MIPS: io: Add barrier after register read in readX()
authorSinan Kaya <okaya@codeaurora.org>
Fri, 13 Apr 2018 02:30:44 +0000 (22:30 -0400)
committerJames Hogan <jhogan@kernel.org>
Fri, 13 Apr 2018 23:46:53 +0000 (00:46 +0100)
While a barrier is present in the writeX() functions before the register
write, a similar barrier is missing in the readX() functions after the
register read. This could allow memory accesses following readX() to
observe stale data.

Signed-off-by: Sinan Kaya <okaya@codeaurora.org>
Reported-by: Arnd Bergmann <arnd@arndb.de>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Paul Burton <paul.burton@mips.com>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/19069/
[jhogan@kernel.org: Tidy commit message]
Signed-off-by: James Hogan <jhogan@kernel.org>
arch/mips/include/asm/io.h

index fd00ddafb425e2f8529ed15a6b2c9c69c6e8ad09..a7d0b836f2f7dd9c8bf7897759aed6b9f59ade39 100644 (file)
@@ -377,6 +377,8 @@ static inline type pfx##read##bwlq(const volatile void __iomem *mem)        \
                BUG();                                                  \
        }                                                               \
                                                                        \
+       /* prevent prefetching of coherent DMA data prematurely */      \
+       rmb();                                                          \
        return pfx##ioswab##bwlq(__mem, __val);                         \
 }