OSDN Git Service

drm/i915/perf: don't read head/tail pointers outside critical section
authorLionel Landwerlin <lionel.g.landwerlin@intel.com>
Mon, 30 Mar 2020 09:14:11 +0000 (12:14 +0300)
committerLionel Landwerlin <lionel.g.landwerlin@intel.com>
Tue, 31 Mar 2020 08:47:19 +0000 (11:47 +0300)
Reading or writing those fields should only happen under
stream->oa_buffer.ptr_lock.

Signed-off-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com>
Fixes: d1df41eb72ef ("drm/i915/perf: rework aging tail workaround")
Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
Acked-by: Ashutosh Dixit <ashutosh.dixit@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200330091411.37357-1-lionel.g.landwerlin@intel.com
drivers/gpu/drm/i915/i915_perf.c

index dc0365d..28e3d76 100644 (file)
@@ -463,6 +463,7 @@ static bool oa_buffer_check_unlocked(struct i915_perf_stream *stream)
        u32 gtt_offset = i915_ggtt_offset(stream->oa_buffer.vma);
        int report_size = stream->oa_buffer.format_size;
        unsigned long flags;
+       bool pollin;
        u32 hw_tail;
        u64 now;
 
@@ -532,10 +533,12 @@ static bool oa_buffer_check_unlocked(struct i915_perf_stream *stream)
                stream->oa_buffer.aging_timestamp = now;
        }
 
+       pollin = OA_TAKEN(stream->oa_buffer.tail - gtt_offset,
+                         stream->oa_buffer.head - gtt_offset) >= report_size;
+
        spin_unlock_irqrestore(&stream->oa_buffer.ptr_lock, flags);
 
-       return OA_TAKEN(stream->oa_buffer.tail - gtt_offset,
-                       stream->oa_buffer.head - gtt_offset) >= report_size;
+       return pollin;
 }
 
 /**