#ifndef __BD19__ #define __BD19__ //===============================================================================// // // sfr define // //===============================================================================// #define hs_base 0x1f0000 #define ls_base 0x1e0000 #define __RW volatile // read write #define __RO volatile const // only read #define __WO volatile // only write #define __u8 unsigned int // u8 to u32 special for struct #define __u16 unsigned int // u16 to u32 special for struct #define __u32 unsigned int #define __s8(x) char(x); char(reserved_1_##x); char(reserved_2_##x); char(reserved_3_##x) #define __s16(x) short(x); short(reserved_1_##x) #define __s32(x) int(x) #define map_adr(grp, adr) ((64 * grp + adr) * 4) // grp(0x0-0xff), adr(0x0-0x3f) //===============================================================================// // // high speed sfr address define // //===============================================================================// //............. 0x0000 - 0x00ff............ for hemu typedef struct { __RW __u32 WREN; __RW __u32 CON0; __RW __u32 CON1; __RW __u32 CON2; __RW __u32 CON3; __RW __u32 MSG0; __RW __u32 MSG1; __RW __u32 MSG2; __RW __u32 MSG3; __RO __u32 ID; } JL_HEMU_TypeDef; #define JL_HEMU_BASE (hs_base + map_adr(0x00, 0x00)) #define JL_HEMU ((JL_HEMU_TypeDef *)JL_HEMU_BASE) //............. 0x0200 - 0x02ff............ for sfc typedef struct { __RW __u32 CON; __WO __u32 BAUD; __WO __u32 CODE; __WO __u32 BASE_ADR; __WO __u32 QUCNT; __RW __u8 ENC_CON; __RW __u16 ENC_KEY; __WO __u32 UNENC_ADRH; __WO __u32 UNENC_ADRL; } JL_SFC_TypeDef; #define JL_SFC_BASE (hs_base + map_adr(0x02, 0x00)) #define JL_SFC ((JL_SFC_TypeDef *)JL_SFC_BASE) ////............. 0x0500 - 0x05ff............ for psram //typedef struct { // __RW __u32 CON; // __WO __u32 BAUD; // __WO __u32 QUCNT; //} JL_PSRAM_TypeDef; // //#define JL_PSRAM_BASE (hs_base + map_adr(0x05, 0x00)) //#define JL_PSRAM ((JL_PSRAM_TypeDef *)JL_PSRAM_BASE) //............. 0x1200 - 0x12ff............ for CORDIC typedef struct { __RW __u32 CON; __RW __u32 XDAT; __RW __u32 YDAT; } JL_CORDIC_TypeDef; #define JL_CORDIC_BASE (hs_base + map_adr(0x12, 0x00)) #define JL_CORDIC ((JL_CORDIC_TypeDef *)JL_CORDIC_BASE) //............. 0x1300 - 0x13ff............ for dcp typedef struct { __RW __u32 CON; __RW __u32 ADR; } JL_DCP_TypeDef; #define JL_DCP_BASE (hs_base + map_adr(0x13, 0x00)) #define JL_DCP ((JL_DCP_TypeDef *)JL_DCP_BASE) //............. 0x1500 - 0x15ff............ for eq typedef struct { __RW __u32 CON0; __RW __u32 CON1; __RW __u32 DATAI_ADR; __RW __u32 DATAO_ADR; __RW __u32 DATA_LEN; __RW __u32 FLT_ADR; } JL_EQ_TypeDef; #define JL_EQ_BASE (hs_base + map_adr(0x15, 0x00)) #define JL_EQ ((JL_EQ_TypeDef *)JL_EQ_BASE) //............. 0x2100 - 0x21ff............ for wireless typedef struct { __RW __u32 CON0; __RW __u32 CON3; __RW __u32 LOFC_CON; __RW __u32 LOFC_RES; __RW __u32 DBG_CON; } JL_WL_TypeDef; #define JL_WL_BASE (hs_base + map_adr(0x21, 0x00)) #define JL_WL ((JL_WL_TypeDef *)JL_WL_BASE) //............. 0x2200 - 0x22ff............ typedef struct { __RW __u32 CON0; } JL_WL_AUD_TypeDef; #define JL_WL_AUD_BASE (hs_base + map_adr(0x22, 0x00)) #define JL_WL_AUD ((JL_WL_AUD_TypeDef *)JL_WL_AUD_BASE) //===============================================================================// // // low speed sfr address define // //===============================================================================// //............. 0x0000 - 0x00ff............ for syscfg typedef struct { __RW __u32 PWR_CON; __RW __u32 HTC_CON; __RW __u32 SYS_DIV; __RW __u32 CLK_CON0; __RW __u32 CLK_CON1; __RW __u32 CLK_CON2; __RW __u32 CLK_CON3; __RW __u32 CLK_CON4; __RW __u32 CLK_CON5; } JL_CLOCK_TypeDef; #define JL_CLOCK_BASE (ls_base + map_adr(0x00, 0x00)) #define JL_CLOCK ((JL_CLOCK_TypeDef *)JL_CLOCK_BASE) typedef struct { __RW __u32 RST_SRC; } JL_RST_TypeDef; #define JL_RST_BASE (ls_base + map_adr(0x00, 0x30)) #define JL_RST ((JL_RST_TypeDef *)JL_RST_BASE) //............. 0x0100 - 0x01ff............ typedef struct { __RW __u32 MODE_CON; } JL_MODE_TypeDef; #define JL_MODE_BASE (ls_base + map_adr(0x01, 0x00)) #define JL_MODE ((JL_MODE_TypeDef *)JL_MODE_BASE) //............. 0x0200 - 0x02ff............ typedef struct { __WO __u32 CHIP_ID; } JL_SYSTEM_TypeDef; #define JL_SYSTEM_BASE (ls_base + map_adr(0x02, 0x00)) #define JL_SYSTEM ((JL_SYSTEM_TypeDef *)JL_SYSTEM_BASE) //............. 0x0300 - 0x03ff............ typedef struct { __RW __u32 WREN; __RW __u32 CON0; __RW __u32 CON1; __RW __u32 CON2; __RW __u32 CON3; __RW __u32 MSG0; __RW __u32 MSG1; __RW __u32 MSG2; __RW __u32 MSG3; __RO __u32 ID; } JL_LEMU_TypeDef; #define JL_LEMU_BASE (ls_base + map_adr(0x03, 0x00)) #define JL_LEMU ((JL_LEMU_TypeDef *)JL_LEMU_BASE) //............. 0x0400 - 0x09ff............ typedef struct { __RW __u32 CON; __RW __u32 CNT; __RW __u32 PRD; __RW __u32 PWM; } JL_TIMER_TypeDef; #define JL_TIMER0_BASE (ls_base + map_adr(0x04, 0x00)) #define JL_TIMER0 ((JL_TIMER_TypeDef *)JL_TIMER0_BASE) #define JL_TIMER1_BASE (ls_base + map_adr(0x05, 0x00)) #define JL_TIMER1 ((JL_TIMER_TypeDef *)JL_TIMER1_BASE) #define JL_TIMER2_BASE (ls_base + map_adr(0x06, 0x00)) #define JL_TIMER2 ((JL_TIMER_TypeDef *)JL_TIMER2_BASE) #define JL_TIMER3_BASE (ls_base + map_adr(0x07, 0x00)) #define JL_TIMER3 ((JL_TIMER_TypeDef *)JL_TIMER3_BASE) //#define JL_TIMER4_BASE (ls_base + map_adr(0x08, 0x00)) //#define JL_TIMER4 ((JL_TIMER_TypeDef *)JL_TIMER4_BASE) //#define JL_TIMER5_BASE (ls_base + map_adr(0x09, 0x00)) //#define JL_TIMER5 ((JL_TIMER_TypeDef *)JL_TIMER5_BASE) //............. 0x1000 - 0x10ff............ typedef struct { __RW __u32 CON; __RW __u32 VAL; } JL_PCNT_TypeDef; #define JL_PCNT_BASE (ls_base + map_adr(0x10, 0x00)) #define JL_PCNT ((JL_PCNT_TypeDef *)JL_PCNT_BASE) //............. 0x1100 - 0x11ff............ typedef struct { __RW __u32 CON; __RO __u32 NUM; } JL_GPCNT_TypeDef; #define JL_GPCNT_BASE (ls_base + map_adr(0x11, 0x00)) #define JL_GPCNT ((JL_GPCNT_TypeDef *)JL_GPCNT_BASE) //............. 0x1400 - 0x17ff............ //............. 0x1600 - 0x16ff............ for src typedef struct { __RW __u32 CON0; __RW __u32 CON1; __RW __u32 CON2; __RW __u32 CON3; __RW __u32 IDAT_ADR; __RW __u32 IDAT_LEN; __RW __u32 ODAT_ADR; __RW __u32 ODAT_LEN; __RW __u32 FLTB_ADR; __WO __u32 ODAT_ADR_START; __WO __u32 ODAT_ADR_END; __WO __u32 STOP_FLAG; #ifdef CONFIG_BR30_C_VERSION __RW __u32 INSR; __RW __u32 OUTSR; __RW __u32 PHASE; #endif } JL_SRC_TypeDef; #define JL_SRC_BASE (hs_base + map_adr(0x16, 0x00)) #define JL_SRC ((JL_SRC_TypeDef *)JL_SRC_BASE) //............. 0x1800 - 0x18ff............ typedef struct { __RW __u32 CON0; __RW __u32 CON1; __WO __u32 EP0_CNT; __WO __u32 EP1_CNT; __WO __u32 EP2_CNT; __WO __u32 EP3_CNT; __WO __u32 EP4_CNT; __WO __u32 EP0_ADR; __WO __u32 EP1_TADR; __WO __u32 EP1_RADR; __WO __u32 EP2_TADR; __WO __u32 EP2_RADR; __WO __u32 EP3_TADR; __WO __u32 EP3_RADR; __WO __u32 EP4_TADR; __WO __u32 EP4_RADR; __RW __u32 TXDLY_CON; __RW __u32 EP1_RLEN; __RW __u32 EP2_RLEN; __RW __u32 EP3_RLEN; __RW __u32 EP4_RLEN; __RW __u32 EP1_MTX_PRD; __RW __u32 EP1_MRX_PRD; __RO __u32 EP1_MTX_NUM; __RO __u32 EP1_MRX_NUM; } JL_USB_TypeDef; #define JL_USB_BASE (ls_base + map_adr(0x18, 0x00)) #define JL_USB ((JL_USB_TypeDef *)JL_USB_BASE) #define JL_USB1_BASE (ls_base + map_adr(0x5a, 0x00)) #define JL_USB1 ((JL_USB_TypeDef *)JL_USB1_BASE) //............. 0x1900 - 0x19ff............ typedef struct { __RW __u32 WLA_CON0 ; __RW __u32 WLA_CON1 ; __RW __u32 WLA_CON2 ; __RW __u32 WLA_CON3 ; __RW __u32 WLA_CON4 ; __RW __u32 WLA_CON5 ; __RW __u32 WLA_CON6 ; __RW __u32 WLA_CON7 ; __RW __u32 WLA_CON8 ; __RW __u32 WLA_CON9 ; __RW __u32 WLA_CON10; __RW __u32 WLA_CON11; __RW __u32 WLA_CON12; __RW __u32 WLA_CON13; __RW __u32 WLA_CON14; __RW __u32 WLA_CON15; __RW __u32 WLA_CON16; __RW __u32 WLA_CON17; __RW __u32 WLA_CON18; __RW __u32 WLA_CON19; __RW __u32 WLA_CON20; __RW __u32 WLA_CON21; __RW __u32 WLA_CON22; __RW __u32 WLA_CON23; __RW __u32 WLA_CON24; __RW __u32 WLA_CON25; __RW __u32 WLA_CON26; __RW __u32 WLA_CON27; __RW __u32 WLA_CON28; __RW __u32 WLA_CON29; __RO __u32 WLA_CON30; __RO __u32 WLA_CON31; __RO __u32 WLA_CON32; __RO __u32 WLA_CON33; __RO __u32 WLA_CON34; __RO __u32 WLA_CON35; __RO __u32 WLA_CON36; __RO __u32 WLA_CON37; __RO __u32 WLA_CON38; __RO __u32 WLA_CON39; } JL_WLA_TypeDef; #define JL_WLA_BASE (ls_base + map_adr(0x19, 0x00)) #define JL_WLA ((JL_WLA_TypeDef *)JL_WLA_BASE) //............. 0x1a00 - 0x1aff............ typedef struct { __RW __u32 CON; __RW __u32 CADR; __RW __u32 ACC0L; __RW __u32 ACC0H; __RW __u32 ACC1L; __RW __u32 ACC1H; __RW __u32 TEST0; __RW __u32 TEST1; } JL_FFT_TypeDef; #define JL_FFT_BASE (hs_base + map_adr(0x1a, 0x00)) #define JL_FFT ((JL_FFT_TypeDef *)JL_FFT_BASE) //............. 0x1c00 - 0x1eff............ typedef struct { __RW __u32 CON; __WO __u32 BAUD; __RW __u32 BUF; __WO __u32 ADR; __WO __u32 CNT; } JL_SPI_TypeDef; #define JL_SPI0_BASE (ls_base + map_adr(0x1c, 0x00)) #define JL_SPI0 ((JL_SPI_TypeDef *)JL_SPI0_BASE) #define JL_SPI1_BASE (ls_base + map_adr(0x1d, 0x00)) #define JL_SPI1 ((JL_SPI_TypeDef *)JL_SPI1_BASE) #define JL_SPI2_BASE (ls_base + map_adr(0x1e, 0x00)) #define JL_SPI2 ((JL_SPI_TypeDef *)JL_SPI2_BASE) //............. 0x2000 - 0x22ff............ typedef struct { __RW __u16 CON0; __RW __u16 CON1; __WO __u16 BAUD; __RW __u8 BUF; __RW __u32 OTCNT; __RW __u32 TXADR; __WO __u16 TXCNT; __RW __u32 RXSADR; __RW __u32 RXEADR; __RW __u32 RXCNT; __RO __u16 HRXCNT; __RW __u16 CON2; } JL_UART_TypeDef; #define JL_UART0_BASE (ls_base + map_adr(0x20, 0x00)) #define JL_UART0 ((JL_UART_TypeDef *)JL_UART0_BASE) #define JL_UART1_BASE (ls_base + map_adr(0x21, 0x00)) #define JL_UART1 ((JL_UART_TypeDef *)JL_UART1_BASE) #define JL_UART2_BASE (ls_base + map_adr(0x22, 0x00)) #define JL_UART2 ((JL_UART_TypeDef *)JL_UART2_BASE) //............. 0x2400 - 0x24ff............ typedef struct { __RW __u16 CON0; __RW __u8 BUF; __WO __u16 BAUD; __RW __u32 ADR; __RW __u32 CNT; } JL_IIC_TypeDef; #define JL_IIC_BASE (ls_base + map_adr(0x24, 0x00)) #define JL_IIC ((JL_IIC_TypeDef *)JL_IIC_BASE) //............. 0x2600 - 0x26ff............ for src_sync typedef struct { __RW __u32 CON0; #ifdef CONFIG_BR30_C_VERSION __RW __u32 RESERVE; #else __RW __u32 CON1; #endif /* #ifdef CONFIG_BR30_C_VERSION */ __RW __u32 CON2; __RW __u32 CON3; __RW __u32 IDAT_ADR; __RW __u32 IDAT_LEN; __RW __u32 ODAT_ADR; __RW __u32 ODAT_LEN; __RW __u32 FLTB_ADR; __WO __u32 ODAT_ADR_START; __WO __u32 ODAT_ADR_END; __RW __u32 STOP_FLAG; #ifdef CONFIG_BR30_C_VERSION __RW __u32 INSR; __RW __u32 OUTSR; __RW __u32 PHASE; #endif /* #ifdef CONFIG_BR30_C_VERSION */ } JL_SRC_SYNC_TypeDef; #define JL_SRC_SYNC_BASE (hs_base + map_adr(0x26, 0x00)) #define JL_SRC_SYNC ((JL_SRC_SYNC_TypeDef *)JL_SRC_SYNC_BASE) //............. 0x2700 - 0x27ff............ typedef struct { __RW __u32 CLK; } JL_LEDCK_TypeDef; #define JL_LEDCK_BASE (ls_base + map_adr(0x27,0x00)) #define JL_LEDCK ((JL_LEDCK_TypeDef *)JL_LEDCK_BASE) typedef struct { __RW __u32 CON; __RW __u32 FD; __RW __u32 LP; __RW __u32 TIX; __RW __u32 RSTX; __RW __u32 ADR; } JL_LEDC_TypeDef; #define JL_LEDC0_BASE (ls_base + map_adr(0x27, 0x01)) #define JL_LEDC0 ((JL_LEDC_TypeDef *)JL_LEDC0_BASE) #define JL_LEDC1_BASE (ls_base + map_adr(0x27, 0x07)) #define JL_LEDC1 ((JL_LEDC_TypeDef *)JL_LEDC1_BASE) //............. 0x2800 - 0x28ff............ //typedef struct { // __RW __u32 CON; // __WO __u32 DAT0; // __WO __u32 DAT1; // __RW __u32 BUF; // __WO __u32 ADR; // __WO __u32 CNT; //} JL_PAP_TypeDef; // //#define JL_PAP_BASE (ls_base + map_adr(0x28, 0x00)) //#define JL_PAP ((JL_PAP_TypeDef *)JL_PAP_BASE) //............. 0x2b00 - 0x2bff............ //typedef struct { // __RW __u32 CON; // __RO __u32 SR_CNT; // __RW __u32 IO_CON; // __RW __u32 DMA_CON; // __RW __u32 DMA_LEN; // __WO __u32 DAT_ADR; // __WO __u32 INF_ADR; // __RO __u32 CSB0; // __RO __u32 CSB1; // __RO __u32 CSB2; // __RO __u32 CSB3; // __RO __u32 CSB4; // __RO __u32 CSB5; //} JL_SS_TypeDef; // //#define JL_SS_BASE (ls_base + map_adr(0x2b, 0x00)) //#define JL_SS ((JL_SS_TypeDef *)JL_SS_BASE) //............. 0x2c00 - 0x2cff............ typedef struct { __RW __u8 CON; __RW __u8 DAT; __RW __u8 SMP; } JL_RDEC_TypeDef; #define JL_RDEC0_BASE (ls_base + map_adr(0x2c, 0x00)) #define JL_RDEC0 ((JL_RDEC_TypeDef *)JL_RDEC0_BASE) #define JL_RDEC1_BASE (ls_base + map_adr(0x44, 0x00)) #define JL_RDEC1 ((JL_RDEC_TypeDef *)JL_RDEC1_BASE) #define JL_RDEC2_BASE (ls_base + map_adr(0x45, 0x00)) #define JL_RDEC2 ((JL_RDEC_TypeDef *)JL_RDEC2_BASE) // #define JL_RDEC3_BASE (ls_base + map_adr(0x4f, 0x00)) // #define JL_RDEC3 ((JL_RDEC_TypeDef *)JL_RDEC3_BASE) //............. 0x2e00 - 0x2eff............ //#define JL_ALNK1_BASE (ls_base + map_adr(0x33, 0x00)) //#define JL_ALNK1 ((JL_ALNK_TypeDef *)JL_ALNK1_BASE) //............. 0x3000 - 0x30ff............ typedef struct { __RW __u32 TMR0_CON; __RW __u32 TMR0_CNT; __RW __u32 TMR0_PR; __RW __u32 TMR1_CON; __RW __u32 TMR1_CNT; __RW __u32 TMR1_PR; __RW __u32 TMR2_CON; __RW __u32 TMR2_CNT; __RW __u32 TMR2_PR; __RW __u32 TMR3_CON; __RW __u32 TMR3_CNT; __RW __u32 TMR3_PR; __RW __u32 TMR4_CON; __RW __u32 TMR4_CNT; __RW __u32 TMR4_PR; __RW __u32 TMR5_CON; __RW __u32 TMR5_CNT; __RW __u32 TMR5_PR; __RW __u32 TMR6_CON; __RW __u32 TMR6_CNT; __RW __u32 TMR6_PR; __RW __u32 TMR7_CON; __RW __u32 TMR7_CNT; __RW __u32 TMR7_PR; __RW __u32 FPINCON; __RW __u32 CH0_CON0; __RW __u32 CH0_CON1; __RW __u32 CH0_CMPH; __RW __u32 CH0_CMPL; __RW __u32 CH1_CON0; __RW __u32 CH1_CON1; __RW __u32 CH1_CMPH; __RW __u32 CH1_CMPL; __RW __u32 CH2_CON0; __RW __u32 CH2_CON1; __RW __u32 CH2_CMPH; __RW __u32 CH2_CMPL; __RW __u32 CH3_CON0; __RW __u32 CH3_CON1; __RW __u32 CH3_CMPH; __RW __u32 CH3_CMPL; __RW __u32 CH4_CON0; __RW __u32 CH4_CON1; __RW __u32 CH4_CMPH; __RW __u32 CH4_CMPL; __RW __u32 CH5_CON0; __RW __u32 CH5_CON1; __RW __u32 CH5_CMPH; __RW __u32 CH5_CMPL; __RW __u32 CH6_CON0; __RW __u32 CH6_CON1; __RW __u32 CH6_CMPH; __RW __u32 CH6_CMPL; __RW __u32 CH7_CON0; __RW __u32 CH7_CON1; __RW __u32 CH7_CMPH; __RW __u32 CH7_CMPL; __RW __u32 MCPWM_CON0; } JL_MCPWM_TypeDef; #define JL_MCPWM_BASE (ls_base + map_adr(0x30, 0x00)) #define JL_MCPWM ((JL_MCPWM_TypeDef *)JL_MCPWM_BASE) //............. 0x3100 - 0x31ff............ typedef struct { __RW __u32 CON; __RO __u32 RES; } JL_ADC_TypeDef; #define JL_ADC_BASE (ls_base + map_adr(0x31, 0x00)) #define JL_ADC ((JL_ADC_TypeDef *)JL_ADC_BASE) //............. 0x3200 - 0x32ff............ typedef struct { __RW __u32 RFLT_CON; } JL_IR_TypeDef; #define JL_IR_BASE (ls_base + map_adr(0x32, 0x00)) #define JL_IR ((JL_IR_TypeDef *)JL_IR_BASE) //............. 0x3300 - 0x33ff............ // Used by ALNK1 //............. 0x3400 - 0x34ff............ typedef struct { __RW __u32 CON; } JL_OSA_TypeDef; #define JL_OSA_BASE (ls_base + map_adr(0x34, 0x00)) #define JL_OSA ((JL_OSA_TypeDef *)JL_OSA_BASE) //............. 0x3500 - 0x35ff............ typedef struct { __WO __u32 FIFO; __RW __u32 REG; } JL_CRC_TypeDef; #define JL_CRC_BASE (ls_base + map_adr(0x35, 0x00)) #define JL_CRC ((JL_CRC_TypeDef *)JL_CRC_BASE) //............. 0x3600 - 0x36ff............ typedef struct { __WO __u32 CON; __RW __u32 NUM; } JL_LRCT_TypeDef; #define JL_LRCT_BASE (ls_base + map_adr(0x36, 0x00)) #define JL_LRCT ((JL_LRCT_TypeDef *)JL_LRCT_BASE) ////............. 0x3700 - 0x37ff............ //typedef struct { // __WO __u32 CON; // __RO __u32 RESERVED[8-0-1]; // __WO __u32 ME; //} JL_EFUSE_TypeDef; // //#define JL_EFUSE_BASE (ls_base + map_adr(0x37, 0x00)) //#define JL_EFUSE ((JL_EFUSE_TypeDef *)JL_EFUSE_BASE) //............. 0x3b00 - 0x3bff............ typedef struct { __RO __u32 R64L; __RO __u32 R64H; } JL_RAND_TypeDef; #define JL_RAND_BASE (ls_base + map_adr(0x3b, 0x00)) #define JL_RAND ((JL_RAND_TypeDef *)JL_RAND_BASE) //............. 0x3c00 - 0x3cff............ CTM //............. 0x3e00 - 0x3eff............ for p33 typedef struct { __RW __u32 PMU_CON; __RW __u32 PMU_STA; } JL_PMU_TypeDef; #define JL_PMU_BASE (ls_base + map_adr(0x3e, 0x00)) #define JL_PMU ((JL_PMU_TypeDef *)JL_PMU_BASE) //............. 0x3f00 - 0x3fff............ for dma //typedef struct { // __RW __u32 PRI0; // __RW __u32 PRI1; // __RW __u32 PRI2; // __RW __u32 PRI3; // __RW __u32 RESERVED0[0x08 - 0x03 - 1]; // __RW __u32 MSG; // __RO __u32 MSG_CH; // __RW __u32 RDL; // __RW __u32 RDH; // __RW __u32 WRL; // __RW __u32 WRH; // //} JL_DMA_TypeDef; // //#define JL_DMA_BASE (ls_base + map_adr(0x3f, 0x00)) //#define JL_DMA ((JL_DMA_TypeDef *)JL_DMA_BASE) //............. 0x4000 - 0x40ff............ //............. 0x4100 - 0x41ff............ for lsb peri(spi0/sd0) typedef struct { __RW __u8 ENCCON ; __WO __u16 ENCKEY ; __WO __u16 ENCADR ; } JL_PERIENC_TypeDef; #define JL_PERIENC_BASE (ls_base + map_adr(0x41, 0x00)) #define JL_PERIENC ((JL_PERIENC_TypeDef *)JL_PERIENC_BASE) //............. 0x4200 - 0x42ff............ for sbc //............. 0x4300 - 0x43ff............ for aes typedef struct { __RW __u32 CON; __RW __u32 DATIN; __WO __u32 KEY; __RW __u32 ENCRES0; __RW __u32 ENCRES1; __RW __u32 ENCRES2; __RW __u32 ENCRES3; __WO __u32 NONCE; __WO __u8 HEADER; __WO __u32 SRCADR; __WO __u32 DSTADR; __WO __u32 CTCNT; __WO __u32 TAGLEN; __RO __u32 TAGRES0; __RO __u32 TAGRES1; __RO __u32 TAGRES2; __RO __u32 TAGRES3; } JL_AES_TypeDef; #define JL_AES_BASE (ls_base + map_adr(0x43, 0x00)) #define JL_AES ((JL_AES_TypeDef *)JL_AES_BASE) //............. 0x4400 - 0x44ff............ //Used by rdec1 //............. 0x4500 - 0x45ff............ //Used by rdec2 //............. 0x4600 - 0x46ff............ for mbist typedef struct { __RW __u32 CON; __RO __u32 SO; __RO __u32 GO; __RO __u32 DONE; } JL_MBIST_TypeDef; #define JL_MBIST_BASE (ls_base + map_adr(0x46, 0x00)) #define JL_MBIST ((JL_MBIST_TypeDef *)JL_MBIST_BASE) //............. 0x4700 - 0x47ff............ for pll_ctl typedef struct { __RW __u32 PLL_CON0; __RW __u32 PLL_CON1; __RW __u32 PLL_CON2; __RW __u32 PLL_CON3; __RW __u32 PLL_CON4; __RW __u32 PLL_INTF0; __RW __u32 PLL_INTF1; } JL_PLL_TypeDef; #define JL_PLL_BASE (ls_base + map_adr(0x47, 0x00)) #define JL_PLL ((JL_PLL_TypeDef *)JL_PLL_BASE) //............. 0x4800 - 0x48ff............ for aac //typedef struct { // __RW __u32 CON0; // __WO __u32 CON1; // __RW __u32 CON2; // __WO __u32 WGLS_L; // __WO __u32 WGLS_R; // __WO __u32 PARAM_WADR; // __WO __u32 PARAM_WDAT; // __WO __u32 SPEC_ADR; // __WO __u32 DATA_ADR; // __WO __u32 HALF_ADR; // __RW __u32 PCM_CNT; // __WO __u32 PCM_START_ADR; // __RW __u32 PCM_END_ADR; // __WO __u32 PCM_PDAT; // __WO __u32 PCM_PDAT_ADD; // //} JL_AAC_TypeDef; // //#define JL_AAC_BASE (ls_base + map_adr(0x48, 0x00)) //#define JL_AAC ((JL_AAC_TypeDef *)JL_AAC_BASE) //............. 0x4a00 - 0x4fff............ for sie typedef struct { __RW __u32 FADDR; __RW __u32 POWER; __RO __u32 INTRTX1; __RO __u32 INTRTX2; __RO __u32 INTRRX1; __RO __u32 INTRRX2; __RO __u32 INTRUSB; __RW __u32 INTRTX1E; __RW __u32 INTRTX2E; __RW __u32 INTRRX1E; __RW __u32 INTRRX2E; __RW __u32 INTRUSBE; __RO __u32 FRAME1; __RO __u32 FRAME2; __RO __u32 RESERVED14; __RW __u32 DEVCTL; __RO __u32 RESERVED10_0x16[0x16 - 0x10 + 1]; } JL_USB_SIE_TypeDef; #define JL_USB_SIE_BASE (ls_base + map_adr(0x4a, 0x00)) #define JL_USB_SIE ((JL_USB_SIE_TypeDef *)JL_USB_SIE_BASE) #define JL_USB1_SIE_BASE (ls_base + map_adr(0x5b, 0x00)) #define JL_USB1_SIE ((JL_USB_SIE_TypeDef *)JL_USB1_SIE_BASE) typedef struct { __RO __u32 RESERVED0; __RW __u32 CSR0; __RO __u32 RESERVED2_5[5 - 1]; __RO __u32 COUNT0; } JL_USB_EP0_TypeDef; #define JL_USB_EP0_BASE (ls_base + map_adr(0x4a, 0x10)) #define JL_USB_EP0 ((JL_USB_EP0_TypeDef *)JL_USB_EP0_BASE) #define JL_USB1_EP0_BASE (ls_base + map_adr(0x5b, 0x10)) #define JL_USB1_EP0 ((JL_USB_EP0_TypeDef *)JL_USB1_EP0_BASE) typedef struct { __RW __u32 TXMAXP; __RW __u32 TXCSR1; __RW __u32 TXCSR2; __RW __u32 RXMAXP; __RW __u32 RXCSR1; __RW __u32 RXCSR2; __RO __u32 RXCOUNT1; __RO __u32 RXCOUNT2; __RW __u32 TXTYPE; __RW __u32 TXINTERVAL; __RW __u32 RXTYPE; __RW __u32 RXINTERVAL; } JL_USB_EP_TypeDef; #define JL_USB_EP1_BASE (ls_base + map_adr(0x4b, 0x10)) #define JL_USB_EP1 ((JL_USB_EP_TypeDef *)JL_USB_EP1_BASE) #define JL_USB_EP2_BASE (ls_base + map_adr(0x4c, 0x10)) #define JL_USB_EP2 ((JL_USB_EP_TypeDef *)JL_USB_EP2_BASE) #define JL_USB_EP3_BASE (ls_base + map_adr(0x4d, 0x10)) #define JL_USB_EP3 ((JL_USB_EP_TypeDef *)JL_USB_EP3_BASE) #define JL_USB_EP4_BASE (ls_base + map_adr(0x4e, 0x10)) #define JL_USB_EP4 ((JL_USB_EP_TypeDef *)JL_USB_EP4_BASE) #define JL_USB1_EP1_BASE (ls_base + map_adr(0x5c, 0x10)) #define JL_USB1_EP1 ((JL_USB_EP_TypeDef *)JL_USB1_EP1_BASE) #define JL_USB1_EP2_BASE (ls_base + map_adr(0x5d, 0x10)) #define JL_USB1_EP2 ((JL_USB_EP_TypeDef *)JL_USB1_EP2_BASE) #define JL_USB1_EP3_BASE (ls_base + map_adr(0x5e, 0x10)) #define JL_USB1_EP3 ((JL_USB_EP_TypeDef *)JL_USB1_EP3_BASE) #define JL_USB1_EP4_BASE (ls_base + map_adr(0x5f, 0x10)) #define JL_USB1_EP4 ((JL_USB_EP_TypeDef *)JL_USB1_EP4_BASE) //............. 0x5000 - 0x53ff............ for port typedef struct { __RW __u32 OUT; __RO __u32 IN; __RW __u32 DIR; __RW __u32 DIE; __RW __u32 PU; __RW __u32 PD; __RW __u32 HD0; __RW __u32 HD; __RW __u32 DIEH; } JL_PORT_FLASH_TypeDef; #define JL_PORTA_BASE (ls_base + map_adr(0x50, 0x00)) #define JL_PORTA ((JL_PORT_FLASH_TypeDef *)JL_PORTA_BASE) #define JL_PORTB_BASE (ls_base + map_adr(0x51, 0x00)) #define JL_PORTB ((JL_PORT_FLASH_TypeDef *)JL_PORTB_BASE) #define JL_PORTC_BASE (ls_base + map_adr(0x52, 0x00)) #define JL_PORTC ((JL_PORT_FLASH_TypeDef *)JL_PORTC_BASE) #define JL_PORTD_BASE (ls_base + map_adr(0x53, 0x00)) #define JL_PORTD ((JL_PORT_FLASH_TypeDef *)JL_PORTD_BASE) #define JL_PORTP_BASE (ls_base + map_adr(0x59, 0x00)) #define JL_PORTP ((JL_PORT_FLASH_TypeDef *)JL_PORTP_BASE) typedef struct { __RW __u32 CON0; } JL_USB_IO_TypeDef; #define JL_USB_IO_BASE (ls_base + map_adr(0x54, 0x00)) #define JL_USB_IO ((JL_USB_IO_TypeDef *)JL_USB_IO_BASE) #define JL_USB1_IO_BASE (ls_base + map_adr(0x54, 0x09)) #define JL_USB1_IO ((JL_USB_IO_TypeDef *)JL_USB1_IO_BASE) typedef struct { __RW __u32 CON0; __RW __u32 CON1; __RW __u32 CON2; __RW __u32 CON3; } JL_WAKEUP_TypeDef; #define JL_WAKEUP_BASE (ls_base + map_adr(0x54, 0x01)) #define JL_WAKEUP ((JL_WAKEUP_TypeDef *)JL_WAKEUP_BASE) typedef struct { __RW __u32 CON0; __RW __u32 CON1; __RW __u32 CON2; __RW __u32 CON3; } JL_IOMAP_TypeDef; #define JL_IOMAP_BASE (ls_base + map_adr(0x54, 0x05)) #define JL_IOMAP ((JL_IOMAP_TypeDef *)JL_IOMAP_BASE) typedef struct { __RW __u32 CON0; __RW __u32 CON1; __RW __u32 CON2; __RW __u32 CON3; __RW __u32 BRI_PRDL; __RW __u32 BRI_PRDH; __RW __u32 BRI_DUTY0L; __RW __u32 BRI_DUTY0H; __RW __u32 BRI_DUTY1L; __RW __u32 BRI_DUTY1H; __RW __u32 PRD_DIVL; __RW __u32 DUTY0; __RW __u32 DUTY1; __RW __u32 DUTY2; __RW __u32 DUTY3; __RO __u32 CNT_RD; } JL_PLED_TypeDef; #define JL_PLED_BASE (ls_base + map_adr(0x55, 0x00)) #define JL_PLED ((JL_PLED_TypeDef *)JL_PLED_BASE) //typedef struct { // __RW __u32 CON0; // __RW __u32 SEG_IOEN0; // __RW __u32 SEG_IOEN1; //} JL_LCD_TypeDef; // //#define JL_LCD_BASE (ls_base + map_adr(0x53, 0x00)) //#define JL_LCD ((JL_LCD_TypeDef *)JL_LCD_BASE) //............. Full Speed USB ................... // #define FADDR 0x00 // #define POWER 0x01 // #define INTRTX1 0x02 // #define INTRTX2 0x03 // #define INTRRX1 0x04 // #define INTRRX2 0x05 // #define INTRUSB 0x06 // #define INTRTX1E 0x07 // #define INTRTX2E 0x08 // #define INTRRX1E 0x09 // #define INTRRX2E 0x0a // #define INTRUSBE 0x0b // #define FRAME1 0x0c // #define FRAME2 0x0d // #define INDEX 0x0e // #define DEVCTL 0x0f // #define TXMAXP 0x10 // #define CSR0 0x11 // #define TXCSR1 0x11 // #define TXCSR2 0x12 // #define RXMAXP 0x13 // #define RXCSR1 0x14 // #define RXCSR2 0x15 // #define COUNT0 0x16 // #define RXCOUNT1 0x16 // #define RXCOUNT2 0x17 // #define TXTYPE 0x18 // #define TXINTERVAL 0x19 // #define RXTYPE 0x1a // #define RXINTERVAL 0x1b #include "io_omap.h" #include "io_imap.h" #endif