Commit aecc787c authored by Logan Gunthorpe's avatar Logan Gunthorpe Committed by Greg Kroah-Hartman

iomap: Use non-raw io functions for io{read|write}XXbe

Fix an asymmetry in the io{read|write}XXbe functions in that the
big-endian variants make use of the raw io accessors while the
little-endian variants use the regular accessors. Some architectures
implement barriers to order against both spinlocks and DMA accesses
and for these case, the big-endian variant of the API would not be
protected.

Thus, change the mmio_XXXXbe macros to use the appropriate swab() function
wrapping the regular accessor. This is similar to what was done for PIO.

When this code was originally written, barriers in the IO accessors were
not common and the accessors simply wrapped the raw functions in a
conversion to CPU endianness. Since then, barriers have been added in
some architectures and are now missing in the big endian variant of the
API.

This also manages to silence a few sparse warnings that check
for using the correct endian types which the original code did
not annotate correctly.
Signed-off-by: default avatarLogan Gunthorpe <logang@deltatee.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Kate Stewart <kstewart@linuxfoundation.org>
Cc: Philippe Ombredanne <pombredanne@nexb.com>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: Arnd Bergmann <arnd@arndb.de>
Link: http://lkml.kernel.org/r/CAK8P3a25zQDxyaY3iVv+JmSSzs7F6ssGc+HdBkGs54ZfViX+Fg@mail.gmail.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent dce6d406
...@@ -65,8 +65,8 @@ static void bad_io_access(unsigned long port, const char *access) ...@@ -65,8 +65,8 @@ static void bad_io_access(unsigned long port, const char *access)
#endif #endif
#ifndef mmio_read16be #ifndef mmio_read16be
#define mmio_read16be(addr) be16_to_cpu(__raw_readw(addr)) #define mmio_read16be(addr) swab16(readw(addr))
#define mmio_read32be(addr) be32_to_cpu(__raw_readl(addr)) #define mmio_read32be(addr) swab32(readl(addr))
#endif #endif
unsigned int ioread8(void __iomem *addr) unsigned int ioread8(void __iomem *addr)
...@@ -106,8 +106,8 @@ EXPORT_SYMBOL(ioread32be); ...@@ -106,8 +106,8 @@ EXPORT_SYMBOL(ioread32be);
#endif #endif
#ifndef mmio_write16be #ifndef mmio_write16be
#define mmio_write16be(val,port) __raw_writew(be16_to_cpu(val),port) #define mmio_write16be(val,port) writew(swab16(val),port)
#define mmio_write32be(val,port) __raw_writel(be32_to_cpu(val),port) #define mmio_write32be(val,port) writel(swab32(val),port)
#endif #endif
void iowrite8(u8 val, void __iomem *addr) void iowrite8(u8 val, void __iomem *addr)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment