diff mbox series

linux/io.h: import generic ioread* / iowrite* accessors from Linux

Message ID 1503676959-25682-1-git-send-email-yamada.masahiro@socionext.com
State Accepted
Commit 6c06f8dc4ab02890ef93b50dac129c2b43cc9ea3
Headers show
Series linux/io.h: import generic ioread* / iowrite* accessors from Linux | expand

Commit Message

Masahiro Yamada Aug. 25, 2017, 4:02 p.m. UTC
Some drivers in Linux (ex. drivers/mtd/nand/denali.c) use
ioread*/iowrite* accessors.  Import them to make drivers more
synced.  I copied code from include/asm-generic/io.h of Linux.

Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
---

 include/linux/io.h | 44 ++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 44 insertions(+)

Comments

Tom Rini Sept. 13, 2017, 2:29 a.m. UTC | #1
On Sat, Aug 26, 2017 at 01:02:39AM +0900, Masahiro Yamada wrote:

> Some drivers in Linux (ex. drivers/mtd/nand/denali.c) use

> ioread*/iowrite* accessors.  Import them to make drivers more

> synced.  I copied code from include/asm-generic/io.h of Linux.

> 

> Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>


Applied to u-boot/master, thanks!

-- 
Tom
diff mbox series

Patch

diff --git a/include/linux/io.h b/include/linux/io.h
index a104b7e69f7c..bf1ddbbaa671 100644
--- a/include/linux/io.h
+++ b/include/linux/io.h
@@ -9,6 +9,50 @@ 
 #include <linux/types.h>
 #include <asm/io.h>
 
+static inline u8 ioread8(const volatile void __iomem *addr)
+{
+	return readb(addr);
+}
+
+static inline u16 ioread16(const volatile void __iomem *addr)
+{
+	return readw(addr);
+}
+
+static inline u32 ioread32(const volatile void __iomem *addr)
+{
+	return readl(addr);
+}
+
+#ifdef CONFIG_64BIT
+static inline u64 ioread64(const volatile void __iomem *addr)
+{
+	return readq(addr);
+}
+#endif /* CONFIG_64BIT */
+
+static inline void iowrite8(u8 value, volatile void __iomem *addr)
+{
+	writeb(value, addr);
+}
+
+static inline void iowrite16(u16 value, volatile void __iomem *addr)
+{
+	writew(value, addr);
+}
+
+static inline void iowrite32(u32 value, volatile void __iomem *addr)
+{
+	writel(value, addr);
+}
+
+#ifdef CONFIG_64BIT
+static inline void iowrite64(u64 value, volatile void __iomem *addr)
+{
+	writeq(value, addr);
+}
+#endif /* CONFIG_64BIT */
+
 #ifndef CONFIG_HAVE_ARCH_IOREMAP
 static inline void __iomem *ioremap(resource_size_t offset,
 				    resource_size_t size)