Chris Wilson <chris@xxxxxxxxxxxxxxxxxx> writes: > When reading from the HWS page, we use barrier() to prevent the compiler > optimising away the read from the volatile (may be updated by the GPU) > memory address. This is more suited to READ_ONCE(); make it so. > > Signed-off-by: Chris Wilson <chris@xxxxxxxxxxxxxxxxxx> > Cc: Daniel Vetter <daniel.vetter@xxxxxxxx> After reading Documentation/memory-barriers.txt I feel that deodorant failed. I confirmed my confusion about hws page cacheability from Chris, and it is snooped. The barrier here is superset of what we need. We need to instruct compiler to throw out compiler cached value of this particular address, not everything it had. So it makes sense to me. Reviewed-by: Mika Kuoppala <mika.kuoppala@xxxxxxxxx> > --- > drivers/gpu/drm/i915/intel_ringbuffer.h | 3 +-- > 1 file changed, 1 insertion(+), 2 deletions(-) > > diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.h b/drivers/gpu/drm/i915/intel_ringbuffer.h > index 6cc8e9c5f8d6..8f305ce253ae 100644 > --- a/drivers/gpu/drm/i915/intel_ringbuffer.h > +++ b/drivers/gpu/drm/i915/intel_ringbuffer.h > @@ -418,8 +418,7 @@ intel_read_status_page(struct intel_engine_cs *ring, > int reg) > { > /* Ensure that the compiler doesn't optimize away the load. */ > - barrier(); > - return ring->status_page.page_addr[reg]; > + return READ_ONCE(ring->status_page.page_addr[reg]); > } > > static inline void > -- > 2.7.0.rc3 > > _______________________________________________ > Intel-gfx mailing list > Intel-gfx@xxxxxxxxxxxxxxxxxxxxx > http://lists.freedesktop.org/mailman/listinfo/intel-gfx _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/intel-gfx