[PATCH] AVR32: Use __raw MMIO access for internal peripherals
authorHaavard Skinnemoen <hskinnemoen@atmel.com>
Tue, 24 Oct 2006 08:12:45 +0000 (10:12 +0200)
committerLinus Torvalds <torvalds@g5.osdl.org>
Thu, 26 Oct 2006 03:26:33 +0000 (20:26 -0700)
The read[bwl] and write[bwl] functions are meant for accessing PCI
devices. How this is achieved on AVR32 is unknown, as there are no
systems with a PCI bridge available yet.

On-chip peripheral access, however, should not depend on how we end
up implementing PCI access, so using __raw_read[bwl]/__raw_write[bwl]
is the right thing to do for on-chip peripherals. This patch converts
the drivers for the static memory controller, interrupt controller,
PIO controller and system manager to use __raw MMIO access.

Signed-off-by: Haavard Skinnemoen <hskinnemoen@atmel.com>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
arch/avr32/mach-at32ap/hsmc.h
arch/avr32/mach-at32ap/intc.h
arch/avr32/mach-at32ap/pio.h
arch/avr32/mach-at32ap/sm.h

index 5681276fafdb88b801c5db9d1736a2afd6e4691a..d1d48e26e39378702eee37b4d7e148ddf76306ea 100644 (file)
 
 /* Register access macros */
 #define hsmc_readl(port,reg)                                           \
-       readl((port)->regs + HSMC_##reg)
+       __raw_readl((port)->regs + HSMC_##reg)
 #define hsmc_writel(port,reg,value)                                    \
-       writel((value), (port)->regs + HSMC_##reg)
+       __raw_writel((value), (port)->regs + HSMC_##reg)
 
 #endif /* __ASM_AVR32_HSMC_H__ */
index d289ca2fff13bf9de671527ce6348f8eb92a7b49..4d3664e43a8e605218bd23dafc72d8821d7c8b68 100644 (file)
 #define INTC_MKBF(name, value)       (((value) & ((1 << INTC_##name##_SIZE) - 1)) << INTC_##name##_OFFSET)
 #define INTC_GETBF(name, value)      (((value) >> INTC_##name##_OFFSET) & ((1 << INTC_##name##_SIZE) - 1))
 
-#define intc_readl(port,reg)         readl((port)->regs + INTC_##reg)
-#define intc_writel(port,reg,value)  writel((value), (port)->regs + INTC_##reg)
+#define intc_readl(port,reg)                                   \
+       __raw_readl((port)->regs + INTC_##reg)
+#define intc_writel(port,reg,value)                            \
+       __raw_writel((value), (port)->regs + INTC_##reg)
 
 #endif /* __ASM_AVR32_PERIHP_INTC_H__ */
index cfea123515993bb9dc0e3392d771c24303501dd9..50fa3aca32c58c23f471469e2def0c02767b2491 100644 (file)
 #define PIO_BFINS(name,value,old)              (((old) & ~(((1 << PIO_##name##_SIZE) - 1) << PIO_##name##_OFFSET)) | PIO_BF(name,value))
 
 /* Register access macros */
-#define pio_readl(port,reg)                    readl((port)->regs + PIO_##reg)
-#define pio_writel(port,reg,value)             writel((value), (port)->regs + PIO_##reg)
+#define pio_readl(port,reg)                                    \
+       __raw_readl((port)->regs + PIO_##reg)
+#define pio_writel(port,reg,value)                             \
+       __raw_writel((value), (port)->regs + PIO_##reg)
 
 void at32_init_pio(struct platform_device *pdev);
 
index 27565822ae2a3e08590447567434c8f9ee7b797a..cad02b512bcb68f4d65cd4e41d5ce5206d1b9896 100644 (file)
 #define SM_BFINS(name,value,old)                (((old) & ~(((1 << SM_##name##_SIZE) - 1) << SM_##name##_OFFSET)) | SM_BF(name,value))
 
 /* Register access macros */
-#define sm_readl(port,reg)                      readl((port)->regs + SM_##reg)
-#define sm_writel(port,reg,value)               writel((value), (port)->regs + SM_##reg)
+#define sm_readl(port,reg)                                     \
+       __raw_readl((port)->regs + SM_##reg)
+#define sm_writel(port,reg,value)                              \
+       __raw_writel((value), (port)->regs + SM_##reg)
 
 #endif /* __ASM_AVR32_SM_H__ */