[PATCH v3 2/2] MIPS: io: add a barrier after register read in readX()

David Laight David.Laight at ACULAB.COM
Fri Apr 13 08:41:00 PDT 2018


From: James Hogan
> Sent: 12 April 2018 22:52
> On Tue, Apr 03, 2018 at 08:55:04AM -0400, Sinan Kaya wrote:
> > While a barrier is present in writeX() function before the register write,
> > a similar barrier is missing in the readX() function after the register
> > read. This could allow memory accesses following readX() to observe
> > stale data.
> >
> > Signed-off-by: Sinan Kaya <okaya at codeaurora.org>
> > Reported-by: Arnd Bergmann <arnd at arndb.de>
> 
> Both patches look like obvious improvements to me, so I'm happy to apply
> to my fixes branch.

Don't you also need at least barrier() between the register write in writeX()
and the register read in readX()?
On ppc you probably need eieio.
Or are drivers expected to insert that one?
If they need to insert that one then why not all the others??

	David



More information about the linux-arm-kernel mailing list