Skip to content

Commit

Permalink
drm/i915: Fix wrong return value
Browse files Browse the repository at this point in the history
In function i915_active_acquire_preallocate_barrier(), not all
paths have the return value set correctly, and in case of memory
allocation failure, a negative error code should be returned.

Cc: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Tianjia Zhang <tianjia.zhang@linux.alibaba.com>
Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Link: https://patchwork.freedesktop.org/patch/msgid/20200802115655.25568-1-chris@chris-wilson.co.uk
Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
  • Loading branch information
uudiin authored and rodrigovivi committed Aug 17, 2020
1 parent ecb40d0 commit e714977
Show file tree
Hide file tree
Showing 2 changed files with 3 additions and 6 deletions.
7 changes: 2 additions & 5 deletions drivers/gpu/drm/i915/i915_active.c
Original file line number Diff line number Diff line change
Expand Up @@ -758,7 +758,6 @@ int i915_active_acquire_preallocate_barrier(struct i915_active *ref,
intel_engine_mask_t tmp, mask = engine->mask;
struct llist_node *first = NULL, *last = NULL;
struct intel_gt *gt = engine->gt;
int err;

GEM_BUG_ON(i915_active_is_idle(ref));

Expand All @@ -781,10 +780,8 @@ int i915_active_acquire_preallocate_barrier(struct i915_active *ref,
node = reuse_idle_barrier(ref, idx);
if (!node) {
node = kmem_cache_alloc(global.slab_cache, GFP_KERNEL);
if (!node) {
err = ENOMEM;
if (!node)
goto unwind;
}

RCU_INIT_POINTER(node->base.fence, NULL);
node->base.cb.func = node_retire;
Expand Down Expand Up @@ -832,7 +829,7 @@ int i915_active_acquire_preallocate_barrier(struct i915_active *ref,

kmem_cache_free(global.slab_cache, node);
}
return err;
return -ENOMEM;
}

void i915_active_acquire_barrier(struct i915_active *ref)
Expand Down
2 changes: 1 addition & 1 deletion drivers/gpu/drm/i915/selftests/i915_request.c
Original file line number Diff line number Diff line change
Expand Up @@ -331,7 +331,7 @@ static int __igt_breadcrumbs_smoketest(void *arg)
if (!wait) {
i915_sw_fence_commit(submit);
heap_fence_put(submit);
err = ENOMEM;
err = -ENOMEM;
break;
}

Expand Down

0 comments on commit e714977

Please sign in to comment.