[PATCH 01/10] dma-buf: make fence sequence numbers 64 bit v2

Chris Wilson chris at chris-wilson.co.uk
Tue Dec 4 12:57:02 UTC 2018


Quoting Chris Wilson (2018-12-04 12:52:15)
> Quoting Christian König (2018-12-04 11:59:39)
> > -static inline bool __dma_fence_is_later(u32 f1, u32 f2)
> > +static inline bool __dma_fence_is_later(u64 f1, u64 f2)
> >  {
> > -       return (int)(f1 - f2) > 0;
> > +       /* This is for backward compatibility with drivers which can only handle
> > +        * 32bit sequence numbers. Use a 64bit compare when any of the higher
> > +        * bits are none zero, otherwise use a 32bit compare with wrap around
> > +        * handling.
> > +        */
> > +       if (upper_32_bits(f1) || upper_32_bits(f2))
> > +               return f1 > f2;
> > +
> > +       return (int)(lower_32_bits(f1) - lower_32_bits(f2)) > 0;
> 
> Or just "(int64_t)(f1 - f2) > 0", works if drivers are only using the low
> 32b and if they use the full 64b.

No, it doesn't.
-Chris


More information about the dri-devel mailing list