Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 452976b2 authored by Haavard Skinnemoen's avatar Haavard Skinnemoen Committed by Linus Torvalds
Browse files

[PATCH] AVR32: Use __raw MMIO access for internal peripherals



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: default avatarHaavard Skinnemoen <hskinnemoen@atmel.com>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent d68041cc
Loading
Loading
Loading
Loading
+2 −2
Original line number Diff line number Diff line
@@ -120,8 +120,8 @@

/* 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__ */
+4 −2
Original line number Diff line number Diff line
@@ -321,7 +321,9 @@
#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__ */
+4 −2
Original line number Diff line number Diff line
@@ -170,8 +170,10 @@
#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);

+4 −2
Original line number Diff line number Diff line
@@ -234,7 +234,9 @@
#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__ */