ARM: io: fix ioremap_wt() implementation
authorRussell King <rmk+kernel@arm.linux.org.uk>
Wed, 1 Jul 2015 09:17:55 +0000 (10:17 +0100)
committerRussell King <rmk+kernel@arm.linux.org.uk>
Fri, 3 Jul 2015 14:00:23 +0000 (15:00 +0100)
commit1e2c727f6c022778d4562147433ca4c0b101f0ad
tree6603b8b4554880e9f0f210d3ac2c2d3a18d0f84a
parentac5e2f170f033e48cfcdc2c4f74b27083eabffa5
ARM: io: fix ioremap_wt() implementation

ioremap_wt() was added by aliasing it to ioremap_nocache(), which is a
device mapping.  Device mappings do not allow unaligned accesses, but
it appears that GCC is able to inline its own memcpy() implementation
which may use such accesses.  The only user of this is pmem, which
uses memcpy() on the region.

Therefore, this is unsafe.  We must implement ioremap_wt() correctly
for ARM, or not at all.

This patch adds a more correct implementation by re-using ioremap_wc()
to provide a normal-memory non-cacheable mapping.

Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
arch/arm/include/asm/io.h