Commit 416d3838 authored by Chris Wilson's avatar Chris Wilson

drm/i915: Satisfy smatch that a loop has at least one iteration

Smatch worries that the engine->mask may be 0 leading to the loop being
shortcircuited leaving the next pointer unset,

drivers/gpu/drm/i915/i915_active.c:667 i915_active_acquire_preallocate_barrier() error: uninitialized symbol 'next'.

Assert that mask is not 0 and smatch can then verify that next must be
initialised before use.
Signed-off-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Reviewed-by: default avatarMatthew Auld <matthew.auld@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200117110603.2982286-1-chris@chris-wilson.co.uk
parent f1766e3a
...@@ -621,6 +621,7 @@ int i915_active_acquire_preallocate_barrier(struct i915_active *ref, ...@@ -621,6 +621,7 @@ int i915_active_acquire_preallocate_barrier(struct i915_active *ref,
* We can then use the preallocated nodes in * We can then use the preallocated nodes in
* i915_active_acquire_barrier() * i915_active_acquire_barrier()
*/ */
GEM_BUG_ON(!mask);
for_each_engine_masked(engine, gt, mask, tmp) { for_each_engine_masked(engine, gt, mask, tmp) {
u64 idx = engine->kernel_context->timeline->fence_context; u64 idx = engine->kernel_context->timeline->fence_context;
struct active_node *node; struct active_node *node;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment