[PATCH 17/19] iop3xx: define IOP3XX_REG_ADDR[32|16|8] and clean up DMA/AAU defs

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



From: Dan Williams <[email protected]>

Also brings the iop3xx registers in line with the format of the iop13xx
register definitions.

Signed-off-by: Dan Williams <[email protected]>
---

 include/asm-arm/arch-iop32x/entry-macro.S |    2 
 include/asm-arm/arch-iop32x/iop32x.h      |   14 +
 include/asm-arm/arch-iop33x/entry-macro.S |    2 
 include/asm-arm/arch-iop33x/iop33x.h      |   38 ++-
 include/asm-arm/hardware/iop3xx.h         |  347 +++++++++++++----------------
 5 files changed, 188 insertions(+), 215 deletions(-)

diff --git a/include/asm-arm/arch-iop32x/entry-macro.S b/include/asm-arm/arch-iop32x/entry-macro.S
index 1500cbb..f357be4 100644
--- a/include/asm-arm/arch-iop32x/entry-macro.S
+++ b/include/asm-arm/arch-iop32x/entry-macro.S
@@ -13,7 +13,7 @@ #include <asm/arch/iop32x.h>
 		.endm
 
 		.macro	get_irqnr_and_base, irqnr, irqstat, base, tmp
-		ldr	\base, =IOP3XX_REG_ADDR(0x07D8)
+		ldr	\base, =0xfeffe7d8
 		ldr	\irqstat, [\base]		@ Read IINTSRC
 		cmp	\irqstat, #0
 		clzne	\irqnr, \irqstat
diff --git a/include/asm-arm/arch-iop32x/iop32x.h b/include/asm-arm/arch-iop32x/iop32x.h
index 15b4d6a..904a14d 100644
--- a/include/asm-arm/arch-iop32x/iop32x.h
+++ b/include/asm-arm/arch-iop32x/iop32x.h
@@ -19,16 +19,18 @@ #define __IOP32X_H
  * Peripherals that are shared between the iop32x and iop33x but
  * located at different addresses.
  */
-#define IOP3XX_GPIO_REG(reg)	(IOP3XX_PERIPHERAL_VIRT_BASE + 0x07c0 + (reg))
-#define IOP3XX_TIMER_REG(reg)	(IOP3XX_PERIPHERAL_VIRT_BASE + 0x07e0 + (reg))
+#define IOP3XX_GPIO_REG32(reg)	 (volatile u32 *)(IOP3XX_PERIPHERAL_VIRT_BASE +\
+						  0x07c0 + (reg))
+#define IOP3XX_TIMER_REG32(reg) (volatile u32 *)(IOP3XX_PERIPHERAL_VIRT_BASE +\
+						  0x07e0 + (reg))
 
 #include <asm/hardware/iop3xx.h>
 
 /* Interrupt Controller  */
-#define IOP32X_INTCTL		(volatile u32 *)IOP3XX_REG_ADDR(0x07d0)
-#define IOP32X_INTSTR		(volatile u32 *)IOP3XX_REG_ADDR(0x07d4)
-#define IOP32X_IINTSRC		(volatile u32 *)IOP3XX_REG_ADDR(0x07d8)
-#define IOP32X_FINTSRC		(volatile u32 *)IOP3XX_REG_ADDR(0x07dc)
+#define IOP32X_INTCTL		IOP3XX_REG_ADDR32(0x07d0)
+#define IOP32X_INTSTR		IOP3XX_REG_ADDR32(0x07d4)
+#define IOP32X_IINTSRC		IOP3XX_REG_ADDR32(0x07d8)
+#define IOP32X_FINTSRC		IOP3XX_REG_ADDR32(0x07dc)
 
 
 #endif
diff --git a/include/asm-arm/arch-iop33x/entry-macro.S b/include/asm-arm/arch-iop33x/entry-macro.S
index 92b7917..eb207d2 100644
--- a/include/asm-arm/arch-iop33x/entry-macro.S
+++ b/include/asm-arm/arch-iop33x/entry-macro.S
@@ -13,7 +13,7 @@ #include <asm/arch/iop33x.h>
 		.endm
 
 		.macro	get_irqnr_and_base, irqnr, irqstat, base, tmp
-		ldr	\base, =IOP3XX_REG_ADDR(0x07C8)
+		ldr	\base, =0xfeffe7c8
 		ldr	\irqstat, [\base]		@ Read IINTVEC
 		cmp	\irqstat, #0
 		ldreq	\irqstat, [\base]		@ erratum 63 workaround
diff --git a/include/asm-arm/arch-iop33x/iop33x.h b/include/asm-arm/arch-iop33x/iop33x.h
index 9b38fde..c171383 100644
--- a/include/asm-arm/arch-iop33x/iop33x.h
+++ b/include/asm-arm/arch-iop33x/iop33x.h
@@ -18,28 +18,30 @@ #define __IOP33X_H
  * Peripherals that are shared between the iop32x and iop33x but
  * located at different addresses.
  */
-#define IOP3XX_GPIO_REG(reg)	(IOP3XX_PERIPHERAL_VIRT_BASE + 0x1780 + (reg))
-#define IOP3XX_TIMER_REG(reg)	(IOP3XX_PERIPHERAL_VIRT_BASE + 0x07d0 + (reg))
+#define IOP3XX_GPIO_REG32(reg)	 (volatile u32 *)(IOP3XX_PERIPHERAL_VIRT_BASE +\
+						  0x1780 + (reg))
+#define IOP3XX_TIMER_REG32(reg) (volatile u32 *)(IOP3XX_PERIPHERAL_VIRT_BASE +\
+						  0x07d0 + (reg))
 
 #include <asm/hardware/iop3xx.h>
 
 /* Interrupt Controller  */
-#define IOP33X_INTCTL0		(volatile u32 *)IOP3XX_REG_ADDR(0x0790)
-#define IOP33X_INTCTL1		(volatile u32 *)IOP3XX_REG_ADDR(0x0794)
-#define IOP33X_INTSTR0		(volatile u32 *)IOP3XX_REG_ADDR(0x0798)
-#define IOP33X_INTSTR1		(volatile u32 *)IOP3XX_REG_ADDR(0x079c)
-#define IOP33X_IINTSRC0		(volatile u32 *)IOP3XX_REG_ADDR(0x07a0)
-#define IOP33X_IINTSRC1		(volatile u32 *)IOP3XX_REG_ADDR(0x07a4)
-#define IOP33X_FINTSRC0		(volatile u32 *)IOP3XX_REG_ADDR(0x07a8)
-#define IOP33X_FINTSRC1		(volatile u32 *)IOP3XX_REG_ADDR(0x07ac)
-#define IOP33X_IPR0		(volatile u32 *)IOP3XX_REG_ADDR(0x07b0)
-#define IOP33X_IPR1		(volatile u32 *)IOP3XX_REG_ADDR(0x07b4)
-#define IOP33X_IPR2		(volatile u32 *)IOP3XX_REG_ADDR(0x07b8)
-#define IOP33X_IPR3		(volatile u32 *)IOP3XX_REG_ADDR(0x07bc)
-#define IOP33X_INTBASE		(volatile u32 *)IOP3XX_REG_ADDR(0x07c0)
-#define IOP33X_INTSIZE		(volatile u32 *)IOP3XX_REG_ADDR(0x07c4)
-#define IOP33X_IINTVEC		(volatile u32 *)IOP3XX_REG_ADDR(0x07c8)
-#define IOP33X_FINTVEC		(volatile u32 *)IOP3XX_REG_ADDR(0x07cc)
+#define IOP33X_INTCTL0		IOP3XX_REG_ADDR32(0x0790)
+#define IOP33X_INTCTL1		IOP3XX_REG_ADDR32(0x0794)
+#define IOP33X_INTSTR0		IOP3XX_REG_ADDR32(0x0798)
+#define IOP33X_INTSTR1		IOP3XX_REG_ADDR32(0x079c)
+#define IOP33X_IINTSRC0	IOP3XX_REG_ADDR32(0x07a0)
+#define IOP33X_IINTSRC1	IOP3XX_REG_ADDR32(0x07a4)
+#define IOP33X_FINTSRC0	IOP3XX_REG_ADDR32(0x07a8)
+#define IOP33X_FINTSRC1	IOP3XX_REG_ADDR32(0x07ac)
+#define IOP33X_IPR0		IOP3XX_REG_ADDR32(0x07b0)
+#define IOP33X_IPR1		IOP3XX_REG_ADDR32(0x07b4)
+#define IOP33X_IPR2		IOP3XX_REG_ADDR32(0x07b8)
+#define IOP33X_IPR3		IOP3XX_REG_ADDR32(0x07bc)
+#define IOP33X_INTBASE		IOP3XX_REG_ADDR32(0x07c0)
+#define IOP33X_INTSIZE		IOP3XX_REG_ADDR32(0x07c4)
+#define IOP33X_IINTVEC		IOP3XX_REG_ADDR32(0x07c8)
+#define IOP33X_FINTVEC		IOP3XX_REG_ADDR32(0x07cc)
 
 /* UARTs  */
 #define IOP33X_UART0_PHYS	(IOP3XX_PERIPHERAL_PHYS_BASE + 0x1700)
diff --git a/include/asm-arm/hardware/iop3xx.h b/include/asm-arm/hardware/iop3xx.h
index b5c12ef..295789a 100644
--- a/include/asm-arm/hardware/iop3xx.h
+++ b/include/asm-arm/hardware/iop3xx.h
@@ -34,153 +34,166 @@ #endif
 /*
  * IOP3XX processor registers
  */
-#define IOP3XX_PERIPHERAL_PHYS_BASE	0xffffe000
-#define IOP3XX_PERIPHERAL_VIRT_BASE	0xfeffe000
-#define IOP3XX_PERIPHERAL_SIZE		0x00002000
-#define IOP3XX_REG_ADDR(reg)		(IOP3XX_PERIPHERAL_VIRT_BASE + (reg))
+#define IOP3XX_PERIPHERAL_PHYS_BASE 0xffffe000
+#define IOP3XX_PERIPHERAL_VIRT_BASE 0xfeffe000
+#define IOP3XX_PERIPHERAL_SIZE	     0x00002000
+#define IOP3XX_REG_ADDR32(reg)	     (volatile u32 *)(IOP3XX_PERIPHERAL_VIRT_BASE + (reg))
+#define IOP3XX_REG_ADDR16(reg)	     (volatile u16 *)(IOP3XX_PERIPHERAL_VIRT_BASE + (reg))
+#define IOP3XX_REG_ADDR8(reg)	     (volatile u8 *)(IOP3XX_PERIPHERAL_VIRT_BASE + (reg))
 
 /* Address Translation Unit  */
-#define IOP3XX_ATUVID		(volatile u16 *)IOP3XX_REG_ADDR(0x0100)
-#define IOP3XX_ATUDID		(volatile u16 *)IOP3XX_REG_ADDR(0x0102)
-#define IOP3XX_ATUCMD		(volatile u16 *)IOP3XX_REG_ADDR(0x0104)
-#define IOP3XX_ATUSR		(volatile u16 *)IOP3XX_REG_ADDR(0x0106)
-#define IOP3XX_ATURID		(volatile u8  *)IOP3XX_REG_ADDR(0x0108)
-#define IOP3XX_ATUCCR		(volatile u32 *)IOP3XX_REG_ADDR(0x0109)
-#define IOP3XX_ATUCLSR		(volatile u8  *)IOP3XX_REG_ADDR(0x010c)
-#define IOP3XX_ATULT		(volatile u8  *)IOP3XX_REG_ADDR(0x010d)
-#define IOP3XX_ATUHTR		(volatile u8  *)IOP3XX_REG_ADDR(0x010e)
-#define IOP3XX_ATUBIST		(volatile u8  *)IOP3XX_REG_ADDR(0x010f)
-#define IOP3XX_IABAR0		(volatile u32 *)IOP3XX_REG_ADDR(0x0110)
-#define IOP3XX_IAUBAR0		(volatile u32 *)IOP3XX_REG_ADDR(0x0114)
-#define IOP3XX_IABAR1		(volatile u32 *)IOP3XX_REG_ADDR(0x0118)
-#define IOP3XX_IAUBAR1		(volatile u32 *)IOP3XX_REG_ADDR(0x011c)
-#define IOP3XX_IABAR2		(volatile u32 *)IOP3XX_REG_ADDR(0x0120)
-#define IOP3XX_IAUBAR2		(volatile u32 *)IOP3XX_REG_ADDR(0x0124)
-#define IOP3XX_ASVIR		(volatile u16 *)IOP3XX_REG_ADDR(0x012c)
-#define IOP3XX_ASIR		(volatile u16 *)IOP3XX_REG_ADDR(0x012e)
-#define IOP3XX_ERBAR		(volatile u32 *)IOP3XX_REG_ADDR(0x0130)
-#define IOP3XX_ATUILR		(volatile u8  *)IOP3XX_REG_ADDR(0x013c)
-#define IOP3XX_ATUIPR		(volatile u8  *)IOP3XX_REG_ADDR(0x013d)
-#define IOP3XX_ATUMGNT		(volatile u8  *)IOP3XX_REG_ADDR(0x013e)
-#define IOP3XX_ATUMLAT		(volatile u8  *)IOP3XX_REG_ADDR(0x013f)
-#define IOP3XX_IALR0		(volatile u32 *)IOP3XX_REG_ADDR(0x0140)
-#define IOP3XX_IATVR0		(volatile u32 *)IOP3XX_REG_ADDR(0x0144)
-#define IOP3XX_ERLR		(volatile u32 *)IOP3XX_REG_ADDR(0x0148)
-#define IOP3XX_ERTVR		(volatile u32 *)IOP3XX_REG_ADDR(0x014c)
-#define IOP3XX_IALR1		(volatile u32 *)IOP3XX_REG_ADDR(0x0150)
-#define IOP3XX_IALR2		(volatile u32 *)IOP3XX_REG_ADDR(0x0154)
-#define IOP3XX_IATVR2		(volatile u32 *)IOP3XX_REG_ADDR(0x0158)
-#define IOP3XX_OIOWTVR		(volatile u32 *)IOP3XX_REG_ADDR(0x015c)
-#define IOP3XX_OMWTVR0		(volatile u32 *)IOP3XX_REG_ADDR(0x0160)
-#define IOP3XX_OUMWTVR0		(volatile u32 *)IOP3XX_REG_ADDR(0x0164)
-#define IOP3XX_OMWTVR1		(volatile u32 *)IOP3XX_REG_ADDR(0x0168)
-#define IOP3XX_OUMWTVR1		(volatile u32 *)IOP3XX_REG_ADDR(0x016c)
-#define IOP3XX_OUDWTVR		(volatile u32 *)IOP3XX_REG_ADDR(0x0178)
-#define IOP3XX_ATUCR		(volatile u32 *)IOP3XX_REG_ADDR(0x0180)
-#define IOP3XX_PCSR		(volatile u32 *)IOP3XX_REG_ADDR(0x0184)
-#define IOP3XX_ATUISR		(volatile u32 *)IOP3XX_REG_ADDR(0x0188)
-#define IOP3XX_ATUIMR		(volatile u32 *)IOP3XX_REG_ADDR(0x018c)
-#define IOP3XX_IABAR3		(volatile u32 *)IOP3XX_REG_ADDR(0x0190)
-#define IOP3XX_IAUBAR3		(volatile u32 *)IOP3XX_REG_ADDR(0x0194)
-#define IOP3XX_IALR3		(volatile u32 *)IOP3XX_REG_ADDR(0x0198)
-#define IOP3XX_IATVR3		(volatile u32 *)IOP3XX_REG_ADDR(0x019c)
-#define IOP3XX_OCCAR		(volatile u32 *)IOP3XX_REG_ADDR(0x01a4)
-#define IOP3XX_OCCDR		(volatile u32 *)IOP3XX_REG_ADDR(0x01ac)
-#define IOP3XX_PDSCR		(volatile u32 *)IOP3XX_REG_ADDR(0x01bc)
-#define IOP3XX_PMCAPID		(volatile u8  *)IOP3XX_REG_ADDR(0x01c0)
-#define IOP3XX_PMNEXT		(volatile u8  *)IOP3XX_REG_ADDR(0x01c1)
-#define IOP3XX_APMCR		(volatile u16 *)IOP3XX_REG_ADDR(0x01c2)
-#define IOP3XX_APMCSR		(volatile u16 *)IOP3XX_REG_ADDR(0x01c4)
-#define IOP3XX_PCIXCAPID	(volatile u8  *)IOP3XX_REG_ADDR(0x01e0)
-#define IOP3XX_PCIXNEXT		(volatile u8  *)IOP3XX_REG_ADDR(0x01e1)
-#define IOP3XX_PCIXCMD		(volatile u16 *)IOP3XX_REG_ADDR(0x01e2)
-#define IOP3XX_PCIXSR		(volatile u32 *)IOP3XX_REG_ADDR(0x01e4)
-#define IOP3XX_PCIIRSR		(volatile u32 *)IOP3XX_REG_ADDR(0x01ec)
+#define IOP3XX_ATUVID		IOP3XX_REG_ADDR16(0x0100)
+#define IOP3XX_ATUDID		IOP3XX_REG_ADDR16(0x0102)
+#define IOP3XX_ATUCMD		IOP3XX_REG_ADDR16(0x0104)
+#define IOP3XX_ATUSR		IOP3XX_REG_ADDR16(0x0106)
+#define IOP3XX_ATURID		IOP3XX_REG_ADDR8(0x0108)
+#define IOP3XX_ATUCCR		IOP3XX_REG_ADDR32(0x0109)
+#define IOP3XX_ATUCLSR		IOP3XX_REG_ADDR8(0x010c)
+#define IOP3XX_ATULT		IOP3XX_REG_ADDR8(0x010d)
+#define IOP3XX_ATUHTR		IOP3XX_REG_ADDR8(0x010e)
+#define IOP3XX_ATUBIST		IOP3XX_REG_ADDR8(0x010f)
+#define IOP3XX_IABAR0		IOP3XX_REG_ADDR32(0x0110)
+#define IOP3XX_IAUBAR0		IOP3XX_REG_ADDR32(0x0114)
+#define IOP3XX_IABAR1		IOP3XX_REG_ADDR32(0x0118)
+#define IOP3XX_IAUBAR1		IOP3XX_REG_ADDR32(0x011c)
+#define IOP3XX_IABAR2		IOP3XX_REG_ADDR32(0x0120)
+#define IOP3XX_IAUBAR2		IOP3XX_REG_ADDR32(0x0124)
+#define IOP3XX_ASVIR		IOP3XX_REG_ADDR16(0x012c)
+#define IOP3XX_ASIR		IOP3XX_REG_ADDR16(0x012e)
+#define IOP3XX_ERBAR		IOP3XX_REG_ADDR32(0x0130)
+#define IOP3XX_ATUILR		IOP3XX_REG_ADDR8(0x013c)
+#define IOP3XX_ATUIPR		IOP3XX_REG_ADDR8(0x013d)
+#define IOP3XX_ATUMGNT		IOP3XX_REG_ADDR8(0x013e)
+#define IOP3XX_ATUMLAT		IOP3XX_REG_ADDR8(0x013f)
+#define IOP3XX_IALR0		IOP3XX_REG_ADDR32(0x0140)
+#define IOP3XX_IATVR0		IOP3XX_REG_ADDR32(0x0144)
+#define IOP3XX_ERLR		IOP3XX_REG_ADDR32(0x0148)
+#define IOP3XX_ERTVR		IOP3XX_REG_ADDR32(0x014c)
+#define IOP3XX_IALR1		IOP3XX_REG_ADDR32(0x0150)
+#define IOP3XX_IALR2		IOP3XX_REG_ADDR32(0x0154)
+#define IOP3XX_IATVR2		IOP3XX_REG_ADDR32(0x0158)
+#define IOP3XX_OIOWTVR		IOP3XX_REG_ADDR32(0x015c)
+#define IOP3XX_OMWTVR0		IOP3XX_REG_ADDR32(0x0160)
+#define IOP3XX_OUMWTVR0	IOP3XX_REG_ADDR32(0x0164)
+#define IOP3XX_OMWTVR1		IOP3XX_REG_ADDR32(0x0168)
+#define IOP3XX_OUMWTVR1	IOP3XX_REG_ADDR32(0x016c)
+#define IOP3XX_OUDWTVR		IOP3XX_REG_ADDR32(0x0178)
+#define IOP3XX_ATUCR		IOP3XX_REG_ADDR32(0x0180)
+#define IOP3XX_PCSR		IOP3XX_REG_ADDR32(0x0184)
+#define IOP3XX_ATUISR		IOP3XX_REG_ADDR32(0x0188)
+#define IOP3XX_ATUIMR		IOP3XX_REG_ADDR32(0x018c)
+#define IOP3XX_IABAR3		IOP3XX_REG_ADDR32(0x0190)
+#define IOP3XX_IAUBAR3		IOP3XX_REG_ADDR32(0x0194)
+#define IOP3XX_IALR3		IOP3XX_REG_ADDR32(0x0198)
+#define IOP3XX_IATVR3		IOP3XX_REG_ADDR32(0x019c)
+#define IOP3XX_OCCAR		IOP3XX_REG_ADDR32(0x01a4)
+#define IOP3XX_OCCDR		IOP3XX_REG_ADDR32(0x01ac)
+#define IOP3XX_PDSCR		IOP3XX_REG_ADDR32(0x01bc)
+#define IOP3XX_PMCAPID		IOP3XX_REG_ADDR8(0x01c0)
+#define IOP3XX_PMNEXT		IOP3XX_REG_ADDR8(0x01c1)
+#define IOP3XX_APMCR		IOP3XX_REG_ADDR16(0x01c2)
+#define IOP3XX_APMCSR		IOP3XX_REG_ADDR16(0x01c4)
+#define IOP3XX_PCIXCAPID	IOP3XX_REG_ADDR8(0x01e0)
+#define IOP3XX_PCIXNEXT	IOP3XX_REG_ADDR8(0x01e1)
+#define IOP3XX_PCIXCMD		IOP3XX_REG_ADDR16(0x01e2)
+#define IOP3XX_PCIXSR		IOP3XX_REG_ADDR32(0x01e4)
+#define IOP3XX_PCIIRSR		IOP3XX_REG_ADDR32(0x01ec)
 
 /* Messaging Unit  */
-#define IOP3XX_IMR0		(volatile u32 *)IOP3XX_REG_ADDR(0x0310)
-#define IOP3XX_IMR1		(volatile u32 *)IOP3XX_REG_ADDR(0x0314)
-#define IOP3XX_OMR0		(volatile u32 *)IOP3XX_REG_ADDR(0x0318)
-#define IOP3XX_OMR1		(volatile u32 *)IOP3XX_REG_ADDR(0x031c)
-#define IOP3XX_IDR		(volatile u32 *)IOP3XX_REG_ADDR(0x0320)
-#define IOP3XX_IISR		(volatile u32 *)IOP3XX_REG_ADDR(0x0324)
-#define IOP3XX_IIMR		(volatile u32 *)IOP3XX_REG_ADDR(0x0328)
-#define IOP3XX_ODR		(volatile u32 *)IOP3XX_REG_ADDR(0x032c)
-#define IOP3XX_OISR		(volatile u32 *)IOP3XX_REG_ADDR(0x0330)
-#define IOP3XX_OIMR		(volatile u32 *)IOP3XX_REG_ADDR(0x0334)
-#define IOP3XX_MUCR		(volatile u32 *)IOP3XX_REG_ADDR(0x0350)
-#define IOP3XX_QBAR		(volatile u32 *)IOP3XX_REG_ADDR(0x0354)
-#define IOP3XX_IFHPR		(volatile u32 *)IOP3XX_REG_ADDR(0x0360)
-#define IOP3XX_IFTPR		(volatile u32 *)IOP3XX_REG_ADDR(0x0364)
-#define IOP3XX_IPHPR		(volatile u32 *)IOP3XX_REG_ADDR(0x0368)
-#define IOP3XX_IPTPR		(volatile u32 *)IOP3XX_REG_ADDR(0x036c)
-#define IOP3XX_OFHPR		(volatile u32 *)IOP3XX_REG_ADDR(0x0370)
-#define IOP3XX_OFTPR		(volatile u32 *)IOP3XX_REG_ADDR(0x0374)
-#define IOP3XX_OPHPR		(volatile u32 *)IOP3XX_REG_ADDR(0x0378)
-#define IOP3XX_OPTPR		(volatile u32 *)IOP3XX_REG_ADDR(0x037c)
-#define IOP3XX_IAR		(volatile u32 *)IOP3XX_REG_ADDR(0x0380)
+#define IOP3XX_IMR0		IOP3XX_REG_ADDR32(0x0310)
+#define IOP3XX_IMR1		IOP3XX_REG_ADDR32(0x0314)
+#define IOP3XX_OMR0		IOP3XX_REG_ADDR32(0x0318)
+#define IOP3XX_OMR1		IOP3XX_REG_ADDR32(0x031c)
+#define IOP3XX_IDR		IOP3XX_REG_ADDR32(0x0320)
+#define IOP3XX_IISR		IOP3XX_REG_ADDR32(0x0324)
+#define IOP3XX_IIMR		IOP3XX_REG_ADDR32(0x0328)
+#define IOP3XX_ODR		IOP3XX_REG_ADDR32(0x032c)
+#define IOP3XX_OISR		IOP3XX_REG_ADDR32(0x0330)
+#define IOP3XX_OIMR		IOP3XX_REG_ADDR32(0x0334)
+#define IOP3XX_MUCR		IOP3XX_REG_ADDR32(0x0350)
+#define IOP3XX_QBAR		IOP3XX_REG_ADDR32(0x0354)
+#define IOP3XX_IFHPR		IOP3XX_REG_ADDR32(0x0360)
+#define IOP3XX_IFTPR		IOP3XX_REG_ADDR32(0x0364)
+#define IOP3XX_IPHPR		IOP3XX_REG_ADDR32(0x0368)
+#define IOP3XX_IPTPR		IOP3XX_REG_ADDR32(0x036c)
+#define IOP3XX_OFHPR		IOP3XX_REG_ADDR32(0x0370)
+#define IOP3XX_OFTPR		IOP3XX_REG_ADDR32(0x0374)
+#define IOP3XX_OPHPR		IOP3XX_REG_ADDR32(0x0378)
+#define IOP3XX_OPTPR		IOP3XX_REG_ADDR32(0x037c)
+#define IOP3XX_IAR		IOP3XX_REG_ADDR32(0x0380)
 
-/* DMA Controller  */
-#define IOP3XX_DMA0_CCR		(volatile u32 *)IOP3XX_REG_ADDR(0x0400)
-#define IOP3XX_DMA0_CSR		(volatile u32 *)IOP3XX_REG_ADDR(0x0404)
-#define IOP3XX_DMA0_DAR		(volatile u32 *)IOP3XX_REG_ADDR(0x040c)
-#define IOP3XX_DMA0_NDAR	(volatile u32 *)IOP3XX_REG_ADDR(0x0410)
-#define IOP3XX_DMA0_PADR	(volatile u32 *)IOP3XX_REG_ADDR(0x0414)
-#define IOP3XX_DMA0_PUADR	(volatile u32 *)IOP3XX_REG_ADDR(0x0418)
-#define IOP3XX_DMA0_LADR	(volatile u32 *)IOP3XX_REG_ADDR(0x041c)
-#define IOP3XX_DMA0_BCR		(volatile u32 *)IOP3XX_REG_ADDR(0x0420)
-#define IOP3XX_DMA0_DCR		(volatile u32 *)IOP3XX_REG_ADDR(0x0424)
-#define IOP3XX_DMA1_CCR		(volatile u32 *)IOP3XX_REG_ADDR(0x0440)
-#define IOP3XX_DMA1_CSR		(volatile u32 *)IOP3XX_REG_ADDR(0x0444)
-#define IOP3XX_DMA1_DAR		(volatile u32 *)IOP3XX_REG_ADDR(0x044c)
-#define IOP3XX_DMA1_NDAR	(volatile u32 *)IOP3XX_REG_ADDR(0x0450)
-#define IOP3XX_DMA1_PADR	(volatile u32 *)IOP3XX_REG_ADDR(0x0454)
-#define IOP3XX_DMA1_PUADR	(volatile u32 *)IOP3XX_REG_ADDR(0x0458)
-#define IOP3XX_DMA1_LADR	(volatile u32 *)IOP3XX_REG_ADDR(0x045c)
-#define IOP3XX_DMA1_BCR		(volatile u32 *)IOP3XX_REG_ADDR(0x0460)
-#define IOP3XX_DMA1_DCR		(volatile u32 *)IOP3XX_REG_ADDR(0x0464)
+/* DMA Controllers  */
+#define IOP3XX_DMA_OFFSET(chan, ofs) 	IOP3XX_REG_ADDR32((chan << 6) + (ofs))
+
+#define IOP3XX_DMA_CCR(chan)		IOP3XX_DMA_OFFSET(chan, 0x0400)
+#define IOP3XX_DMA_CSR(chan)		IOP3XX_DMA_OFFSET(chan, 0x0404)
+#define IOP3XX_DMA_DAR(chan)		IOP3XX_DMA_OFFSET(chan, 0x040c)
+#define IOP3XX_DMA_NDAR(chan)		IOP3XX_DMA_OFFSET(chan, 0x0410)
+#define IOP3XX_DMA_PADR(chan)		IOP3XX_DMA_OFFSET(chan, 0x0414)
+#define IOP3XX_DMA_PUADR(chan)		IOP3XX_DMA_OFFSET(chan, 0x0418)
+#define IOP3XX_DMA_LADR(chan)		IOP3XX_DMA_OFFSET(chan, 0x041c)
+#define IOP3XX_DMA_BCR(chan)		IOP3XX_DMA_OFFSET(chan, 0x0420)
+#define IOP3XX_DMA_DCR(chan)		IOP3XX_DMA_OFFSET(chan, 0x0424)
+
+/* Application accelerator unit  */
+#define IOP3XX_AAU_ACR		IOP3XX_REG_ADDR32(0x0800)
+#define IOP3XX_AAU_ASR		IOP3XX_REG_ADDR32(0x0804)
+#define IOP3XX_AAU_ADAR	IOP3XX_REG_ADDR32(0x0808)
+#define IOP3XX_AAU_ANDAR	IOP3XX_REG_ADDR32(0x080c)
+#define IOP3XX_AAU_SAR(src)	IOP3XX_REG_ADDR32(0x0810 + ((src) << 2))
+#define IOP3XX_AAU_DAR		IOP3XX_REG_ADDR32(0x0820)
+#define IOP3XX_AAU_ABCR	IOP3XX_REG_ADDR32(0x0824)
+#define IOP3XX_AAU_ADCR	IOP3XX_REG_ADDR32(0x0828)
+#define IOP3XX_AAU_SAR_EDCR(src_edc) IOP3XX_REG_ADDR32(0x082c + ((src_edc - 4) << 2))
+#define IOP3XX_AAU_EDCR0_IDX	8
+#define IOP3XX_AAU_EDCR1_IDX	17
+#define IOP3XX_AAU_EDCR2_IDX	26
+
+#define IOP3XX_DMA0_ID 0
+#define IOP3XX_DMA1_ID 1
+#define IOP3XX_AAU_ID 2
 
 /* Peripheral bus interface  */
-#define IOP3XX_PBCR		(volatile u32 *)IOP3XX_REG_ADDR(0x0680)
-#define IOP3XX_PBISR		(volatile u32 *)IOP3XX_REG_ADDR(0x0684)
-#define IOP3XX_PBBAR0		(volatile u32 *)IOP3XX_REG_ADDR(0x0688)
-#define IOP3XX_PBLR0		(volatile u32 *)IOP3XX_REG_ADDR(0x068c)
-#define IOP3XX_PBBAR1		(volatile u32 *)IOP3XX_REG_ADDR(0x0690)
-#define IOP3XX_PBLR1		(volatile u32 *)IOP3XX_REG_ADDR(0x0694)
-#define IOP3XX_PBBAR2		(volatile u32 *)IOP3XX_REG_ADDR(0x0698)
-#define IOP3XX_PBLR2		(volatile u32 *)IOP3XX_REG_ADDR(0x069c)
-#define IOP3XX_PBBAR3		(volatile u32 *)IOP3XX_REG_ADDR(0x06a0)
-#define IOP3XX_PBLR3		(volatile u32 *)IOP3XX_REG_ADDR(0x06a4)
-#define IOP3XX_PBBAR4		(volatile u32 *)IOP3XX_REG_ADDR(0x06a8)
-#define IOP3XX_PBLR4		(volatile u32 *)IOP3XX_REG_ADDR(0x06ac)
-#define IOP3XX_PBBAR5		(volatile u32 *)IOP3XX_REG_ADDR(0x06b0)
-#define IOP3XX_PBLR5		(volatile u32 *)IOP3XX_REG_ADDR(0x06b4)
-#define IOP3XX_PMBR0		(volatile u32 *)IOP3XX_REG_ADDR(0x06c0)
-#define IOP3XX_PMBR1		(volatile u32 *)IOP3XX_REG_ADDR(0x06e0)
-#define IOP3XX_PMBR2		(volatile u32 *)IOP3XX_REG_ADDR(0x06e4)
+#define IOP3XX_PBCR		IOP3XX_REG_ADDR32(0x0680)
+#define IOP3XX_PBISR		IOP3XX_REG_ADDR32(0x0684)
+#define IOP3XX_PBBAR0		IOP3XX_REG_ADDR32(0x0688)
+#define IOP3XX_PBLR0		IOP3XX_REG_ADDR32(0x068c)
+#define IOP3XX_PBBAR1		IOP3XX_REG_ADDR32(0x0690)
+#define IOP3XX_PBLR1		IOP3XX_REG_ADDR32(0x0694)
+#define IOP3XX_PBBAR2		IOP3XX_REG_ADDR32(0x0698)
+#define IOP3XX_PBLR2		IOP3XX_REG_ADDR32(0x069c)
+#define IOP3XX_PBBAR3		IOP3XX_REG_ADDR32(0x06a0)
+#define IOP3XX_PBLR3		IOP3XX_REG_ADDR32(0x06a4)
+#define IOP3XX_PBBAR4		IOP3XX_REG_ADDR32(0x06a8)
+#define IOP3XX_PBLR4		IOP3XX_REG_ADDR32(0x06ac)
+#define IOP3XX_PBBAR5		IOP3XX_REG_ADDR32(0x06b0)
+#define IOP3XX_PBLR5		IOP3XX_REG_ADDR32(0x06b4)
+#define IOP3XX_PMBR0		IOP3XX_REG_ADDR32(0x06c0)
+#define IOP3XX_PMBR1		IOP3XX_REG_ADDR32(0x06e0)
+#define IOP3XX_PMBR2		IOP3XX_REG_ADDR32(0x06e4)
 
 /* Peripheral performance monitoring unit  */
-#define IOP3XX_GTMR		(volatile u32 *)IOP3XX_REG_ADDR(0x0700)
-#define IOP3XX_ESR		(volatile u32 *)IOP3XX_REG_ADDR(0x0704)
-#define IOP3XX_EMISR		(volatile u32 *)IOP3XX_REG_ADDR(0x0708)
-#define IOP3XX_GTSR		(volatile u32 *)IOP3XX_REG_ADDR(0x0710)
+#define IOP3XX_GTMR		IOP3XX_REG_ADDR32(0x0700)
+#define IOP3XX_ESR		IOP3XX_REG_ADDR32(0x0704)
+#define IOP3XX_EMISR		IOP3XX_REG_ADDR32(0x0708)
+#define IOP3XX_GTSR		IOP3XX_REG_ADDR32(0x0710)
 /* PERCR0 DOESN'T EXIST - index from 1! */
-#define IOP3XX_PERCR0		(volatile u32 *)IOP3XX_REG_ADDR(0x0710)
+#define IOP3XX_PERCR0		IOP3XX_REG_ADDR32(0x0710)
 
 /* General Purpose I/O  */
-#define IOP3XX_GPOE		(volatile u32 *)IOP3XX_GPIO_REG(0x0004)
-#define IOP3XX_GPID		(volatile u32 *)IOP3XX_GPIO_REG(0x0008)
-#define IOP3XX_GPOD		(volatile u32 *)IOP3XX_GPIO_REG(0x000c)
+#define IOP3XX_GPOE		IOP3XX_GPIO_REG32(0x0004)
+#define IOP3XX_GPID		IOP3XX_GPIO_REG32(0x0008)
+#define IOP3XX_GPOD		IOP3XX_GPIO_REG32(0x000c)
 
 /* Timers  */
-#define IOP3XX_TU_TMR0		(volatile u32 *)IOP3XX_TIMER_REG(0x0000)
-#define IOP3XX_TU_TMR1		(volatile u32 *)IOP3XX_TIMER_REG(0x0004)
-#define IOP3XX_TU_TCR0		(volatile u32 *)IOP3XX_TIMER_REG(0x0008)
-#define IOP3XX_TU_TCR1		(volatile u32 *)IOP3XX_TIMER_REG(0x000c)
-#define IOP3XX_TU_TRR0		(volatile u32 *)IOP3XX_TIMER_REG(0x0010)
-#define IOP3XX_TU_TRR1		(volatile u32 *)IOP3XX_TIMER_REG(0x0014)
-#define IOP3XX_TU_TISR		(volatile u32 *)IOP3XX_TIMER_REG(0x0018)
-#define IOP3XX_TU_WDTCR		(volatile u32 *)IOP3XX_TIMER_REG(0x001c)
+#define IOP3XX_TU_TMR0		IOP3XX_TIMER_REG32(0x0000)
+#define IOP3XX_TU_TMR1		IOP3XX_TIMER_REG32(0x0004)
+#define IOP3XX_TU_TCR0		IOP3XX_TIMER_REG32(0x0008)
+#define IOP3XX_TU_TCR1		IOP3XX_TIMER_REG32(0x000c)
+#define IOP3XX_TU_TRR0		IOP3XX_TIMER_REG32(0x0010)
+#define IOP3XX_TU_TRR1		IOP3XX_TIMER_REG32(0x0014)
+#define IOP3XX_TU_TISR		IOP3XX_TIMER_REG32(0x0018)
+#define IOP3XX_TU_WDTCR		IOP3XX_TIMER_REG32(0x001c)
 #define IOP3XX_TMR_TC		0x01
 #define IOP3XX_TMR_EN		0x02
 #define IOP3XX_TMR_RELOAD	0x04
@@ -190,69 +203,25 @@ #define IOP3XX_TMR_RATIO_4_1	0x10
 #define IOP3XX_TMR_RATIO_8_1	0x20
 #define IOP3XX_TMR_RATIO_16_1	0x30
 
-/* Application accelerator unit  */
-#define IOP3XX_AAU_ACR		(volatile u32 *)IOP3XX_REG_ADDR(0x0800)
-#define IOP3XX_AAU_ASR		(volatile u32 *)IOP3XX_REG_ADDR(0x0804)
-#define IOP3XX_AAU_ADAR		(volatile u32 *)IOP3XX_REG_ADDR(0x0808)
-#define IOP3XX_AAU_ANDAR	(volatile u32 *)IOP3XX_REG_ADDR(0x080c)
-#define IOP3XX_AAU_SAR1		(volatile u32 *)IOP3XX_REG_ADDR(0x0810)
-#define IOP3XX_AAU_SAR2		(volatile u32 *)IOP3XX_REG_ADDR(0x0814)
-#define IOP3XX_AAU_SAR3		(volatile u32 *)IOP3XX_REG_ADDR(0x0818)
-#define IOP3XX_AAU_SAR4		(volatile u32 *)IOP3XX_REG_ADDR(0x081c)
-#define IOP3XX_AAU_DAR		(volatile u32 *)IOP3XX_REG_ADDR(0x0820)
-#define IOP3XX_AAU_ABCR		(volatile u32 *)IOP3XX_REG_ADDR(0x0824)
-#define IOP3XX_AAU_ADCR		(volatile u32 *)IOP3XX_REG_ADDR(0x0828)
-#define IOP3XX_AAU_SAR5		(volatile u32 *)IOP3XX_REG_ADDR(0x082c)
-#define IOP3XX_AAU_SAR6		(volatile u32 *)IOP3XX_REG_ADDR(0x0830)
-#define IOP3XX_AAU_SAR7		(volatile u32 *)IOP3XX_REG_ADDR(0x0834)
-#define IOP3XX_AAU_SAR8		(volatile u32 *)IOP3XX_REG_ADDR(0x0838)
-#define IOP3XX_AAU_EDCR0	(volatile u32 *)IOP3XX_REG_ADDR(0x083c)
-#define IOP3XX_AAU_SAR9		(volatile u32 *)IOP3XX_REG_ADDR(0x0840)
-#define IOP3XX_AAU_SAR10	(volatile u32 *)IOP3XX_REG_ADDR(0x0844)
-#define IOP3XX_AAU_SAR11	(volatile u32 *)IOP3XX_REG_ADDR(0x0848)
-#define IOP3XX_AAU_SAR12	(volatile u32 *)IOP3XX_REG_ADDR(0x084c)
-#define IOP3XX_AAU_SAR13	(volatile u32 *)IOP3XX_REG_ADDR(0x0850)
-#define IOP3XX_AAU_SAR14	(volatile u32 *)IOP3XX_REG_ADDR(0x0854)
-#define IOP3XX_AAU_SAR15	(volatile u32 *)IOP3XX_REG_ADDR(0x0858)
-#define IOP3XX_AAU_SAR16	(volatile u32 *)IOP3XX_REG_ADDR(0x085c)
-#define IOP3XX_AAU_EDCR1	(volatile u32 *)IOP3XX_REG_ADDR(0x0860)
-#define IOP3XX_AAU_SAR17	(volatile u32 *)IOP3XX_REG_ADDR(0x0864)
-#define IOP3XX_AAU_SAR18	(volatile u32 *)IOP3XX_REG_ADDR(0x0868)
-#define IOP3XX_AAU_SAR19	(volatile u32 *)IOP3XX_REG_ADDR(0x086c)
-#define IOP3XX_AAU_SAR20	(volatile u32 *)IOP3XX_REG_ADDR(0x0870)
-#define IOP3XX_AAU_SAR21	(volatile u32 *)IOP3XX_REG_ADDR(0x0874)
-#define IOP3XX_AAU_SAR22	(volatile u32 *)IOP3XX_REG_ADDR(0x0878)
-#define IOP3XX_AAU_SAR23	(volatile u32 *)IOP3XX_REG_ADDR(0x087c)
-#define IOP3XX_AAU_SAR24	(volatile u32 *)IOP3XX_REG_ADDR(0x0880)
-#define IOP3XX_AAU_EDCR2	(volatile u32 *)IOP3XX_REG_ADDR(0x0884)
-#define IOP3XX_AAU_SAR25	(volatile u32 *)IOP3XX_REG_ADDR(0x0888)
-#define IOP3XX_AAU_SAR26	(volatile u32 *)IOP3XX_REG_ADDR(0x088c)
-#define IOP3XX_AAU_SAR27	(volatile u32 *)IOP3XX_REG_ADDR(0x0890)
-#define IOP3XX_AAU_SAR28	(volatile u32 *)IOP3XX_REG_ADDR(0x0894)
-#define IOP3XX_AAU_SAR29	(volatile u32 *)IOP3XX_REG_ADDR(0x0898)
-#define IOP3XX_AAU_SAR30	(volatile u32 *)IOP3XX_REG_ADDR(0x089c)
-#define IOP3XX_AAU_SAR31	(volatile u32 *)IOP3XX_REG_ADDR(0x08a0)
-#define IOP3XX_AAU_SAR32	(volatile u32 *)IOP3XX_REG_ADDR(0x08a4)
-
 /* I2C bus interface unit  */
-#define IOP3XX_ICR0		(volatile u32 *)IOP3XX_REG_ADDR(0x1680)
-#define IOP3XX_ISR0		(volatile u32 *)IOP3XX_REG_ADDR(0x1684)
-#define IOP3XX_ISAR0		(volatile u32 *)IOP3XX_REG_ADDR(0x1688)
-#define IOP3XX_IDBR0		(volatile u32 *)IOP3XX_REG_ADDR(0x168c)
-#define IOP3XX_IBMR0		(volatile u32 *)IOP3XX_REG_ADDR(0x1694)
-#define IOP3XX_ICR1		(volatile u32 *)IOP3XX_REG_ADDR(0x16a0)
-#define IOP3XX_ISR1		(volatile u32 *)IOP3XX_REG_ADDR(0x16a4)
-#define IOP3XX_ISAR1		(volatile u32 *)IOP3XX_REG_ADDR(0x16a8)
-#define IOP3XX_IDBR1		(volatile u32 *)IOP3XX_REG_ADDR(0x16ac)
-#define IOP3XX_IBMR1		(volatile u32 *)IOP3XX_REG_ADDR(0x16b4)
+#define IOP3XX_ICR0		IOP3XX_REG_ADDR32(0x1680)
+#define IOP3XX_ISR0		IOP3XX_REG_ADDR32(0x1684)
+#define IOP3XX_ISAR0		IOP3XX_REG_ADDR32(0x1688)
+#define IOP3XX_IDBR0		IOP3XX_REG_ADDR32(0x168c)
+#define IOP3XX_IBMR0		IOP3XX_REG_ADDR32(0x1694)
+#define IOP3XX_ICR1		IOP3XX_REG_ADDR32(0x16a0)
+#define IOP3XX_ISR1		IOP3XX_REG_ADDR32(0x16a4)
+#define IOP3XX_ISAR1		IOP3XX_REG_ADDR32(0x16a8)
+#define IOP3XX_IDBR1		IOP3XX_REG_ADDR32(0x16ac)
+#define IOP3XX_IBMR1		IOP3XX_REG_ADDR32(0x16b4)
 
 
 /*
  * IOP3XX I/O and Mem space regions for PCI autoconfiguration
  */
 #define IOP3XX_PCI_MEM_WINDOW_SIZE	0x04000000
-#define IOP3XX_PCI_LOWER_MEM_PA		0x80000000
-#define IOP3XX_PCI_LOWER_MEM_BA		(*IOP3XX_OMWTVR0)
+#define IOP3XX_PCI_LOWER_MEM_PA	0x80000000
+#define IOP3XX_PCI_LOWER_MEM_BA	(*IOP3XX_OMWTVR0)
 
 #define IOP3XX_PCI_IO_WINDOW_SIZE	0x00010000
 #define IOP3XX_PCI_LOWER_IO_PA		0x90000000
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux