97 lines
3.0 KiB
C
97 lines
3.0 KiB
C
#ifndef __JZ47XX_H__
|
|
#define __JZ47XX_H__
|
|
|
|
#define __REG8(addr) *((volatile unsigned char *)(addr))
|
|
#define __REG16(addr) *((volatile unsigned short *)(addr))
|
|
#define __REG32(addr) *((volatile unsigned int *)(addr))
|
|
|
|
#define HARB_BASE 0xB3000000
|
|
#define EMC_BASE 0xB3010000
|
|
#define DMAC_BASE 0xB3020000
|
|
#define UHC_BASE 0xB3030000
|
|
#define UDC_BASE 0xB3040000
|
|
#define LCD_BASE 0xB3050000
|
|
#define CIM_BASE 0xB3060000
|
|
#define ETH_BASE 0xB3100000
|
|
#define NBM_BASE 0xB3F00000
|
|
|
|
#define CPM_BASE 0xB0000000
|
|
#define INTC_BASE 0xB0001000
|
|
#define OST_BASE 0xB0002000
|
|
#define RTC_BASE 0xB0003000
|
|
#define WDT_BASE 0xB0004000
|
|
#define GPIO_BASE 0xB0010000
|
|
#define AIC_BASE 0xB0020000
|
|
#define MSC_BASE 0xB0021000
|
|
#define UART0_BASE 0xB0030000
|
|
#define UART1_BASE 0xB0031000
|
|
#define UART2_BASE 0xB0032000
|
|
#define UART3_BASE 0xB0033000
|
|
#define FIR_BASE 0xB0040000
|
|
#define SCC_BASE 0xB0041000
|
|
#define SCC0_BASE 0xB0041000
|
|
#define I2C_BASE 0xB0042000
|
|
#define SSI_BASE 0xB0043000
|
|
#define SCC1_BASE 0xB0044000
|
|
#define PWM0_BASE 0xB0050000
|
|
#define PWM1_BASE 0xB0051000
|
|
#define DES_BASE 0xB0060000
|
|
#define UPRT_BASE 0xB0061000
|
|
#define KBC_BASE 0xB0062000
|
|
|
|
/* uart offset */
|
|
#define UART_RDR(base) __REG8((base) + 0x00) /* R 8b H'xx */
|
|
#define UART_TDR(base) __REG8((base) + 0x00) /* W 8b H'xx */
|
|
#define UART_DLLR(base) __REG8((base) + 0x00) /* RW 8b H'00 */
|
|
#define UART_DLHR(base) __REG8((base) + 0x04) /* RW 8b H'00 */
|
|
#define UART_IER(base) __REG8((base) + 0x04) /* RW 8b H'00 */
|
|
#define UART_ISR(base) __REG8((base) + 0x08) /* R 8b H'01 */
|
|
#define UART_FCR(base) __REG8((base) + 0x08) /* W 8b H'00 */
|
|
#define UART_LCR(base) __REG8((base) + 0x0C) /* RW 8b H'00 */
|
|
#define UART_MCR(base) __REG8((base) + 0x10) /* RW 8b H'00 */
|
|
#define UART_LSR(base) __REG8((base) + 0x14) /* R 8b H'00 */
|
|
#define UART_MSR(base) __REG8((base) + 0x18) /* R 8b H'00 */
|
|
#define UART_SPR(base) __REG8((base) + 0x1C) /* RW 8b H'00 */
|
|
#define UART_MCR(base) __REG8((base) + 0x10) /* RW 8b H'00 */
|
|
#define UART_SIRCR(base) __REG8((base) + 0x20) /* RW 8b H'00 */
|
|
|
|
/* interrupt controller */
|
|
#define INTC_ISR __REG32(INTC_BASE + 0x00)
|
|
#define INTC_IMR __REG32(INTC_BASE + 0x04)
|
|
#define INTC_IMSR __REG32(INTC_BASE + 0x08)
|
|
#define INTC_IMCR __REG32(INTC_BASE + 0x0c)
|
|
#define INTC_IPR __REG32(INTC_BASE + 0x10)
|
|
|
|
#define IRQ_I2C 1
|
|
#define IRQ_PS2 2
|
|
#define IRQ_UPRT 3
|
|
#define IRQ_CORE 4
|
|
#define IRQ_UART3 6
|
|
#define IRQ_UART2 7
|
|
#define IRQ_UART1 8
|
|
#define IRQ_UART0 9
|
|
#define IRQ_SCC1 10
|
|
#define IRQ_SCC0 11
|
|
#define IRQ_UDC 12
|
|
#define IRQ_UHC 13
|
|
#define IRQ_MSC 14
|
|
#define IRQ_RTC 15
|
|
#define IRQ_FIR 16
|
|
#define IRQ_SSI 17
|
|
#define IRQ_CIM 18
|
|
#define IRQ_ETH 19
|
|
#define IRQ_AIC 20
|
|
#define IRQ_DMAC 21
|
|
#define IRQ_OST2 22
|
|
#define IRQ_OST1 23
|
|
#define IRQ_OST0 24
|
|
#define IRQ_GPIO3 25
|
|
#define IRQ_GPIO2 26
|
|
#define IRQ_GPIO1 27
|
|
#define IRQ_GPIO0 28
|
|
#define IRQ_LCD 30
|
|
|
|
#define SYSTEM_STACK 0x80003fe8 /* the kernel system stack address */
|
|
|
|
#endif
|