diff options
author | Greg Ungerer <gerg@linux-m68k.org> | 2018-03-26 03:35:13 +0200 |
---|---|---|
committer | Greg Ungerer <gerg@linux-m68k.org> | 2018-05-28 01:45:26 +0200 |
commit | 4478048b4485285353cc095a47683d2a86509c7d (patch) | |
tree | b3e4ea471298b7dbd495ad127569a8e3ed8036c0 | |
parent | m68k: use asm-generic/io.h for non-MMU io access functions (diff) | |
download | linux-4478048b4485285353cc095a47683d2a86509c7d.tar.xz linux-4478048b4485285353cc095a47683d2a86509c7d.zip |
m68k: rework raw access macros for the non-MMU case
The primary and fundamental access macros are really the __raw versions.
So make them the actual implementation for access, and not the read/write
access macros. The read/write macros and functions are built on top of
the raw access (with byte swapping or other actions as required).
This in itself causes no functional change right now. But it will make it
easier to fix and resolve problems with PCI bus access in the future.
Signed-off-by: Greg Ungerer <gerg@linux-m68k.org>
Reviewed-by: Angelo Dureghello <angelo@sysam.it>
Tested-by: Angelo Dureghello <angelo@sysam.it>
-rw-r--r-- | arch/m68k/include/asm/io_no.h | 24 |
1 files changed, 12 insertions, 12 deletions
diff --git a/arch/m68k/include/asm/io_no.h b/arch/m68k/include/asm/io_no.h index acd049824dec..5095693e46ce 100644 --- a/arch/m68k/include/asm/io_no.h +++ b/arch/m68k/include/asm/io_no.h @@ -7,23 +7,23 @@ * functions have always worked in CPU native endian. We need to define * that behavior here first before we include asm-generic/io.h. */ -#define readb(addr) \ +#define __raw_readb(addr) \ ({ unsigned char __v = (*(volatile unsigned char *) (addr)); __v; }) -#define readw(addr) \ +#define __raw_readw(addr) \ ({ unsigned short __v = (*(volatile unsigned short *) (addr)); __v; }) -#define readl(addr) \ +#define __raw_readl(addr) \ ({ unsigned int __v = (*(volatile unsigned int *) (addr)); __v; }) -#define writeb(b,addr) (void)((*(volatile unsigned char *) (addr)) = (b)) -#define writew(b,addr) (void)((*(volatile unsigned short *) (addr)) = (b)) -#define writel(b,addr) (void)((*(volatile unsigned int *) (addr)) = (b)) +#define __raw_writeb(b, addr) (void)((*(volatile unsigned char *) (addr)) = (b)) +#define __raw_writew(b, addr) (void)((*(volatile unsigned short *) (addr)) = (b)) +#define __raw_writel(b, addr) (void)((*(volatile unsigned int *) (addr)) = (b)) -#define __raw_readb readb -#define __raw_readw readw -#define __raw_readl readl -#define __raw_writeb writeb -#define __raw_writew writew -#define __raw_writel writel +#define readb __raw_readb +#define readw __raw_readw +#define readl __raw_readl +#define writeb __raw_writeb +#define writew __raw_writew +#define writel __raw_writel #include <asm/virtconvert.h> #include <asm-generic/io.h> |