Re: [Intel-gfx] [PATCH 1/5] drm/i915: document caching related bits

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Jul 13, 2021 at 07:24:23PM +0100, Matthew Auld wrote:
> On Tue, 13 Jul 2021 at 18:47, Ville Syrjälä
> <ville.syrjala@xxxxxxxxxxxxxxx> wrote:
> >
> > On Tue, Jul 13, 2021 at 05:13:37PM +0100, Matthew Auld wrote:
> > > On Tue, 13 Jul 2021 at 16:55, Ville Syrjälä
> > > <ville.syrjala@xxxxxxxxxxxxxxx> wrote:
> > > >
> > > > On Tue, Jul 13, 2021 at 11:45:50AM +0100, Matthew Auld wrote:
> > > > > +     /**
> > > > > +      * @cache_coherent:
> > > > > +      *
> > > > > +      * Track whether the pages are coherent with the GPU if reading or
> > > > > +      * writing through the CPU cache.
> > > > > +      *
> > > > > +      * This largely depends on the @cache_level, for example if the object
> > > > > +      * is marked as I915_CACHE_LLC, then GPU access is coherent for both
> > > > > +      * reads and writes through the CPU cache.
> > > > > +      *
> > > > > +      * Note that on platforms with shared-LLC support(HAS_LLC) reads through
> > > > > +      * the CPU cache are always coherent, regardless of the @cache_level. On
> > > > > +      * snooping based platforms this is not the case, unless the full
> > > > > +      * I915_CACHE_LLC or similar setting is used.
> > > > > +      *
> > > > > +      * As a result of this we need to track coherency separately for reads
> > > > > +      * and writes, in order to avoid superfluous flushing on shared-LLC
> > > > > +      * platforms, for reads.
> > > > > +      *
> > > > > +      * I915_BO_CACHE_COHERENT_FOR_READ:
> > > > > +      *
> > > > > +      * When reading through the CPU cache, the GPU is still coherent. Note
> > > > > +      * that no data has actually been modified here, so it might seem
> > > > > +      * strange that we care about this.
> > > > > +      *
> > > > > +      * As an example, if some object is mapped on the CPU with write-back
> > > > > +      * caching, and we read some page, then the cache likely now contains
> > > > > +      * the data from that read. At this point the cache and main memory
> > > > > +      * match up, so all good. But next the GPU needs to write some data to
> > > > > +      * that same page. Now if the @cache_level is I915_CACHE_NONE and the
> > > > > +      * the platform doesn't have the shared-LLC, then the GPU will
> > > > > +      * effectively skip invalidating the cache(or however that works
> > > > > +      * internally) when writing the new value.  This is really bad since the
> > > > > +      * GPU has just written some new data to main memory, but the CPU cache
> > > > > +      * is still valid and now contains stale data. As a result the next time
> > > > > +      * we do a cached read with the CPU, we are rewarded with stale data.
> > > > > +      * Likewise if the cache is later flushed, we might be rewarded with
> > > > > +      * overwriting main memory with stale data.
> > > > > +      *
> > > > > +      * I915_BO_CACHE_COHERENT_FOR_WRITE:
> > > > > +      *
> > > > > +      * When writing through the CPU cache, the GPU is still coherent. Note
> > > > > +      * that this also implies I915_BO_CACHE_COHERENT_FOR_READ.
> > > > > +      *
> > > > > +      * This is never set when I915_CACHE_NONE is used for @cache_level,
> > > > > +      * where instead we have to manually flush the caches after writing
> > > > > +      * through the CPU cache. For other cache levels this should be set and
> > > > > +      * the object is therefore considered coherent for both reads and writes
> > > > > +      * through the CPU cache.
> > > >
> > > > I don't remember why we have this read vs. write split and this new
> > > > documentation doesn't seem to really explain it either.
> > >
> > > Hmm, I attempted to explain that earlier:
> > >
> > > * Note that on platforms with shared-LLC support(HAS_LLC) reads through
> > > * the CPU cache are always coherent, regardless of the @cache_level. On
> > > * snooping based platforms this is not the case, unless the full
> > > * I915_CACHE_LLC or similar setting is used.
> > > *
> > > * As a result of this we need to track coherency separately for reads
> > > * and writes, in order to avoid superfluous flushing on shared-LLC
> > > * platforms, for reads.
> > >
> > > So AFAIK it's just because shared-LLC can be coherent for reads, while
> > > also not being coherent for writes(CACHE_NONE),
> >
> > CPU vs. GPU is fully coherent when it comes to LLC. Or at least I've
> > never heard of any mechanism that would make it only partially coherent.
> 
> What do you mean by "comes to LLC", are you talking about HAS_LLC() or
> I915_CACHE_LLC?

I'm talking about the actual cache.

> 
> If you set I915_CACHE_LLC, then yes it is fully coherent for both
> HAS_LLC() and HAS_SNOOP().
> 
> If you set I915_CACHE_NONE, then reads are still coherent on
> HAS_LLC(),

Reads and writes both. The only thing that's not coherent is the
display engine.

> for HAS_SNOOP() they are not. Or at least that is the
> existing behaviour in the driver AFAIK.
> 
> >
> > --
> > Ville Syrjälä
> > Intel

-- 
Ville Syrjälä
Intel



[Index of Archives]     [Linux DRI Users]     [Linux Intel Graphics]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux