4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-23 06:17:21 +08:00

2827 lines
93 KiB
C

/*******************************************************************************
* (c) Copyright 2010-2013 Microsemi SoC Products Group. All rights reserved.
*
* Microsemi SmartFusion2 Cortex Microcontroller Software Interface - Peripheral
* Access Layer.
*
* This file describes the interrupt assignment and peripheral registers for
* the SmartFusion2 familly of devices.
*
* SVN $Revision: 6526 $
* SVN $Date: 2014-06-05 16:07:40 +0100 (Thu, 05 Jun 2014) $
*/
#ifndef __SMARTFUSION2_CMSIS_PAL_H__
#define __SMARTFUSION2_CMSIS_PAL_H__
#ifdef __cplusplus
extern "C" {
#endif
/*
* ==========================================================================
* ---------- Interrupt Number Definition -----------------------------------
* ==========================================================================
*/
typedef enum IRQn
{
/****** Cortex-M3 Processor Exceptions Numbers *********************************************************/
NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt - Watchdog timeout interrupt*/
HardFault_IRQn = -13, /*!< 2 Hard Fault Interrupt */
MemoryManagement_IRQn = -12, /*!< 4 Cortex-M3 Memory Management Interrupt */
BusFault_IRQn = -11, /*!< 5 Cortex-M3 Bus Fault Interrupt */
UsageFault_IRQn = -10, /*!< 6 Cortex-M3 Usage Fault Interrupt */
SVCall_IRQn = -5, /*!< 11 Cortex-M3 SV Call Interrupt */
DebugMonitor_IRQn = -4, /*!< 12 Cortex-M3 Debug Monitor Interrupt */
PendSV_IRQn = -2, /*!< 14 Cortex-M3 Pend SV Interrupt */
SysTick_IRQn = -1, /*!< 15 Cortex-M3 System Tick Interrupt */
/****** SmartFusion2 specific Interrupt Numbers *********************************************************/
WdogWakeup_IRQn = 0, /*!< WatchDog wakeup interrupt */
RTC_Wakeup_IRQn = 1, /*!< RTC wakeup interrupt */
SPI0_IRQn = 2, /*!< SPI0 interrupt */
SPI1_IRQn = 3, /*!< SPI1 interrupt */
I2C0_IRQn = 4, /*!< I2C0 interrupt */
I2C0_SMBAlert_IRQn = 5, /*!< I2C0 SMBus Alert interrupt */
I2C0_SMBus_IRQn = 6, /*!< I2C0 SMBus Suspend interrupt */
I2C1_IRQn = 7, /*!< I2C1 interrupt */
I2C1_SMBAlert_IRQn = 8, /*!< I2C1 SMBus Alert interrupt */
I2C1_SMBus_IRQn = 9, /*!< I2C1 SMBus Suspend interrupt */
UART0_IRQn = 10, /*!< UART0 interrupt */
UART1_IRQn = 11, /*!< UART1 interrupt */
EthernetMAC_IRQn = 12, /*!< Ethernet MAC interrupt */
DMA_IRQn = 13, /*!< Peripheral DMA interrupt */
Timer1_IRQn = 14, /*!< Timer1 interrupt */
Timer2_IRQn = 15, /*!< Timer2 interrupt */
CAN_IRQn = 16, /*!< CAN controller interrupt */
ENVM0_IRQn = 17, /*!< eNVM0 operation completion interrupt */
ENVM1_IRQn = 18, /*!< eNVM1 operation completion interrupt */
ComBlk_IRQn = 19, /*!< COM block interrupt */
USB_IRQn = 20, /*!< USB interrupt */
USB_DMA_IRQn = 21, /*!< USB DMA interrupt */
PLL_Lock_IRQn = 22, /*!< PLL lock interrupt */
PLL_LockLost_IRQn = 23, /*!< PLL loss of lock interrupt */
CommSwitchError_IR = 24, /*!< Communications Switch error interrupt */
CacheError_IRQn = 25, /*!< Cache error interrupt */
DDR_IRQn = 26, /*!< DDR controller interrupt */
HPDMA_Complete_IRQn = 27, /*!< High speed DMA transfer complete interrupt */
HPDMA_Error_IRQn = 28, /*!< High speed DMA transfer error interrupt */
ECC_Error_IRQn = 29, /*!< ECC error detected */
MDDR_IOCalib_IRQn = 30, /*!< MDDR Calibration finished interrupt */
FAB_PLL_Lock_IRQn = 31, /*!< MSSDDR Fabric PLL lock interrupt */
FAB_PLL_LockLost_IRQn = 32, /*!< MSSDDR Fabric PLL lock lost interrupt */
FIC64_IRQn = 33, /*!< FIC64 interrupt */
FabricIrq0_IRQn = 34, /*!< FPGA fabric interrupt 0 */
FabricIrq1_IRQn = 35, /*!< FPGA fabric interrupt 1 */
FabricIrq2_IRQn = 36, /*!< FPGA fabric interrupt 2 */
FabricIrq3_IRQn = 37, /*!< FPGA fabric interrupt 3 */
FabricIrq4_IRQn = 38, /*!< FPGA fabric interrupt 4 */
FabricIrq5_IRQn = 39, /*!< FPGA fabric interrupt 5 */
FabricIrq6_IRQn = 40, /*!< FPGA fabric interrupt 6 */
FabricIrq7_IRQn = 41, /*!< FPGA fabric interrupt 7 */
FabricIrq8_IRQn = 42, /*!< FPGA fabric interrupt 8 */
FabricIrq9_IRQn = 43, /*!< FPGA fabric interrupt 9 */
FabricIrq10_IRQn = 44, /*!< FPGA fabric interrupt 10 */
FabricIrq11_IRQn = 45, /*!< FPGA fabric interrupt 11 */
FabricIrq12_IRQn = 46, /*!< FPGA fabric interrupt 12 */
FabricIrq13_IRQn = 47, /*!< FPGA fabric interrupt 13 */
FabricIrq14_IRQn = 48, /*!< FPGA fabric interrupt 14 */
FabricIrq15_IRQn = 49, /*!< FPGA fabric interrupt 15 */
GPIO0_IRQn = 50, /*!< GPIO 0 interrupt */
GPIO1_IRQn = 51, /*!< GPIO 1 interrupt */
GPIO2_IRQn = 52, /*!< GPIO 2 interrupt */
GPIO3_IRQn = 53, /*!< GPIO 3 interrupt */
GPIO4_IRQn = 54, /*!< GPIO 4 interrupt */
GPIO5_IRQn = 55, /*!< GPIO 5 interrupt */
GPIO6_IRQn = 56, /*!< GPIO 6 interrupt */
GPIO7_IRQn = 57, /*!< GPIO 7 interrupt */
GPIO8_IRQn = 58, /*!< GPIO 8 interrupt */
GPIO9_IRQn = 59, /*!< GPIO 9 interrupt */
GPIO10_IRQn = 60, /*!< GPIO 10 interrupt */
GPIO11_IRQn = 61, /*!< GPIO 11 interrupt */
GPIO12_IRQn = 62, /*!< GPIO 12 interrupt */
GPIO13_IRQn = 63, /*!< GPIO 13 interrupt */
GPIO14_IRQn = 64, /*!< GPIO 14 interrupt */
GPIO15_IRQn = 65, /*!< GPIO 15 interrupt */
GPIO16_IRQn = 66, /*!< GPIO 16 interrupt */
GPIO17_IRQn = 67, /*!< GPIO 17 interrupt */
GPIO18_IRQn = 68, /*!< GPIO 18 interrupt */
GPIO19_IRQn = 69, /*!< GPIO 19 interrupt */
GPIO20_IRQn = 70, /*!< GPIO 20 interrupt */
GPIO21_IRQn = 71, /*!< GPIO 21 interrupt */
GPIO22_IRQn = 72, /*!< GPIO 22 interrupt */
GPIO23_IRQn = 73, /*!< GPIO 23 interrupt */
GPIO24_IRQn = 74, /*!< GPIO 24 interrupt */
GPIO25_IRQn = 75, /*!< GPIO 25 interrupt */
GPIO26_IRQn = 76, /*!< GPIO 26 interrupt */
GPIO27_IRQn = 77, /*!< GPIO 27 interrupt */
GPIO28_IRQn = 78, /*!< GPIO 28 interrupt */
GPIO29_IRQn = 79, /*!< GPIO 29 interrupt */
GPIO30_IRQn = 80, /*!< GPIO 30 interrupt */
GPIO31_IRQn = 81 /*!< GPIO 31 interrupt */
} IRQn_Type;
/*
* ==========================================================================
* ----------- Processor and Core Peripheral Section ------------------------
* ==========================================================================
*/
#define __CM3_REV 0x0201 /*!< Core revision r2p1 */
#define __MPU_PRESENT 1 /*!< MPU present or not */
#define __NVIC_PRIO_BITS 4 /*!< Number of Bits used for Priority Levels */
#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */
#include <core_cm3.h> /* Cortex-M3 processor and core peripherals */
/******************************************************************************/
/* Device Specific Peripheral registers structures */
/******************************************************************************/
#if defined ( __CC_ARM )
/* Enable anonymous unions when building using Keil-MDK */
#pragma anon_unions
#endif
/*----------------------------------------------------------------------------*/
/*----------------------------------- UART -----------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
union
{
__I uint8_t RBR;
__O uint8_t THR;
__IO uint8_t DLR;
uint32_t RESERVED0;
};
union
{
__IO uint8_t DMR;
__IO uint8_t IER;
uint32_t RESERVED1;
};
union
{
__IO uint8_t IIR;
__IO uint8_t FCR;
uint32_t RESERVED2;
};
__IO uint8_t LCR;
uint8_t RESERVED3[3];
__IO uint8_t MCR;
uint8_t RESERVED4[3];
__I uint8_t LSR;
uint8_t RESERVED5[3];
__I uint8_t MSR;
uint8_t RESERVED6[3];
__IO uint8_t SR;
uint8_t RESERVED7[7];
__IO uint8_t IEM;
uint8_t RESERVED8[3];
__IO uint8_t IIM;
uint8_t RESERVED9[7];
__IO uint8_t MM0;
uint8_t RESERVED10[3];
__IO uint8_t MM1;
uint8_t RESERVED11[3];
__IO uint8_t MM2;
uint8_t RESERVED12[3];
__IO uint8_t DFR;
uint8_t RESERVED13[7];
__IO uint8_t GFR;
uint8_t RESERVED14[3];
__IO uint8_t TTG;
uint8_t RESERVED15[3];
__IO uint8_t RTO;
uint8_t RESERVED16[3];
__IO uint8_t ADR;
uint8_t RESERVED17[3];
} UART_TypeDef;
/*----------------------------------------------------------------------------*/
/*----------------------------------- I2C ------------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint8_t CTRL;
uint8_t RESERVED0;
uint16_t RESERVED1;
uint8_t STATUS;
uint8_t RESERVED2;
uint16_t RESERVED3;
__IO uint8_t DATA;
uint8_t RESERVED4;
uint16_t RESERVED5;
__IO uint8_t ADDR;
uint8_t RESERVED6;
uint16_t RESERVED7;
__IO uint8_t SMBUS;
uint8_t RESERVED8;
uint16_t RESERVED9;
__IO uint8_t FREQ;
uint8_t RESERVED10;
uint16_t RESERVED11;
__IO uint8_t GLITCHREG;
uint8_t RESERVED12;
uint16_t RESERVED13;
__IO uint8_t SLAVE1_ADDR;
uint8_t RESERVED14;
uint16_t RESERVED15;
} I2C_TypeDef;
/*------------------------------------------------------------------------------
* I2C bit band
*/
typedef struct
{
__IO uint32_t CTRL_CR0;
__IO uint32_t CTRL_CR1;
__IO uint32_t CTRL_AA;
__IO uint32_t CTRL_SI;
__IO uint32_t CTRL_STO;
__IO uint32_t CTRL_STA;
__IO uint32_t CTRL_ENS1;
__IO uint32_t CTRL_CR2;
uint32_t RESERVED0[56];
__IO uint32_t DATA_DIR;
uint32_t RESERVED1[31];
__IO uint32_t ADDR_GC;
} I2C_BitBand_TypeDef;
/*----------------------------------------------------------------------------*/
/*----------------------------------- SPI ------------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint32_t CONTROL;
__IO uint32_t TXRXDF_SIZE;
__I uint32_t STATUS;
__O uint32_t INT_CLEAR;
__I uint32_t RX_DATA;
__O uint32_t TX_DATA;
__IO uint32_t CLK_GEN;
__IO uint32_t SLAVE_SELECT;
__I uint32_t MIS;
__I uint32_t RIS;
__IO uint32_t CONTROL2;
__IO uint32_t COMMAND;
__IO uint32_t PKTSIZE;
__IO uint32_t CMDSIZE;
__IO uint32_t HWSTATUS;
__IO uint32_t STAT8;
__IO uint32_t CTRL0;
__IO uint32_t CTRL1;
__IO uint32_t CTRL2;
__IO uint32_t CTRL3;
} SPI_TypeDef;
/*----------------------------------------------------------------------------*/
/*----------------------------------- GPIO -----------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint32_t GPIO_0_CFG;
__IO uint32_t GPIO_1_CFG;
__IO uint32_t GPIO_2_CFG;
__IO uint32_t GPIO_3_CFG;
__IO uint32_t GPIO_4_CFG;
__IO uint32_t GPIO_5_CFG;
__IO uint32_t GPIO_6_CFG;
__IO uint32_t GPIO_7_CFG;
__IO uint32_t GPIO_8_CFG;
__IO uint32_t GPIO_9_CFG;
__IO uint32_t GPIO_10_CFG;
__IO uint32_t GPIO_11_CFG;
__IO uint32_t GPIO_12_CFG;
__IO uint32_t GPIO_13_CFG;
__IO uint32_t GPIO_14_CFG;
__IO uint32_t GPIO_15_CFG;
__IO uint32_t GPIO_16_CFG;
__IO uint32_t GPIO_17_CFG;
__IO uint32_t GPIO_18_CFG;
__IO uint32_t GPIO_19_CFG;
__IO uint32_t GPIO_20_CFG;
__IO uint32_t GPIO_21_CFG;
__IO uint32_t GPIO_22_CFG;
__IO uint32_t GPIO_23_CFG;
__IO uint32_t GPIO_24_CFG;
__IO uint32_t GPIO_25_CFG;
__IO uint32_t GPIO_26_CFG;
__IO uint32_t GPIO_27_CFG;
__IO uint32_t GPIO_28_CFG;
__IO uint32_t GPIO_29_CFG;
__IO uint32_t GPIO_30_CFG;
__IO uint32_t GPIO_31_CFG;
__IO uint32_t GPIO_IRQ;
__I uint32_t GPIO_IN;
__IO uint32_t GPIO_OUT;
} GPIO_TypeDef;
/*------------------------------------------------------------------------------
* GPIO bit band
*/
typedef struct
{
__IO uint32_t GPIO_0_CFG[32];
__IO uint32_t GPIO_1_CFG[32];
__IO uint32_t GPIO_2_CFG[32];
__IO uint32_t GPIO_3_CFG[32];
__IO uint32_t GPIO_4_CFG[32];
__IO uint32_t GPIO_5_CFG[32];
__IO uint32_t GPIO_6_CFG[32];
__IO uint32_t GPIO_7_CFG[32];
__IO uint32_t GPIO_8_CFG[32];
__IO uint32_t GPIO_9_CFG[32];
__IO uint32_t GPIO_10_CFG[32];
__IO uint32_t GPIO_11_CFG[32];
__IO uint32_t GPIO_12_CFG[32];
__IO uint32_t GPIO_13_CFG[32];
__IO uint32_t GPIO_14_CFG[32];
__IO uint32_t GPIO_15_CFG[32];
__IO uint32_t GPIO_16_CFG[32];
__IO uint32_t GPIO_17_CFG[32];
__IO uint32_t GPIO_18_CFG[32];
__IO uint32_t GPIO_19_CFG[32];
__IO uint32_t GPIO_20_CFG[32];
__IO uint32_t GPIO_21_CFG[32];
__IO uint32_t GPIO_22_CFG[32];
__IO uint32_t GPIO_23_CFG[32];
__IO uint32_t GPIO_24_CFG[32];
__IO uint32_t GPIO_25_CFG[32];
__IO uint32_t GPIO_26_CFG[32];
__IO uint32_t GPIO_27_CFG[32];
__IO uint32_t GPIO_28_CFG[32];
__IO uint32_t GPIO_29_CFG[32];
__IO uint32_t GPIO_30_CFG[32];
__IO uint32_t GPIO_31_CFG[32];
__IO uint32_t GPIO_IRQ[32];
__I uint32_t GPIO_IN[32];
__IO uint32_t GPIO_OUT[32];
} GPIO_BitBand_TypeDef;
/*----------------------------------------------------------------------------*/
/*--------------------------------- HPDMA ------------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint32_t HPDMASAR_REG ;
__IO uint32_t HPDMADAR_REG ;
__IO uint32_t HPDMACR_REG ;
__I uint32_t HPDMASR_REG ;
__I uint32_t HPDMAPTR_REG ;
}HPDMA_Descriptor_TypeDef;
typedef struct
{
__I uint32_t HPDMAEDR_REG ;
HPDMA_Descriptor_TypeDef Descriptor[4] ;
__O uint32_t HPDMAICR_REG ;
__I uint32_t HPDMADR_REG ;
} HPDMA_TypeDef;
typedef struct
{
uint32_t RESERVED0[64];
__IO uint32_t HPDMACR_XFR_SIZE[16] ;
__IO uint32_t HPDMACR_DCP_VALID ;
__IO uint32_t HPDMACR_DCP_XFR_DIR ;
__IO uint32_t HPDMACR_DCP_CLR ;
__IO uint32_t HPDMACR_DCP_PAUSE ;
__IO uint32_t HPDMACR_XFR_CMP_INT ;
__IO uint32_t HPDMACR_XFR_ERR_INT ;
__IO uint32_t HPDMACR_NON_WORD_INT ;
uint32_t RESERVED1[9];
__I uint32_t HPDMASR_DCP_ACTIVE ;
__I uint32_t HPDMASR_DCP_CMPLET ;
__I uint32_t HPDMASR_DCP_SERR ;
__I uint32_t HPDMASR_DCP_DERR ;
uint32_t RESERVED2[60] ;
}HPDMA_Descriptor_BitBand_TypeDef;
/*------------------------------------------------------------------------------
* HPDMA bit band
*/
typedef struct
{
__I uint32_t HPDMAEDR_DCP_EMPTY[4] ;
__I uint32_t HPDMAEDR_DCP_CMPLET[4] ;
__I uint32_t HPDMAEDR_DCP_ERR[4] ;
__I uint32_t HPDMAEDR_DCP_NON_WORD_ERR[4] ;
uint32_t RESERVED0[16] ;
HPDMA_Descriptor_BitBand_TypeDef Descriptor[4];
__O uint32_t HPDMAICR_CLR_XFR_INT[4] ;
__O uint32_t HPDMAICR_NON_WORD_INT[4] ;
uint32_t RESERVED1[16] ;
__I uint32_t HPDMADR_BFR_EMPTY ;
__I uint32_t HPDMADR_BFR_FULL ;
__I uint32_t HPDMADR_BFR_RD_PNTR[3] ;
__I uint32_t HPDMADR_BFR_WR_PNTR [3] ;
__I uint32_t HPDMADR_AHM1_CST_DBG[4] ;
__I uint32_t HPDMADR_AHM2_CST_DBG[4] ;
__I uint32_t HPDMADR_WBC_CST_DBG[3] ;
__I uint32_t HPDMADR_RBC_CST_DBG[3] ;
__I uint32_t HPDMADR_RRBN_CST_DBG[4] ;
__I uint32_t HPDMADR_DMA_CST_DBG[4] ;
uint32_t RESERVED2[4] ;
}HPDMA_BitBand_TypeDef;
/*----------------------------------------------------------------------------*/
/*----------------------------------- RTC ------------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint32_t CONTROL_REG ;
__IO uint32_t MODE_REG ;
__IO uint32_t PRESCALER_REG ;
__IO uint32_t ALARM_LOWER_REG ;
__IO uint32_t ALARM_UPPER_REG ;
__IO uint32_t COMPARE_LOWER_REG ;
__IO uint32_t COMPARE_UPPER_REG ;
uint32_t RESERVED0 ;
__IO uint32_t DATE_TIME_LOWER_REG ;
__IO uint32_t DATE_TIME_UPPER_REG ;
uint32_t RESERVED1[2] ;
__IO uint32_t SECONDS_REG ;
__IO uint32_t MINUTES_REG ;
__IO uint32_t HOURS_REG ;
__IO uint32_t DAY_REG ;
__IO uint32_t MONTH_REG ;
__IO uint32_t YEAR_REG ;
__IO uint32_t WEEKDAY_REG ;
__IO uint32_t WEEK_REG ;
__IO uint32_t SECONDS_CNT_REG ;
__IO uint32_t MINUTES_CNT_REG ;
__IO uint32_t HOURS_CNT_REG ;
__IO uint32_t DAY_CNT_REG ;
__IO uint32_t MONTH_CNT_REG ;
__IO uint32_t YEAR_CNT_REG ;
__IO uint32_t WEEKDAY_CNT_REG ;
__IO uint32_t WEEK_CNT_REG ;
} RTC_TypeDef;
/*----------------------------------------------------------------------------*/
/*---------------------------------- Timer -----------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__I uint32_t TIM1_VAL;
__IO uint32_t TIM1_LOADVAL;
__IO uint32_t TIM1_BGLOADVAL;
__IO uint32_t TIM1_CTRL;
__IO uint32_t TIM1_RIS;
__I uint32_t TIM1_MIS;
__I uint32_t TIM2_VAL;
__IO uint32_t TIM2_LOADVAL;
__IO uint32_t TIM2_BGLOADVAL;
__IO uint32_t TIM2_CTRL;
__IO uint32_t TIM2_RIS;
__I uint32_t TIM2_MIS;
__I uint32_t TIM64_VAL_U;
__I uint32_t TIM64_VAL_L;
__IO uint32_t TIM64_LOADVAL_U;
__IO uint32_t TIM64_LOADVAL_L;
__IO uint32_t TIM64_BGLOADVAL_U;
__IO uint32_t TIM64_BGLOADVAL_L;
__IO uint32_t TIM64_CTRL;
__IO uint32_t TIM64_RIS;
__I uint32_t TIM64_MIS;
__IO uint32_t TIM64_MODE;
} TIMER_TypeDef;
/*------------------------------------------------------------------------------
* Timer bit band
*/
typedef struct
{
__I uint32_t TIM1_VALUE_BIT[32];
__IO uint32_t TIM1_LOADVAL[32];
__IO uint32_t TIM1_BGLOADVAL[32];
__IO uint32_t TIM1ENABLE;
__IO uint32_t TIM1MODE;
__IO uint32_t TIM1INTEN;
__IO uint32_t TIM1_CTRL_RESERVED[29];
__IO uint32_t TIM1_RIS[32];
__I uint32_t TIM1_MIS[32];
__I uint32_t TIM2_VALUE[32];
__IO uint32_t TIM2_LOADVAL[32];
__IO uint32_t TIM2_BGLOADVAL[32];
__IO uint32_t TIM2ENABLE;
__IO uint32_t TIM2MODE;
__IO uint32_t TIM2INTEN;
__IO uint32_t TIM2_CTRL[29];
__IO uint32_t TIM2_RIS[32];
__I uint32_t TIM2_MIS[32];
__I uint32_t TIM64VALUEU[32];
__I uint32_t TIM64VALUEL[32];
__IO uint32_t TIM64LOADVALUEU[32];
__IO uint32_t TIM64LOADVALUEL[32];
__IO uint32_t TIM64BGLOADVALUEU[32];
__IO uint32_t TIM64BGLOADVALUEL[32];
__IO uint32_t TIM64ENABLE;
__IO uint32_t TIM64MODE;
__IO uint32_t TIM64INTEN;
__IO uint32_t TIM64_CTRL[29];
__IO uint32_t TIM64_RIS[32];
__I uint32_t TIM64_MIS[32];
__IO uint32_t TIM64_MODE[32];
} TIMER_BitBand_TypeDef;
/*----------------------------------------------------------------------------*/
/*--------------------------------- Watchdog ---------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__I uint32_t WDOGVALUE;
__I uint32_t WDOGLOAD;
__I uint32_t WDOGMVRP;
__O uint32_t WDOGREFRESH;
__I uint32_t WDOGENABLE;
__IO uint32_t WDOGCONTROL;
__I uint32_t WDOGSTATUS;
__IO uint32_t WDOGRIS;
__I uint32_t WDOGMIS;
} WATCHDOG_TypeDef;
/*----------------------------------------------------------------------------*/
/*----------------------------- Real Time Clock ------------------------------*/
/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/
/*----------------------------- Peripherals DMA ------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint32_t CRTL;
__IO uint32_t STATUS;
__IO uint32_t BUFFER_A_SRC_ADDR;
__IO uint32_t BUFFER_A_DEST_ADDR;
__IO uint32_t BUFFER_A_TRANSFER_COUNT;
__IO uint32_t BUFFER_B_SRC_ADDR;
__IO uint32_t BUFFER_B_DEST_ADDR;
__IO uint32_t BUFFER_B_TRANSFER_COUNT;
} PDMA_Channel_TypeDef;
typedef struct
{
__IO uint32_t RATIO_HIGH_LOW;
__IO uint32_t BUFFER_STATUS;
uint32_t RESERVED[6];
PDMA_Channel_TypeDef CHANNEL[8];
} PDMA_TypeDef;
/*----------------------------------------------------------------------------*/
/*------------------------------ Ethernet MAC --------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
/*
* MAC registers (MCXMAC)
*/
__IO uint32_t CFG1;
__IO uint32_t CFG2;
__IO uint32_t IFG;
__IO uint32_t HALF_DUPLEX;
__IO uint32_t MAX_FRAME_LENGTH;
uint32_t RESERVED0[2];
__IO uint32_t TEST;
__IO uint32_t MII_CONFIG;
__IO uint32_t MII_COMMAND;
__IO uint32_t MII_ADDRESS;
__O uint32_t MII_CTRL;
__I uint32_t MII_STATUS;
__I uint32_t MII_INDICATORS;
__IO uint32_t INTERFACE_CTRL;
__I uint32_t INTERFACE_STATUS;
__IO uint32_t STATION_ADDRESS1;
__IO uint32_t STATION_ADDRESS2;
/*
* FIFO Configuration / Access registers (MCXFIF)
*/
__IO uint32_t FIFO_CFG0;
__IO uint32_t FIFO_CFG1;
__IO uint32_t FIFO_CFG2;
__IO uint32_t FIFO_CFG3;
__IO uint32_t FIFO_CFG4;
__IO uint32_t FIFO_CFG5;
__IO uint32_t FIFO_RAM_ACCESS0;
__IO uint32_t FIFO_RAM_ACCESS1;
__IO uint32_t FIFO_RAM_ACCESS2;
__I uint32_t FIFO_RAM_ACCESS3;
__IO uint32_t FIFO_RAM_ACCESS4;
__IO uint32_t FIFO_RAM_ACCESS5;
__IO uint32_t FIFO_RAM_ACCESS6;
__I uint32_t FIFO_RAM_ACCESS7;
/*
* Statistics registers (MSTAT)
*/
__IO uint32_t TR64;
__IO uint32_t TR127;
__IO uint32_t TR255;
__IO uint32_t TR511;
__IO uint32_t TR1K;
__IO uint32_t TRMAX;
__IO uint32_t TRMGV;
__IO uint32_t RBYT;
__IO uint32_t PPKT;
__IO uint32_t RFCS;
__IO uint32_t RMCA;
__IO uint32_t RBCA;
__IO uint32_t RXCF;
__IO uint32_t RXPF;
__IO uint32_t RXUO;
__IO uint32_t RALN;
__IO uint32_t RFLR;
__IO uint32_t RCDE;
__IO uint32_t RCSE;
__IO uint32_t RUND;
__IO uint32_t ROVR;
__IO uint32_t RFRG;
__IO uint32_t RJBR;
__IO uint32_t RDRP;
__IO uint32_t TBYT;
__IO uint32_t TPKT;
__IO uint32_t TMCA;
__IO uint32_t TBCA;
__IO uint32_t TXPF;
__IO uint32_t TDFR;
__IO uint32_t TEDF;
__IO uint32_t TSCL;
__IO uint32_t TMCL;
__IO uint32_t TLCL;
__IO uint32_t TXCL;
__IO uint32_t TNCL;
__IO uint32_t TPFH;
__IO uint32_t TDRP;
__IO uint32_t TJBR;
__IO uint32_t TFCS;
__IO uint32_t TXCF;
__IO uint32_t TOVR;
__IO uint32_t TUND;
__IO uint32_t TFRG;
__I uint32_t CAR1;
__I uint32_t CAR2;
__IO uint32_t CAM1;
__IO uint32_t CAM2;
uint32_t RESERVED1[16];
/*
* DMA registers (MAHBE)
*/
__IO uint32_t DMA_TX_CTRL;
__IO uint32_t DMA_TX_DESC;
__IO uint32_t DMA_TX_STATUS;
__IO uint32_t DMA_RX_CTRL;
__IO uint32_t DMA_RX_DESC;
__IO uint32_t DMA_RX_STATUS;
__IO uint32_t DMA_IRQ_MASK;
__I uint32_t DMA_IRQ;
} MAC_TypeDef;
/*----------------------------------------------------------------------------*/
/*------------------------------ USB --------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint16_t TX_MAX_P;
__IO uint16_t TX_CSR;
__IO uint16_t RX_MAX_P;
__IO uint16_t RX_CSR;
__IO uint16_t RX_COUNT;
__IO uint8_t TX_TYPE;
__IO uint8_t TX_INTERVAL;
__IO uint8_t RX_TYPE;
__IO uint8_t RX_INTERVAL;
__IO uint8_t RESERVED;
__IO uint8_t FIFO_SIZE;
} USB_endpoint_regs_t;
typedef struct
{
__IO uint8_t TX_FUNC_ADDR;
__IO uint8_t UNUSED0;
__IO uint8_t TX_HUB_ADDR;
__IO uint8_t TX_HUB_PORT;
__IO uint8_t RX_FUNC_ADDR;
__IO uint8_t UNUSED1;
__IO uint8_t RX_HUB_ADDR;
__IO uint8_t RX_HUB_PORT;
} USB_tar_t;
typedef union
{
struct
{
__IO uint32_t VALUE;
} WORD;
struct
{
__IO uint8_t VALUE;
__IO uint8_t RESERVED1;
__IO uint8_t RESERVED2;
__IO uint8_t RESERVED3;
} BYTE;
struct
{
__IO uint16_t VALUE;
__IO uint16_t RESERVED;
} HALFWORD;
} USB_fifo_t;
typedef union
{
struct
{
__IO uint16_t TX_MAX_P;
__IO uint16_t CSR0;
__IO uint16_t RX_MAX_P;
__IO uint16_t RX_CSR;
__IO uint16_t COUNT0;
__IO uint8_t RESERVED0;
__IO uint8_t RESERVED1;
__IO uint8_t RESERVED2;
__IO uint8_t RESERVED3;
__IO uint8_t RESERVED4;
__IO uint8_t CONFIG_DATA;
} DEVICE_EP0;
struct
{
__IO uint16_t TX_MAX_P;
__IO uint16_t TX_CSR;
__IO uint16_t RX_MAX_P;
__IO uint16_t RX_CSR;
__IO uint16_t RX_COUNT;
__IO uint8_t RESERVED0;
__IO uint8_t RESERVED1;
__IO uint8_t RESERVED2;
__IO uint8_t RESERVED3;
__IO uint8_t RESERVED4;
__IO uint8_t FIFO_SIZE;
} DEVICE_EPN;
struct
{
__IO uint16_t TX_MAX_P;
__IO uint16_t CSR0;
__IO uint16_t RX_MAX_P;
__IO uint16_t RX_CSR;
__IO uint16_t COUNT0;
__IO uint8_t TYPE0;
__IO uint8_t NAK_LIMIT0;
__IO uint8_t RX_TYPE;
__IO uint8_t RX_INTERVAL;
__IO uint8_t RESERVED0;
__IO uint8_t CONFIG_DATA;
} HOST_EP0;
struct
{
__IO uint16_t TX_MAX_P;
__IO uint16_t TX_CSR;
__IO uint16_t RX_MAX_P;
__IO uint16_t RX_CSR;
__IO uint16_t RX_COUNT;
__IO uint8_t TX_TYPE;
__IO uint8_t TX_INTERVAL;
__IO uint8_t RX_TYPE;
__IO uint8_t RX_INTERVAL;
__IO uint8_t RESERVED0;
__IO uint8_t FIFO_SIZE;
} HOST_EPN;
} USB_indexed_csr_t;
typedef struct {
__IO uint32_t IRQ;
__IO uint32_t CNTL;
__IO uint32_t ADDR;
__IO uint32_t COUNT;
} USB_DMA_channel;
typedef struct
{
/*
* Common USB Registers
*/
__IO uint8_t FADDR;
__IO uint8_t POWER;
__IO uint16_t TX_IRQ;
__IO uint16_t RX_IRQ;
__IO uint16_t TX_IRQ_ENABLE;
__IO uint16_t RX_IRQ_ENABLE;
__IO uint8_t USB_IRQ;
__IO uint8_t USB_ENABLE;
__IO uint16_t FRAME;
__IO uint8_t INDEX;
__IO uint8_t TEST_MODE;
/*
* Indexed CSR
*/
USB_indexed_csr_t INDEXED_CSR;
/*
* Endpoint FIFOs
*/
USB_fifo_t FIFO[16];
/*
* OTG, dynamic FIFO and version
*/
__IO uint8_t DEV_CTRL;
__IO uint8_t MISC;
__IO uint8_t TX_FIFO_SIZE;
__IO uint8_t RX_FIFO_SIZE;
__IO uint16_t TX_FIFO_ADDR;
__IO uint16_t RX_FIFO_ADDR;
__IO uint32_t VBUS_CSR;
__IO uint16_t HW_VERSION;
__IO uint16_t RESERVED;
/*
* ULPI and configuration registers
*/
__IO uint8_t ULPI_VBUS_CTRL;
__IO uint8_t ULPI_CARKIT_CTRL;
__IO uint8_t ULPI_IRQ_MASK;
__IO uint8_t ULPI_IRQ_SRC;
__IO uint8_t ULPI_DATA_REG;
__IO uint8_t ULPI_ADDR_REG;
__IO uint8_t ULPI_CTRL_REG;
__IO uint8_t ULPI_RAW_DATA;
__IO uint8_t EP_INFO;
__IO uint8_t RAM_INFO;
__IO uint8_t LINK_INFO;
__IO uint8_t VP_LEN;
__IO uint8_t HS_EOF1;
__IO uint8_t FS_EOF1;
__IO uint8_t LS_EOF1;
__IO uint8_t SOFT_RST;
/*
* Target Address registers
*/
USB_tar_t TAR[16];
/*
* Endpoints CSR
*/
USB_endpoint_regs_t ENDPOINT[16];
/*
* DMA
*/
USB_DMA_channel DMA_CHANNEL[8];
__IO uint32_t RESERVED_EXT[32];
__IO uint32_t RQ_PKT_CNT[16];
__IO uint16_t RX_DPBUF_DIS;
__IO uint16_t TX_DPBUF_DIS;
__IO uint16_t C_T_UCH;
__IO uint16_t C_T_HHSRTN;
__IO uint16_t C_T_HSBT;
} MSS_USB_TypeDef;
/*----------------------------------------------------------------------------*/
/*---------------------- eNVM Special Function Registers ---------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__I uint8_t AB[128];
__IO uint8_t WD[128];
__I uint8_t RESERVED0[32];
__I uint32_t STATUS;
__IO uint32_t RESERVED1;
__IO uint32_t NV_PAGE_STATUS;
__I uint32_t NV_FREQRNG;
__I uint32_t NV_DPD;
__IO uint32_t NV_CE;
uint32_t RESERVED2;
__IO uint32_t RESERVED3;
__IO uint32_t PAGE_LOCK;
__IO uint32_t DWSIZE;
__IO uint32_t CMD;
__IO uint32_t RESERVED4;
__I uint32_t RESERVED5;
__IO uint32_t INTEN;
__IO uint32_t CLRHINT;
uint32_t RESERVED6[40];
__IO uint32_t REQ_ACCESS;
} NVM_TypeDef;
typedef struct
{
__I uint32_t AB[32];
__IO uint32_t WD[32];
__I uint32_t RESERVED0[8];
__I uint32_t STATUS;
__IO uint32_t RESERVED1;
__IO uint32_t NV_PAGE_STATUS;
__I uint32_t NV_FREQRNG;
__I uint32_t NV_DPD;
__IO uint32_t NV_CE;
uint32_t RESERVED2;
__IO uint32_t RESERVED3;
__IO uint32_t PAGE_LOCK;
__IO uint32_t DWSIZE;
__IO uint32_t CMD;
__IO uint32_t RESERVED4;
__I uint32_t RESERVED5;
__IO uint32_t INTEN;
__IO uint32_t CLRHINT;
uint32_t RESERVED6[40];
__IO uint32_t REQ_ACCESS;
} NVM32_TypeDef;
/*----------------------------------------------------------------------------*/
/*---------------------------------- COMBLK ----------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint32_t CONTROL;
__IO uint32_t STATUS;
__IO uint32_t INT_ENABLE;
__IO uint32_t RESERVED;
__IO uint32_t DATA8;
__IO uint32_t DATA32;
__IO uint32_t FRAME_START8;
__IO uint32_t FRAME_START32;
} COMBLK_TypeDef;
/*----------------------------------------------------------------------------*/
/*--------------------- FPGA Fabric Interrupt Controller ---------------------*/
/*----------------------------------------------------------------------------*/
/*
* Please refer to the SmartFusion2 Interrupt Controller User's Guide for a
* description of the following registers.
* The registers defined below can be accessed using INTERRUPT_CTRL as follows:
* uint32_t reason0;
* INTERRUPT_CTRL->INTERRUPT_MODE = 0;
* reason0 = INTERRUPT_CTRL->INTERRUPT_REASON0;
*/
typedef struct
{
__IO uint32_t INTERRUPT_ENABLE0;
__IO uint32_t INTERRUPT_ENABLE1;
__IO uint32_t INTERRUPT_REASON0;
__IO uint32_t INTERRUPT_REASON1;
__IO uint32_t INTERRUPT_MODE;
} INTERRUPT_CTRL_TypeDef;
/*
* Please refer to the SmartFusion2 Interrupt Controller User's Guide for a
* description of the following register bits.
* The register bits defined below can be accessed using INTERRUPT_CTRL_BITBAND
* as follows:
* setting/clearing a bit:
* INTERRUPT_CTRL_BITBAND->MAC_INT_ENBL = 1;
* INTERRUPT_CTRL_BITBAND->PDMAINTERRUPT_ENBL = 0;
* reading a bit value:
* uint32_t timer1_interrupt;
* timer1_interrupt = INTERRUPT_CTRL_BITBAND->TIMER1_INTR_STATUS;
*/
typedef struct
{
/*
* INTERRUPT_ENABLE0 register bitband definitions.
*/
__IO uint32_t SPIINT0_ENBL;
__IO uint32_t SPIINT1_ENBL;
__IO uint32_t I2C_INT0_ENBL;
__IO uint32_t I2C_INT1_ENBL;
__IO uint32_t MMUART0_INTR_ENBL;
__IO uint32_t MMUART1_INTR_ENBL;
__IO uint32_t MAC_INT_ENBL;
__IO uint32_t USB_MC_INT_ENBL;
__IO uint32_t PDMAINTERRUPT_ENBL;
__IO uint32_t HPD_XFR_CMP_INT_ENBL;
__IO uint32_t TIMER1_INTR_ENBL;
__IO uint32_t TIMER2_INTR_ENBL;
__IO uint32_t CAN_INTR_ENBL;
__IO uint32_t RTC_WAKEUP_INTR_ENBL;
__IO uint32_t WDOGWAKEUPINT_ENBL;
__IO uint32_t MSSDDR_PLL_LOCKLOST_INT_ENBL;
__IO uint32_t ENVM_INT0_ENBL;
__IO uint32_t ENVM_INT1_ENBL;
__IO uint32_t I2C_SMBALERT0_ENBL;
__IO uint32_t I2C_SMBSUS0_ENBL;
__IO uint32_t I2C_SMBALERT1_ENBL;
__IO uint32_t I2C_SMBSUS1_ENBL;
__IO uint32_t HPD_XFR_ERR_INT_ENBL;
__IO uint32_t MSSDDR_PLL_LOCK_INT_ENBL;
__IO uint32_t SW_ERRORINTERRUPT_ENBL;
__IO uint32_t DDRB_INTR_ENBL;
__IO uint32_t ECCINTR_ENBL;
__IO uint32_t CACHE_ERRINTR_ENBL;
__IO uint32_t SOFTINTERRUPT_ENBL;
__IO uint32_t COMBLK_INTR_ENBL;
__IO uint32_t USB_DMA_INT_ENBL;
__IO uint32_t RESERVED0;
/*
* INTERRUPT_ENABLE1 register bitband definitions.
*/
__IO uint32_t RESERVED1[3];
__IO uint32_t MDDR_IO_CALIB_INT_ENBL;
__IO uint32_t RESERVED2;
__IO uint32_t FAB_PLL_LOCK_INT_ENBL;
__IO uint32_t FAB_PLL_LOCKLOST_INT_ENBL;
__IO uint32_t FIC64_INT_ENBL;
__IO uint32_t RESERVED3[24];
/*
* INTERRUPT_REASON0 register bitband definitions.
*/
__IO uint32_t SPIINT0_STATUS;
__IO uint32_t SPIINT1_STATUS;
__IO uint32_t I2C_INT0_STATUS;
__IO uint32_t I2C_INT1_STATUS;
__IO uint32_t MMUART0_INTR_STATUS;
__IO uint32_t MMUART1_INTR_STATUS;
__IO uint32_t MAC_INT_STATUS;
__IO uint32_t USB_MC_INT_STATUS;
__IO uint32_t PDMAINTERRUPT_STATUS;
__IO uint32_t HPD_XFR_CMP_INT_STATUS;
__IO uint32_t TIMER1_INTR_STATUS;
__IO uint32_t TIMER2_INTR_STATUS;
__IO uint32_t CAN_INTR_STATUS;
__IO uint32_t RTC_WAKEUP_INTR_STATUS;
__IO uint32_t WDOGWAKEUPINT_STATUS;
__IO uint32_t MSSDDR_PLL_LOCKLOST_INT_STATUS;
__IO uint32_t ENVM_INT0_STATUS;
__IO uint32_t ENVM_INT1_STATUS;
__IO uint32_t I2C_SMBALERT0_STATUS;
__IO uint32_t I2C_SMBSUS0_STATUS;
__IO uint32_t I2C_SMBALERT1_STATUS;
__IO uint32_t I2C_SMBSUS1_STATUS;
__IO uint32_t HPD_XFR_ERR_INT_STATUS;
__IO uint32_t MSSDDR_PLL_LOCK_INT_STATUS;
__IO uint32_t SW_ERRORINTERRUPT_STATUS;
__IO uint32_t DDRB_INTR_STATUS;
__IO uint32_t ECCINTR_STATUS;
__IO uint32_t CACHE_ERRINTR_STATUS;
__IO uint32_t SOFTINTERRUPT_STATUS;
__IO uint32_t COMBLK_INTR_STATUS;
__IO uint32_t USB_DMA_INT_STATUS;
__IO uint32_t RESERVED4;
/*
* INTERRUPT_REASON1 register bitband definitions.
*/
__IO uint32_t RESERVED5[3];
__IO uint32_t MDDR_IO_CALIB_INT_STATUS;
__IO uint32_t RESERVED6;
__IO uint32_t FAB_PLL_LOCK_INT_STATUS;
__IO uint32_t FAB_PLL_LOCKLOST_INT_STATUS;
__IO uint32_t FIC64_INT_STATUS;
__IO uint32_t RESERVED7[24];
/*
* INTERRUPT_MODE register bitband definitions.
*/
__IO uint32_t SELECT_MODE;
__IO uint32_t RESERVED8[31];
} INTERRUPT_CTRL_BitBand_TypeDef;
/*----------------------------------------------------------------------------*/
/*------------------------ DDR Controller APB Registers ----------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
/*--------------------------------------------------------------------------
* DDR Controller registers.
* All registers are 16-bit wide unless mentioned beside the definition.
*/
struct
{
__IO uint32_t DYN_SOFT_RESET_CR;
__IO uint32_t RESERVED0;
__IO uint32_t DYN_REFRESH_1_CR;
__IO uint32_t DYN_REFRESH_2_CR;
__IO uint32_t DYN_POWERDOWN_CR;
__IO uint32_t DYN_DEBUG_CR;
__IO uint32_t MODE_CR;
__IO uint32_t ADDR_MAP_BANK_CR;
__IO uint32_t ECC_DATA_MASK_CR;
__IO uint32_t ADDR_MAP_COL_1_CR;
__IO uint32_t ADDR_MAP_COL_2_CR;
__IO uint32_t ADDR_MAP_ROW_1_CR;
__IO uint32_t ADDR_MAP_ROW_2_CR;
__IO uint32_t INIT_1_CR;
__IO uint32_t CKE_RSTN_CYCLES_CR[2]; /* 0:27 bits are valid */
__IO uint32_t INIT_MR_CR;
__IO uint32_t INIT_EMR_CR;
__IO uint32_t INIT_EMR2_CR;
__IO uint32_t INIT_EMR3_CR;
__IO uint32_t DRAM_BANK_TIMING_PARAM_CR;
__IO uint32_t DRAM_RD_WR_LATENCY_CR;
__IO uint32_t DRAM_RD_WR_PRE_CR;
__IO uint32_t DRAM_MR_TIMING_PARAM_CR;
__IO uint32_t DRAM_RAS_TIMING_CR;
__IO uint32_t DRAM_RD_WR_TRNARND_TIME_CR;
__IO uint32_t DRAM_T_PD_CR;
__IO uint32_t DRAM_BANK_ACT_TIMING_CR;
__IO uint32_t ODT_PARAM_1_CR;
__IO uint32_t ODT_PARAM_2_CR;
__IO uint32_t ADDR_MAP_COL_3_CR;
__IO uint32_t MODE_REG_RD_WR_CR;
__IO uint32_t MODE_REG_DATA_CR;
__IO uint32_t PWR_SAVE_1_CR;
__IO uint32_t PWR_SAVE_2_CR;
__IO uint32_t ZQ_LONG_TIME_CR;
__IO uint32_t ZQ_SHORT_TIME_CR;
__IO uint32_t ZQ_SHORT_INT_REFRESH_MARGIN_CR[2];
__IO uint32_t PERF_PARAM_1_CR;
__IO uint32_t HPR_QUEUE_PARAM_CR[2];
__IO uint32_t LPR_QUEUE_PARAM_CR[2];
__IO uint32_t WR_QUEUE_PARAM_CR;
__IO uint32_t PERF_PARAM_2_CR;
__IO uint32_t PERF_PARAM_3_CR;
__IO uint32_t DFI_RDDATA_EN_CR;
__IO uint32_t DFI_MIN_CTRLUPD_TIMING_CR;
__IO uint32_t DFI_MAX_CTRLUPD_TIMING_CR;
__IO uint32_t DFI_WR_LVL_CONTROL_CR[2];
__IO uint32_t DFI_RD_LVL_CONTROL_CR[2];
__IO uint32_t DFI_CTRLUPD_TIME_INTERVAL_CR;
__IO uint32_t DYN_SOFT_RESET_CR2;
__IO uint32_t AXI_FABRIC_PRI_ID_CR;
__I uint32_t DDRC_SR;
__I uint32_t SINGLE_ERR_CNT_SR;
__I uint32_t DOUBLE_ERR_CNT_SR;
__I uint32_t LUE_SYNDROME_SR[5]; /* LUE : Last Uncorrected Error */
__I uint32_t LUE_ADDRESS_SR[2];
__I uint32_t LCE_SYNDROME_SR[5]; /* LCE : Last Corrected Error */
__I uint32_t LCE_ADDRESS_SR[2];
__I uint32_t LCB_NUMBER_SR; /* LCB : Last Corrected Bit */
__I uint32_t LCB_MASK_SR[4];
__I uint32_t ECC_INT_SR;
__O uint32_t ECC_INT_CLR_REG;
__I uint32_t ECC_OUTPUT_DATA_SR;
__IO uint32_t RESERVED1[46];
} ddrc;
/*--------------------------------------------------------------------------
* DDR PHY configuration registers
*/
struct
{
__IO uint32_t DYN_BIST_TEST_CR;
__IO uint32_t DYN_BIST_TEST_ERRCLR_CR[3];
__IO uint32_t BIST_TEST_SHIFT_PATTERN_CR[3];
__IO uint32_t LOOPBACK_TEST_CR;
__IO uint32_t BOARD_LOOPBACK_CR;
__IO uint32_t CTRL_SLAVE_RATIO_CR;
__IO uint32_t CTRL_SLAVE_FORCE_CR;
__IO uint32_t CTRL_SLAVE_DELAY_CR;
__IO uint32_t DATA_SLICE_IN_USE_CR;
__IO uint32_t LVL_NUM_OF_DQ0_CR;
__IO uint32_t DQ_OFFSET_CR[3];
__IO uint32_t DIS_CALIB_RST_CR;
__IO uint32_t DLL_LOCK_DIFF_CR;
__IO uint32_t FIFO_WE_IN_DELAY_CR[3];
__IO uint32_t FIFO_WE_IN_FORCE_CR;
__IO uint32_t FIFO_WE_SLAVE_RATIO_CR[4];
__IO uint32_t GATELVL_INIT_MODE_CR;
__IO uint32_t GATELVL_INIT_RATIO_CR[4];
__IO uint32_t LOCAL_ODT_CR;
__IO uint32_t INVERT_CLKOUT_CR;
__IO uint32_t RD_DQS_SLAVE_DELAY_CR[3];
__IO uint32_t RD_DQS_SLAVE_FORCE_CR;
__IO uint32_t RD_DQS_SLAVE_RATIO_CR[4];
__IO uint32_t WR_DQS_SLAVE_DELAY_CR[3];
__IO uint32_t WR_DQS_SLAVE_FORCE_CR;
__IO uint32_t WR_DQS_SLAVE_RATIO_CR[4];
__IO uint32_t WR_DATA_SLAVE_DELAY_CR[3];
__IO uint32_t WR_DATA_SLAVE_FORCE_CR;
__IO uint32_t WR_DATA_SLAVE_RATIO_CR[4];
__IO uint32_t WRLVL_INIT_MODE_CR;
__IO uint32_t WRLVL_INIT_RATIO_CR[4];
__IO uint32_t WR_RD_RL_CR;
__IO uint32_t RDC_FIFO_RST_ERRCNTCLR_CR;
__IO uint32_t RDC_WE_TO_RE_DELAY_CR;
__IO uint32_t USE_FIXED_RE_CR;
__IO uint32_t USE_RANK0_DELAYS_CR;
__IO uint32_t USE_LVL_TRNG_LEVEL_CR;
__IO uint32_t CONFIG_CR;
__IO uint32_t RD_WR_GATE_LVL_CR;
__IO uint32_t DYN_RESET_CR;
/*----------------------------------------------------------------------
* DDR PHY status registers
*/
__I uint32_t LEVELLING_FAILURE_SR;
__I uint32_t BIST_ERROR_SR[3];
__I uint32_t WRLVL_DQS_RATIO_SR[4];
__I uint32_t WRLVL_DQ_RATIO_SR[4];
__I uint32_t RDLVL_DQS_RATIO_SR[4];
__I uint32_t FIFO_SR[4];
__I uint32_t MASTER_DLL_SR;
__I uint32_t DLL_SLAVE_VALUE_SR[2];
__I uint32_t STATUS_OF_IN_DELAY_VAL_SR[2];
__I uint32_t STATUS_OF_OUT_DELAY_VAL_SR[2];
__I uint32_t DLL_LOCK_AND_SLAVE_VAL_SR;
__I uint32_t CTRL_OUTPUT_FILTER_SR;
__I uint32_t CTRL_OF_OUTPUT_DELAY_SR;
__I uint32_t RD_DQS_SLAVE_DLL_VAL_SR[3];
__I uint32_t WR_DATA_SLAVE_DLL_VAL_SR[3];
__I uint32_t FIFO_WE_SLAVE_DLL_VAL_SR[3];
__I uint32_t WR_DQS_SLAVE_DLL_VAL_SR[3];
__I uint32_t CTRL_SLAVE_DLL_VAL_SR;
__IO uint32_t RESERVED2[13];
} phy;
/*--------------------------------------------------------------------------
* FIC-64 registers
* These registers are 16-bit wide and 32-bit aligned.
*/
struct
{
__IO uint32_t NB_ADDR_CR;
__IO uint32_t NBRWB_SIZE_CR;
__IO uint32_t WB_TIMEOUT_CR;
__IO uint32_t HPD_SW_RW_EN_CR;
__IO uint32_t HPD_SW_RW_INVAL_CR;
__IO uint32_t SW_WR_ERCLR_CR;
__IO uint32_t ERR_INT_ENABLE_CR;
__IO uint32_t NUM_AHB_MASTERS_CR;
__I uint32_t HPB_ERR_ADDR_SR[2];
__I uint32_t SW_ERR_ADDR_SR[2];
__I uint32_t HPD_SW_WRB_EMPTY_SR;
__I uint32_t SW_HPB_LOCKOUT_SR;
__I uint32_t SW_HPD_WERR_SR;
uint32_t RESERVED0;
__IO uint32_t LOCK_TIMEOUTVAL_CR[2];
__IO uint32_t LOCK_TIMEOUT_EN_CR;
uint32_t RESERVED1[5];
__IO uint32_t RDWR_ERR_SR;
} fic;
} DDRCore_TypeDef;
/*----------------------------------------------------------------------------*/
/*--------------------- MDDR APB Configuration Registers ---------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
/*--------------------------------------------------------------------------
* MDDR core configuration registers.
* These registers are to be accessed as:
* MDDR->core.fic.<regname> = <value>;
* MDDR->core.phy.<regname> = <value>;
* MDDR->core.ddrc.<regname> = <value>;
*/
DDRCore_TypeDef core;
} MDDR_TypeDef;
/*----------------------------------------------------------------------------*/
/*--------------------- FDDR APB Configuration Registers ---------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
/*--------------------------------------------------------------------------
* FDDR core configuration registers. These are same as corresponding
* MDDR registers.
* These registers are to be accessed as:
* FDDR->core.fic.<regname> = <value>;
* FDDR->core.phy.<regname> = <value>;
* FDDR->core.ddrc.<regname> = <value>;
*/
DDRCore_TypeDef core;
__IO uint32_t RESERVED[39];
/*--------------------------------------------------------------------------
* FDDR system registers
* These registers are to be accessed as:
* FDDR->sysreg.PLL_CONFIG_LOW_2 = 0x04u;
*/
struct
{
__IO uint32_t PLL_CONFIG_LOW_1;
__IO uint32_t PLL_CONFIG_LOW_2;
__IO uint32_t PLL_CONFIG_HIGH;
__IO uint32_t FACC_CLK_EN;
__IO uint32_t FACC_MUX_CONFIG;
__IO uint32_t FACC_DIVISOR_RATIO;
__IO uint32_t PLL_DELAY_LINE_SEL;
__IO uint32_t SOFT_RESET;
__IO uint32_t IO_CALIB;
__IO uint32_t INTERRUPT_ENABLE;
__IO uint32_t AXI_AHB_MODE_SEL;
__IO uint32_t PHY_SELF_REF_EN;
__IO uint32_t FAB_PLL_CLK_SR;
__IO uint32_t FPLL_CLK_SR;
__IO uint32_t CLK_CALIB_STATUS;
__IO uint32_t INTERRUPT_SR;
__IO uint32_t CLK_CALIB_CONFIG;
__IO uint32_t IO_CALIB_SR;
__IO uint32_t FATC_RESET;
} sysreg;
} FDDR_TypeDef;
/*----------------------------------------------------------------------------*/
/*------------------------------ SERDES Interface ----------------------------*/
/*----------------------------------------------------------------------------*/
/*------------------------------------------------------------------------------
AXI window
*/
typedef struct
{
__IO uint32_t base;
__IO uint32_t size;
__IO uint32_t window_lsb;
__IO uint32_t window_msb;
} axi_window_TypeDef;
/*------------------------------------------------------------------------------
PCI Express Bridge Core registers.
This data structure is used to access to the registers of the PCI Express
Bridge Core.
*/
typedef struct
{
/*======================= Information registers ======================*/
/**
Information register: vendor_id & device_id
bits [15:0] vendor_id
bits [31:16] device_id
*/
/* 0x000 */
__IO uint32_t VID_DEVID;
/**
PCI Express Control & Status Register: cfg_prmscr
*/
/* 0x004 */
__IO uint32_t CFG_PRMSCR;
/**
Information register: class_code
*/
/* 0x008 */
__IO uint32_t CLASS_CODE;
__IO uint32_t RESERVED0;
/**
Bridge Configuration Register: bar0
*/
/* 0x010 */
__IO uint32_t BAR0;
/**
Bridge Configuration Register: bar1
*/
/* 0x014 */
__IO uint32_t BAR1;
/**
Bridge Configuration Register: bar2
*/
/* 0x018 */
__IO uint32_t BAR2;
/**
Bridge Configuration Register: bar3
*/
/* 0x01C */
__IO uint32_t BAR3;
/**
Bridge Configuration Register: bar4
*/
/* 0x020 */
__IO uint32_t BAR4;
/**
Bridge Configuration Register: bar5
*/
/* 0x024 */
__IO uint32_t BAR5;
__IO uint32_t RESERVED1;
/**
Information register: subsystem_id
*/
/* 0x02C */
__IO uint32_t SUBSYSTEM_ID;
/**
PCI Express Control & Status Register: pcie_devscr
*/
/* 0x030 */
__IO uint32_t PCIE_DEVSCR;
/**
PCI Express Control & Status Register: pcie_linkscr
*/
/* 0x034 */
__IO uint32_t PCIE_LINKSCR;
/**
Bridge Configuration Register: tc_vc_mapping
*/
/* 0x038 */
__IO uint32_t TC_VC_MAPPING;
/**
Information register: captured_bus_device_nb
*/
/* 0x03C */
__IO uint32_t CAPTURED_BUS_DEVICE_NB;
/**
Endpoint Interrupt register: msi_ctrl_status
*/
/* 0x040 */
__IO uint32_t MSI_CTRL_STATUS;
/**
Power Management register: ltssm
*/
/* 0x044 */
__IO uint32_t LTSSM;
/**
Power Management register: power_mgt_capability
*/
/* 0x048 */
__IO uint32_t POWER_MGT_CAPABILITY;
/**
PCI Express Control & Status Register: cfg_pmscr
*/
/* 0x04C */
__IO uint32_t CFG_PMSCR;
/**
Bridge Configuration Register: aer_ecrc_capability
*/
/* 0x050 */
__IO uint32_t AER_ECRC_CAPABILITY;
/**
Bridge Configuration Register: vc1_capability
*/
/* 0x054 */
__IO uint32_t VC1_CAPABILITY;
/**
Bridge Configuration Register: max_payload_size
*/
/* 0x058 */
__IO uint32_t MAX_PAYLOAD_SIZE;
/**
Bridge Configuration Register: clkreq
*/
/* 0x05C */
__IO uint32_t CLKREQ;
/**
Power Management register: aspm_l0s_capability
*/
/* 0x060 */
__IO uint32_t ASPM_L0S_CAPABILITY;
/**
Power Management register: aspm_l1_capability
*/
/* 0x064 */
__IO uint32_t ASPM_L1_CAPABILITY;
/**
Power Management register: timeout_completion
*/
/* 0x068 */
__IO uint32_t TIMEOUT_COMPLETION;
__IO uint32_t RESERVED2;
/**
Power Management register: pm_data_scale
*/
/* 0x070 */
__IO uint32_t PM_DATA_SCALE[4];
/**
Endpoint Interrupt register: msi
*/
/* 0x080 */
__IO uint32_t MSI[8];
/**
Bridge Configuration Register: error_counter
*/
/* 0x0A0 */
__IO uint32_t ERROR_COUNTER[4];
/**
Bridge Configuration Register: credit_allocation
*/
/* 0x0B0 */
__IO uint32_t CREDIT_ALLOCATION[4];
/**
Address Mapping register: axi_slave_window
*/
/* 0x0C0 */
axi_window_TypeDef AXI_SLAVE_WINDOW[4];
/**
Address Mapping register: axi_master_window
*/
/* 0x100 */
axi_window_TypeDef AXI_MASTER_WINDOW[4];
/**
Rootport Interrupt register: imask
*/
/* 0x140 */
__IO uint32_t IMASK;
/**
Rootport Interrupt register: istatus
*/
/* 0x144 */
__IO uint32_t ISTATUS;
/**
Rootport Interrupt register: icmd
*/
/* 0x148 */
__IO uint32_t ICMD;
/**
Rootport Interrupt register: irstatus
*/
/* 0x14C */
__IO uint32_t IRSTATUS;
/**
Rootport Interrupt register: imsiaddr
*/
/* 0x150 */
__IO uint32_t IMSIADDR;
/**
PCI Express Control & Status Register: slotcap
*/
/* 0x154 */
__IO uint32_t SLOTCAP;
/**
PCI Express Control & Status Register: slotcsr
*/
/* 0x158 */
__IO uint32_t SLOTCSR;
/**
PCI Express Control & Status Register: rootcsr
*/
/* 0x15C */
__IO uint32_t ROOTCSR;
/**
Configuration Register: cfg_control
*/
/* 0x160 */
__IO uint32_t CFG_CONTROL;
/**
Configuration Register: cfg_write_data
*/
/* 0x164 */
__IO uint32_t CFG_WRITE_DATA;
/**
Configuration Register: cfg_read_data
*/
/* 0x168 */
__IO uint32_t CFG_READ_DATA;
/**
Information register: info
*/
/* 0x16C */
__IO uint32_t INFO;
/**
Input/Output Control Register: io_control
*/
/* 0x170 */
__IO uint32_t IO_CONTROL;
/**
Input/Output Control Register: io_addr
*/
/* 0x174 */
__IO uint32_t IO_ADDR;
/**
Input/Output Control Register: io_write_data
*/
/* 0x178 */
__IO uint32_t IO_WRITE_DATA;
/**
Input/Output Control Register: io_read_data
*/
/* 0x17C */
__IO uint32_t IO_READ_DATA;
/**
Configuration Register: cfg_fbe
*/
/* 0x180 */
__IO uint32_t CFG_FBE;
/**
Address Mapping register: prefetch_io_window
*/
/* 0x184 */
__IO uint32_t PREFETCH_IO_WINDOW;
__IO uint32_t RESERVED4[31];
/**
Bridge Configuration Register: pcie_config
*/
/* 0x204 */
__IO uint32_t PCIE_CONFIG;
__IO uint32_t RESERVED5[10];
/**
PCI Express Control & Status Register: pcie_dev2scr
*/
/* 0x230 */
__IO uint32_t PCIE_DEV2SCR;
/**
PCI Express Control & Status Register: pcie_link2scr
*/
/* 0x234 */
__IO uint32_t PCIE_LINK2SCR;
__IO uint32_t RESERVED6[10];
/**
Power Management register: aspm_l0s_gen2 capability
*/
/* 0x260 */
__IO uint32_t ASPM_L0S_GEN2;
__IO uint32_t RESERVED7[39];
/**
Bridge Configuration Register: k_cnt_config
*/
/* 0x300 */
__IO uint32_t K_CNT_CONFIG[6];
__IO uint32_t RESERVED8[826];
} PCIE_TypeDef;
/*------------------------------------------------------------------------------
SERDESIF System Registers.
*/
typedef struct
{
__IO uint32_t SER_PLL_CONFIG_LOW;
__IO uint32_t SER_PLL_CONFIG_HIGH;
__IO uint32_t SERDESIF_SOFT_RESET;
__IO uint32_t SER_INTERRUPT_ENABLE;
__IO uint32_t CONFIG_AXI_AHB_BRIDGE;
__IO uint32_t CONFIG_ECC_INTR_ENABLE;
__IO uint32_t CONFIG_TEST_IN;
__IO uint32_t TEST_OUT_READ_ADDR;
__IO uint32_t CONFIG_PCIE_PM;
__IO uint32_t CONFIG_PHY_MODE_0;
__IO uint32_t CONFIG_PHY_MODE_1;
__IO uint32_t CONFIG_PHY_MODE_2;
__IO uint32_t CONFIG_PCIE_0;
__IO uint32_t CONFIG_PCIE_1;
__IO uint32_t CONFIG_PCIE_2;
__IO uint32_t CONFIG_PCIE_3;
__IO uint32_t CONFIG_BAR_SIZE_0_1;
__IO uint32_t CONFIG_BAR_SIZE_2_3;
__IO uint32_t CONFIG_BAR_SIZE_3_4;
__IO uint32_t SER_CLK_STATUS;
__IO uint32_t SER_CLK_CALIB_STATUS;
__IO uint32_t TEST_OUT_READ_DATA;
__IO uint32_t SER_INTERRUPT;
__IO uint32_t SERDESIF_INTR_STATUS;
__IO uint32_t SER_CLK_CALIB_CONFIG;
__IO uint32_t REFCLK_SEL;
__IO uint32_t PCLK_SEL;
__IO uint32_t EPCS_RSTN_SEL;
__IO uint32_t CHIP_ENABLES;
__IO uint32_t SERDES_TEST_OUT;
__IO uint32_t SERDES_FATC_RESET;
__IO uint32_t RC_OSC_SPLL_REFCLK_SEL;
__IO uint32_t SPREAD_SPECTRUM_CLK;
__IO uint32_t CONF_AXI_MSTR_WNDW_0;
__IO uint32_t CONF_AXI_MSTR_WNDW_1;
__IO uint32_t CONF_AXI_MSTR_WNDW_2;
__IO uint32_t CONF_AXI_MSTR_WNDW_3;
__IO uint32_t CONF_AXI_SLV_WNDW_0;
__IO uint32_t CONF_AXI_SLV_WNDW_1;
__IO uint32_t CONF_AXI_SLV_WNDW_2;
__IO uint32_t CONF_AXI_SLV_WNDW_3;
__IO uint32_t DESKEW_CONFIG;
__IO uint32_t DEBUG_MODE_KEY;
__IO uint32_t RESERVED0;
/*
* The following registers are only available on the M2S090.
*/
__IO uint32_t IDDQ;
__IO uint32_t ADVCONFIG;
__IO uint32_t ADVSTATUS;
__IO uint32_t ECC_ERR_INJECT;
__IO uint32_t RESERVED2;
__IO uint32_t RESERVED3;
__IO uint32_t ENHANCEMENT;
__IO uint32_t RESERVED4;
__IO uint32_t RESERVED5;
__IO uint32_t RESERVED6;
__IO uint32_t RESERVED7;
__IO uint32_t RESERVED8;
__IO uint32_t RESERVED9;
__IO uint32_t RESERVED10;
__IO uint32_t RESERVED11;
__IO uint32_t RESERVED12;
__IO uint32_t RESERVED13;
__IO uint32_t RESERVED14;
__IO uint32_t RESERVED15;
__IO uint32_t RESERVED16;
__IO uint32_t RESERVED17;
__IO uint32_t RESERVED18;
__IO uint32_t RESERVED19;
__IO uint32_t RESERVED20;
__IO uint32_t CONFIG2_AXI_AHB_BRIDGE;
__IO uint32_t CONFIG2_ECC_INTR_ENABLE;
__IO uint32_t CONFIG2_TEST_IN;
__IO uint32_t TEST2_OUT_READ_ADDR;
__IO uint32_t CONFIG2_PCIE_PM;
__IO uint32_t RESERVED21;
__IO uint32_t RESERVED22;
__IO uint32_t RESERVED23;
__IO uint32_t CONFIG2_PCIE_0;
__IO uint32_t CONFIG2_PCIE_1;
__IO uint32_t CONFIG2_PCIE_2;
__IO uint32_t CONFIG2_PCIE_3;
__IO uint32_t CONFIG2_BAR_SIZE_0_1;
__IO uint32_t CONFIG2_BAR_SIZE_2_3;
__IO uint32_t CONFIG2_BAR_SIZE_3_4;
__IO uint32_t RESERVED24;
__IO uint32_t RESERVED25;
__IO uint32_t TEST2_OUT_READ_DATA;
__IO uint32_t RESERVED26;
__IO uint32_t SERDESIF2_INTR_STATUS;
__IO uint32_t RESERVED27;
__IO uint32_t RESERVED28;
__IO uint32_t RESERVED29;
__IO uint32_t RESERVED30;
__IO uint32_t RESERVED31;
__IO uint32_t RESERVED32;
__IO uint32_t RESERVED33;
__IO uint32_t RESERVED34;
__IO uint32_t RESERVED35;
__IO uint32_t CONF2_AXI_MSTR_WNDW_0;
__IO uint32_t CONF2_AXI_MSTR_WNDW_1;
__IO uint32_t CONF2_AXI_MSTR_WNDW_2;
__IO uint32_t CONF2_AXI_MSTR_WNDW_3;
__IO uint32_t CONF2_AXI_SLV_WNDW_0;
__IO uint32_t CONF2_AXI_SLV_WNDW_1;
__IO uint32_t CONF2_AXI_SLV_WNDW_2;
__IO uint32_t CONF2_AXI_SLV_WNDW_3;
__IO uint32_t RESERVED36;
__IO uint32_t RESERVED37;
__IO uint32_t RESERVED38;
__IO uint32_t RESERVED39;
__IO uint32_t ADVCONFIG2;
__IO uint32_t ADVSTATUS2;
__IO uint32_t ECC_ERR_INJECT2;
} SERDES_INTF_SYSREG_TypeDef;
/*------------------------------------------------------------------------------
SERDES PHY registers
*/
typedef struct
{
/**
Control register 0
*/
__IO uint32_t CR0;
/**
Clock count for error counter decrement
*/
__IO uint32_t ERRCNT_DEC;
/**
Error counter threshold - Rx idle detect max latency
*/
__IO uint32_t RXIDLE_MAX_ERRCNT_THR;
/**
Tx Impedance ratio
*/
__IO uint32_t IMPED_RATIO;
/**
PLL F settings and PCLK ratio
*/
__IO uint32_t PLL_F_PCLK_RATIO;
/**
PLL M & N settings
*/
__IO uint32_t PLL_M_N;
/**
250ns timer base count
*/
__IO uint32_t CNT250NS_MAX;
/**
Rx Equalization amplitude ratio
*/
__IO uint32_t RE_AMP_RATIO;
/**
Rx Equalization Cut frequency
*/
__IO uint32_t RE_CUT_RATIO;
/**
Tx Amplitude ratio
*/
__IO uint32_t TX_AMP_RATIO;
/**
Tx Post-Cursor ratio
*/
__IO uint32_t TX_PST_RATIO;
/**
Tx Pre-Cursor ratio
*/
__IO uint32_t TX_PRE_RATIO;
/**
End of calibration counter
*/
__IO uint32_t ENDCALIB_MAX;
/**
Calibration stability counter
*/
__IO uint32_t CALIB_STABILITY_COUNT;
/**
Power down feature
*/
__IO uint32_t POWER_DOWN;
/**
Rx offset counter
*/
__IO uint32_t RX_OFFSET_COUNT;
/**
PLL F settings and PCLK ratio (in PCIe 5 Gbps speed)
*/
__IO uint32_t PLL_F_PCLK_RATIO_5GBPS;
/**
PLL M & N sttings (in PCIe 5 Gbps spped)
*/
__IO uint32_t PLL_M_N_5GBPS;
/**
250ns timer base count (in PCIe 5 Gbps speed)
*/
__IO uint32_t CNT250NS_MAX_5GBPS;
/**
reserved
*/
__IO uint32_t RESERVED;
/**
Tx Post-Cursor ratio with TxDeemp=0, Full swing
*/
__IO uint32_t TX_PST_RATIO_DEEMP0_FULL;
/**
Tx Pre-Cursor ratio TxDeemp=0, full swing
*/
__IO uint32_t TX_PRE_RATIO_DEEMP0_FULL;
/**
Tx Post-Cursor ratio with TxDeemp=1, Full swing
*/
__IO uint32_t TX_PST_RATIO_DEEMP1_FULL;
/**
Tx Pre-Cursor ratio TxDeemp=1, full swing
*/
__IO uint32_t TX_PRE_RATIO_DEEMP1_FULL;
/**
Tx Amplitude ratio TxMargin=0, full swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN0_FULL;
/**
Tx Amplitude ratio TxMargin=1, full swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN1_FULL;
/**
Tx Amplitude ratio TxMargin=2, full swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN2_FULL;
/**
Tx Amplitude ratio TxMargin=3, full swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN3_FULL;
/**
Tx Amplitude ratio TxMargin=4, full swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN4_FULL;
/**
Tx Amplitude ratio TxMargin=5, full swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN5_FULL;
/**
Tx Amplitude ratio TxMargin=6, full swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN6_FULL;
/**
Tx Amplitude ratio TxMargin=7, full swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN7_FULL;
/**
Rx Equalization amplitude ratio TxDeemp=0
*/
__IO uint32_t RE_AMP_RATIO_DEEMP0;
/**
Rx Equalization Cut frequency TxDeemp=0
*/
__IO uint32_t RE_CUT_RATIO_DEEMP0;
/**
Rx Equalization amplitude ratio TxDeemp=1
*/
__IO uint32_t RE_AMP_RATIO_DEEMP1;
/**
Rx Equalization Cut frequency TxDeemp=1
*/
__IO uint32_t RE_CUT_RATIO_DEEMP1;
/**
Tx Post-Cursor ratio with TxDeemp=0, Half swing
*/
__IO uint32_t TX_PST_RATIO_DEEMP0_HALF;
/**
Tx Pre-Cursor ratio TxDeemp=0, Half swing
*/
__IO uint32_t TX_PRE_RATIO_DEEMP0_HALF;
/**
Tx Post-Cursor ratio with TxDeemp=1, Half swing
*/
__IO uint32_t TX_PST_RATIO_DEEMP1_HALF;
/**
Tx Pre-Cursor ratio TxDeemp=1, Half swing
*/
__IO uint32_t TX_PRE_RATIO_DEEMP1_HALF;
/**
Tx Amplitude ratio TxMargin=0, Half swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN0_HALF;
/**
Tx Amplitude ratio TxMargin=1, Half swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN1_HALF;
/**
Tx Amplitude ratio TxMargin=2, Half swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN2_HALF;
/**
Tx Amplitude ratio TxMargin=3, Half swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN3_HALF;
/**
Tx Amplitude ratio TxMargin=4, Half swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN4_HALF;
/**
Tx Amplitude ratio TxMargin=5, Half swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN5_HALF;
/**
Tx Amplitude ratio TxMargin=6, Half swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN6_HALF;
/**
Tx Amplitude ratio TxMargin=7, Half swing
*/
__IO uint32_t TX_AMP_RATIO_MARGIN7_HALF;
/**
PMA status
*/
__IO uint32_t PMA_STATUS;
/**
Tx sweep center (RO)
*/
__IO uint32_t TX_SWEEP_CENTER;
/**
Rx seep center (RO)
*/
__IO uint32_t RX_SWEEP_CENTER;
/**
Rx Equalization sweep center (RO)
*/
__IO uint32_t RE_SWEEP_CENTER;
/**
Receiver Shift Loader parameter 0 (RO)
*/
__IO uint32_t ATXDRR_7_0;
/**
Receiver Shift Loader parameter 1 (RO)
*/
__IO uint32_t ATXDRR_14_8;
/**
Transmitter P Shift Loader parameter0-0
*/
__IO uint32_t ATXDRP_DYN_7_0;
/**
Transmitter P Shift Loader parameter0-1
*/
__IO uint32_t ATXDRP_DYN_15_8;
/**
Transmitter P Shift Loader parameter0-2
*/
__IO uint32_t ATXDRP_DYN_20_16;
/**
Transmitter A Shift Loader parameter0-0
*/
__IO uint32_t ATXDRA_DYN_7_0;
/**
Transmitter A Shift Loader parameter0-1
*/
__IO uint32_t ATXDRA_DYN_15_8;
/**
Transmitter A Shift Loader parameter0-2
*/
__IO uint32_t ATXDRA_DYN_20_16;
/**
Transmitter T Shift Loader parameter0-0
*/
__IO uint32_t ATXDRT_DYN_7_0;
/**
Transmitter T Shift Loader parameter0-1
*/
__IO uint32_t ATXDRT_DYN_15_8;
/**
Transmitter T Shift Loader parameter0-2
*/
__IO uint32_t ATXDRT_DYN_20_16;
/**
Transmitter P Shift Loader parameter 1-0 (RO)
*/
__IO uint32_t ATXDRP_EI1_7_0;
/**
Transmitter P Shift Loader parameter 1-1 (RO)
*/
__IO uint32_t ATXDRP_EI1_15_8;
/**
Transmitter P Shift Loader parameter 1-2 (RO)
*/
__IO uint32_t ATXDRP_EI1_20_16;
/**
Transmitter A Shift Loader parameter 1-0 (RO)
*/
__IO uint32_t ATXDRA_EI1_7_0;
/**
Transmitter A Shift Loader parameter 1-1 (RO)
*/
__IO uint32_t ATXDRA_EI1_15_8;
/**
Transmitter A Shift Loader parameter 1-2 (RO)
*/
__IO uint32_t ATXDRA_EI1_20_16;
/**
Transmitter T Shift Loader parameter 1-0 (RO)
*/
__IO uint32_t ATXDRT_EI1_7_0;
/**
Transmitter T Shift Loader parameter 1-1 (RO)
*/
__IO uint32_t ATXDRT_EI1_15_8;
/**
Transmitter T Shift Loader parameter 1-2 (RO)
*/
__IO uint32_t ATXDRT_EI1_20_16;
/**
Transmitter P shift Loader parameter 2-0 (RO)
*/
__IO uint32_t ATXDRP_EI2_7_0;
/**
Transmitter P shift Loader parameter 2-1 (RO)
*/
__IO uint32_t ATXDRP_EI2_15_8;
/**
Transmitter P shift Loader parameter 2-2 (RO)
*/
__IO uint32_t ATXDRP_EI2_20_16;
/**
Transmitter A Shift parametr 2-0 (RO)
*/
__IO uint32_t ATXDRA_EI2_7_0;
/**
Transmitter A Shift parametr 2-1 (RO)
*/
__IO uint32_t ATXDRA_EI2_15_8;
/**
Transmitter A Shift parametr 2-2 (RO)
*/
__IO uint32_t ATXDRA_EI2_20_16;
/**
Transmitter T Shift parametr 2-0 (RO)
*/
__IO uint32_t ATXDRT_EI2_7_0;
/**
Transmitter T Shift parametr 2-1 (RO)
*/
__IO uint32_t ATXDRT_EI2_15_8;
/**
Transmitter T Shift parametr 2-2 (RO)
*/
__IO uint32_t ATXDRT_EI2_20_16;
/**
Override calibration register (RW)
*/
__IO uint32_t OVERRIDE_CALIB;
/**
Force Receiver Shift Loader parameter 0 (RW)
*/
__IO uint32_t FORCE_ATXDRR_7_0;
/**
Force Receiver Shift Loader parameter 1 (RW)
*/
__IO uint32_t FORCE_ATXDRR_15_8;
/**
Force Receiver Shift Loader parameter 2 (RW)
*/
__IO uint32_t FORCE_ATXDRR_20_16;
/**
Force Transmitter P Shift Loader parameter 0 (RW)
*/
__IO uint32_t FORCE_ATXDRP_7_0;
/**
Force Transmitter P Shift Loader parameter 1 (RW)
*/
__IO uint32_t FORCE_ATXDRP_15_8;
/**
Force Transmitter P Shift Loader parameter 2 (RW)
*/
__IO uint32_t FORCE_ATXDRP_20_16;
/**
Force Transmitter A Shift Loader parameter 0 (RW)
*/
__IO uint32_t FORCE_ATXDRA_7_0;
/**
Force Transmitter A Shift Loader parameter 1 (RW)
*/
__IO uint32_t FORCE_ATXDRA_15_8;
/**
Force Transmitter A Shift Loader parameter 2 (RW)
*/
__IO uint32_t FORCE_ATXDRA_20_16;
/**
Force Transmitter T Shift parameter 0-0 (RO)
*/
__IO uint32_t FORCE_ATXDRT_7_0;
/**
Force Transmitter T Shift parameter 0-1 (RO)
*/
__IO uint32_t FORCE_ATXDRT_15_8;
/**
Force Transmitter T Shift parameter 0-2 (RO)
*/
__IO uint32_t FORCE_ATXDRT_20_16;
/**
RxD offset calibration result (RO)
*/
__IO uint32_t RXD_OFFSET_CALIB_RESULT;
/**
RxT offset calibration result (RO)
*/
__IO uint32_t RXT_OFFSET_CALIB_RESULT;
/**
Schmitt trigger calibration result (RO)
*/
__IO uint32_t SCHMITT_TRIG_CALIB_RESULT;
/**
Force RxD offset calibration settings (RW)
*/
__IO uint32_t FORCE_RXD_OFFSET_CALIB;
/**
Force RxT offset calibration settings (RW)
*/
__IO uint32_t FORCE_RXT_OFFSET_CALIB;
/**
Force Schmitt trigger calibration settings (RW)
*/
__IO uint32_t FORCE_SCHMITT_TRIG_CALIB;
/**
PRBS control register (RW)
*/
__IO uint32_t PRBS_CTRL;
/**
PRBS error counter register (RO)
*/
__IO uint32_t PRBS_ERRCNT;
/**
PHY reset override register (RW)
*/
__IO uint32_t PHY_RESET_OVERRIDE;
/**
PHY power override register (RW)
*/
__IO uint32_t PHY_POWER_OVERRIDE;
/**
Custom Pattern Byte 0 (RW)
*/
__IO uint32_t CUSTOM_PATTERN_7_0;
/**
Custom Pattern Byte 1 (RW)
*/
__IO uint32_t CUSTOM_PATTERN_15_8;
/**
Custom Pattern Byte 2 (RW)
*/
__IO uint32_t CUSTOM_PATTERN_23_16;
/**
Custom Pattern Byte 3 (RW)
*/
__IO uint32_t CUSTOM_PATTERN_31_24;
/**
Custom Pattern Byte 4 (RW)
*/
__IO uint32_t CUSTOM_PATTERN_39_32;
/**
Custom Pattern Byte 5 (RW)
*/
__IO uint32_t CUSTOM_PATTERN_47_40;
/**
Custom Pattern Byte 6 (RW)
*/
__IO uint32_t CUSTOM_PATTERN55_48;
/**
Custom Pattern Byte 7 (RW)
*/
__IO uint32_t CUSTOM_PATTERN_63_56;
/**
Custom Pattern Byte 8 (RW)
*/
__IO uint32_t CUSTOM_PATTERN_71_64;
/**
Custom Pattern Byte 9 (RW)
*/
__IO uint32_t CUSTOM_PATTERN_79_72;
/**
Custom Pattern Control (RW)
*/
__IO uint32_t CUSTOM_PATTERN_CTRL;
/**
Custom Pattern Status register (RO)
*/
__IO uint32_t CUSTOM_PATTERN_STATUS;
/**
PCS Loopback Control (RW)
*/
__IO uint32_t PCS_LOOPBBACK_CTRL;
/**
Gen1 Transmit PLL Current Charge Pump (RW)
*/
__IO uint32_t GEN1_TX_PLL_CCP;
/**
Gen1 Receive PLL Current Charge Pump (RW)
*/
__IO uint32_t GEN1_RX_PLL_CCP;
/**
Gen2 Transmit PLL Current Charge Pump (RW)
*/
__IO uint32_t GEN2_TX_PLL_CCP;
/**
Gen2 Receive PLL Current Charge Pump (RW)
*/
__IO uint32_t GEN2_RX_PLL_CCP;
/**
CDR PLL manual control
*/
__IO uint32_t CDR_PLL_MANUAL_CR;
/**
Reserved0
*/
__IO uint32_t RESERVED0[6];
/**
Update settings command register
*/
__IO uint32_t UPDATE_SETTINGS;
/**
Reserved1
*/
__IO uint32_t RESERVED1[31];
/**
PRBS first error cycle counter bits [7:0]
*/
__IO uint32_t PRBS_ERR_CYC_FIRST_7_0;
/**
PRBS first error cycle counter bits [15:8]
*/
__IO uint32_t PRBS_ERR_CYC_FIRST_15_8;
/**
PRBS first error cycle counter bits [23:16]
*/
__IO uint32_t PRBS_ERR_CYC_FIRST_23_16;
/**
PRBS first error cycle counter bits [31:24]
*/
__IO uint32_t PRBS_ERR_CYC_FIRST_31_24;
/**
PRBS first error cycle counter bits [39:32]
*/
__IO uint32_t PRBS_ERR_CYC_FIRST_39_32;
/**
PRBS first error cycle counter bits [47:40]
*/
__IO uint32_t PRBS_ERR_CYC_FIRST_47_40;
/**
PRBS first error cycle counter bits [49:48]
*/
__IO uint32_t PRBS_ERR_CYC_FIRST_49_48;
/**
Reserved2
*/
__IO uint32_t RESERVED2;
/**
PRBS last error cycle counter bits [7:0]
*/
__IO uint32_t PRBS_ERR_CYC_LAST_7_0;
/**
PRBS last error cycle counter bits [15:8]
*/
__IO uint32_t PRBS_ERR_CYC_LAST_15_8;
/**
PRBS last error cycle counter bits [23:16]
*/
__IO uint32_t PRBS_ERR_CYC_LAST_23_16;
/**
PRBS last error cycle counter bits [31:24]
*/
__IO uint32_t PRBS_ERR_CYC_LAST_31_24;
/**
PRBS last error cycle counter bits [39:32]
*/
__IO uint32_t PRBS_ERR_CYC_LAST_39_32;
/**
PRBS last error cycle counter bits [47:40]
*/
__IO uint32_t PRBS_ERR_CYC_LAST_47_40;
/**
PRBS last error cycle counter bits [49:48]
*/
__IO uint32_t PRBS_ERR_CYC_LAST_49_48;
/**
Reserved3
*/
__IO uint32_t RESERVED3[81];
} SERDES_TypeDef;
/*-------------------------------------------------------------------------*//**
The serdesif_regs_t data structure provides access to the complete set of the
SERDES Interface hardware block configuration registers. These registers are
accessed through the APB interface of the SERDES Interface hardware block.
*/
typedef struct
{
/**
PCIe core registers.
*/
PCIE_TypeDef core;
/**
SERDES macro registers.
*/
SERDES_TypeDef lane[4];
/**
SERDESIF system registers.
*/
SERDES_INTF_SYSREG_TypeDef sys_regs;
} SERDESIF_TypeDef;
/*----------------------------------------------------------------------------*/
/*------------------------------ System Registers ----------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint32_t ESRAM_CR; /*0X0 */
__IO uint32_t ESRAM_MAX_LAT_CR; /*0X4 */
__IO uint32_t DDR_CR; /*0X8 */
__IO uint32_t ENVM_CR; /*0XC */
__IO uint32_t ENVM_REMAP_BASE_CR; /*0X10 */
__IO uint32_t ENVM_REMAP_FAB_CR; /*0X14 */
__IO uint32_t CC_CR; /*0X18 */
__IO uint32_t CC_REGION_CR; /*0X1C */
__IO uint32_t CC_LOCK_BASE_ADDR_CR; /*0X20 */
__IO uint32_t CC_FLUSH_INDX_CR; /*0X24 */
__IO uint32_t DDRB_BUF_TIMER_CR; /*0X28 */
__IO uint32_t DDRB_NB_ADDR_CR; /*0X2C */
__IO uint32_t DDRB_NB_SIZE_CR; /*0X30 */
__IO uint32_t DDRB_CR; /*0X34 */
__IO uint32_t EDAC_CR; /*0X38 */
__IO uint32_t MASTER_WEIGHT0_CR; /*0X3C */
__IO uint32_t MASTER_WEIGHT1_CR; /*0X40 */
__IO uint32_t SOFT_IRQ_CR; /*0X44 */
__IO uint32_t SOFT_RST_CR; /*0X48 */
__IO uint32_t M3_CR; /*0X4C */
__IO uint32_t FAB_IF_CR; /*0X50 */
__IO uint32_t LOOPBACK_CR; /*0X54 */
__IO uint32_t GPIO_SYSRESET_SEL_CR; /*0X58 */
__IO uint32_t GPIN_SRC_SEL_CR; /*0X5C */
__IO uint32_t MDDR_CR; /*0X60 */
__IO uint32_t USB_IO_INPUT_SEL_CR; /*0X64 */
__IO uint32_t PERIPH_CLK_MUX_SEL_CR; /*0X68 */
__IO uint32_t WDOG_CR; /*0X6C */
__IO uint32_t MDDR_IO_CALIB_CR; /*0X70 */
__IO uint32_t SPARE_OUT_CR; /*0X74 */
__IO uint32_t EDAC_IRQ_ENABLE_CR; /*0X78 */
__IO uint32_t USB_CR; /*0X7C */
__IO uint32_t ESRAM_PIPELINE_CR; /*0X80 */
__IO uint32_t MSS_IRQ_ENABLE_CR; /*0X84 */
__IO uint32_t RTC_WAKEUP_CR; /*0X88 */
__IO uint32_t MAC_CR; /*0X8C */
__IO uint32_t MSSDDR_PLL_STATUS_LOW_CR; /*0X90 */
__IO uint32_t MSSDDR_PLL_STATUS_HIGH_CR; /*0X94 */
__IO uint32_t MSSDDR_FACC1_CR; /*0X98 */
__IO uint32_t MSSDDR_FACC2_CR; /*0X9C */
__IO uint32_t PLL_LOCK_EN_CR; /*0XA0 */
__IO uint32_t MSSDDR_CLK_CALIB_CR; /*0XA4 */
__IO uint32_t PLL_DELAY_LINE_SEL_CR; /*0XA8 */
__IO uint32_t MAC_STAT_CLRONRD_CR; /*0XAC */
__IO uint32_t RESET_SOURCE_CR; /*0XB0 */
__I uint32_t CC_DC_ERR_ADDR_SR; /*0XB4 */
__I uint32_t CC_IC_ERR_ADDR_SR; /*0XB8 */
__I uint32_t CC_SB_ERR_ADDR_SR; /*0XBC */
__I uint32_t CC_DECC_ERR_ADDR_SR; /*0XC0 */
__I uint32_t CC_IC_MISS_CNT_SR; /*0XC4 */
__I uint32_t CC_IC_HIT_CNT_SR; /*0XC8 */
__I uint32_t CC_DC_MISS_CNT_SR; /*0XCC */
__I uint32_t CC_DC_HIT_CNT_SR; /*0XD0 */
__I uint32_t CC_IC_TRANS_CNT_SR; /*0XD4 */
__I uint32_t CC_DC_TRANS_CNT_SR; /*0XD8 */
__I uint32_t DDRB_DS_ERR_ADR_SR; /*0XDC */
__I uint32_t DDRB_HPD_ERR_ADR_SR; /*0XE0 */
__I uint32_t DDRB_SW_ERR_ADR_SR; /*0XE4 */
__I uint32_t DDRB_BUF_EMPTY_SR; /*0XE8 */
__I uint32_t DDRB_DSBL_DN_SR; /*0XEC */
__I uint32_t ESRAM0_EDAC_CNT; /*0XF0 */
__I uint32_t ESRAM1_EDAC_CNT; /*0XF4 */
__I uint32_t CC_EDAC_CNT; /*0XF8 */
__I uint32_t MAC_EDAC_TX_CNT; /*0XFC */
__I uint32_t MAC_EDAC_RX_CNT; /*0X100 */
__I uint32_t USB_EDAC_CNT; /*0X104 */
__I uint32_t CAN_EDAC_CNT; /*0X108 */
__I uint32_t ESRAM0_EDAC_ADR; /*0X10C */
__I uint32_t ESRAM1_EDAC_ADR; /*0X110 */
__I uint32_t MAC_EDAC_RX_ADR; /*0X114 */
__I uint32_t MAC_EDAC_TX_ADR; /*0X118 */
__I uint32_t CAN_EDAC_ADR; /*0X11C */
__I uint32_t USB_EDAC_ADR; /*0X120 */
__I uint32_t MM0_1_2_SECURITY; /*0X124 */
__I uint32_t MM4_5_FIC64_SECURITY; /*0X128 */
__I uint32_t MM3_6_7_8_SECURITY; /*0X12C */
__I uint32_t MM9_SECURITY; /*0X130 */
__I uint32_t M3_SR; /*0X134 */
__I uint32_t ETM_COUNT_LOW; /*0X138 */
__I uint32_t ETM_COUNT_HIGH; /*0X13C */
__I uint32_t DEVICE_SR; /*0X140 */
__I uint32_t ENVM_PROTECT_USER; /*0X144 */
__I uint32_t ENVM_STATUS; /*0X148 */
__I uint32_t DEVICE_VERSION; /*0X14C */
__I uint32_t MSSDDR_PLL_STATUS; /*0X150 */
__I uint32_t USB_SR; /*0X154 */
__I uint32_t ENVM_SR; /*0X158 */
__I uint32_t SPARE_IN; /*0X15C */
__I uint32_t DDRB_STATUS; /*0X160 */
__I uint32_t MDDR_IO_CALIB_STATUS; /*0X164 */
__I uint32_t MSSDDR_CLK_CALIB_STATUS; /*0X168 */
__I uint32_t WDOGLOAD; /*0X16C */
__I uint32_t WDOGMVRP; /*0X170 */
__I uint32_t USERCONFIG0; /*0X174 */
__I uint32_t USERCONFIG1; /*0X178 */
__I uint32_t USERCONFIG2; /*0X17C */
__I uint32_t USERCONFIG3; /*0X180 */
__I uint32_t FAB_PROT_SIZE; /*0X184 */
__I uint32_t FAB_PROT_BASE; /*0X188 */
__I uint32_t MSS_GPIO_DEF; /*0X18C */
__IO uint32_t EDAC_SR; /*0X190 */
__IO uint32_t MSS_INTERNAL_SR; /*0X194 */
__IO uint32_t MSS_EXTERNAL_SR; /*0X198 */
__IO uint32_t WDOGTIMEOUTEVENT; /*0X19C */
__IO uint32_t CLR_MSS_COUNTERS; /*0X1A0 */
__IO uint32_t CLR_EDAC_COUNTERS; /*0X1A4 */
__IO uint32_t FLUSH_CR; /*0X1A8 */
__IO uint32_t MAC_STAT_CLR_CR; /*0X1AC */
__IO uint32_t IOMUXCELL_CONFIG[57]; /*0X1B0 */
__I uint32_t NVM_PROTECT_FACTORY; /*0X294 */
__I uint32_t DEVICE_STATUS_FIXED; /*0X298 */
__I uint32_t MBIST_ES0; /*0X29C */
__I uint32_t MBIST_ES1; /*0X2A0 */
__IO uint32_t MSDDR_PLL_STAUS_1; /*0X2A4 */
__I uint32_t REDUNDANCY_ESRAM0; /*0X2A8 */
__I uint32_t REDUNDANCY_ESRAM1; /*0X2AC */
__I uint32_t SERDESIF; /*0X2B0 */
} SYSREG_TypeDef;
#define SYSREG_ENVM0_SOFTRESET_MASK ( (uint32_t)0x01u << 0u )
#define SYSREG_ENVM1_SOFTRESET_MASK ( (uint32_t)0x01u << 1u )
#define SYSREG_ESRAM0_SOFTRESET_MASK ( (uint32_t)0x01u << 2u )
#define SYSREG_ESRAM1_SOFTRESET_MASK ( (uint32_t)0x01u << 3u )
#define SYSREG_MAC_SOFTRESET_MASK ( (uint32_t)0x01u << 4u )
#define SYSREG_PDMA_SOFTRESET_MASK ( (uint32_t)0x01u << 5u )
#define SYSREG_TIMER_SOFTRESET_MASK ( (uint32_t)0x01u << 6u )
#define SYSREG_MMUART0_SOFTRESET_MASK ( (uint32_t)0x01u << 7u )
#define SYSREG_MMUART1_SOFTRESET_MASK ( (uint32_t)0x01u << 8u )
#define SYSREG_SPI0_SOFTRESET_MASK ( (uint32_t)0x01u << 9u )
#define SYSREG_SPI1_SOFTRESET_MASK ( (uint32_t)0x01u << 10u )
#define SYSREG_I2C0_SOFTRESET_MASK ( (uint32_t)0x01u << 11u )
#define SYSREG_I2C1_SOFTRESET_MASK ( (uint32_t)0x01u << 12u )
#define SYSREG_CAN_SOFTRESET_MASK ( (uint32_t)0x01u << 13u )
#define SYSREG_USB_SOFTRESET_MASK ( (uint32_t)0x01u << 14u )
#define SYSREG_COMBLK_SOFTRESET_MASK ( (uint32_t)0x01u << 15u )
#define SYSREG_FPGA_SOFTRESET_MASK ( (uint32_t)0x01u << 16u )
#define SYSREG_HPDMA_SOFTRESET_MASK ( (uint32_t)0x01u << 17u )
#define SYSREG_FIC32_0_SOFTRESET_MASK ( (uint32_t)0x01u << 18u )
#define SYSREG_FIC32_1_SOFTRESET_MASK ( (uint32_t)0x01u << 19u )
#define SYSREG_GPIO_SOFTRESET_MASK ( (uint32_t)0x01u << 20u )
#define SYSREG_GPIO_7_0_SOFTRESET_MASK ( (uint32_t)0x01u << 21u )
#define SYSREG_GPIO_15_8_SOFTRESET_MASK ( (uint32_t)0x01u << 22u )
#define SYSREG_GPIO_23_16_SOFTRESET_MASK ( (uint32_t)0x01u << 23u )
#define SYSREG_GPIO_31_24_SOFTRESET_MASK ( (uint32_t)0x01u << 24u )
#define SYSREG_MDDR_SOFTRESET_MASK ( (uint32_t)0x01u << 25u )
#define SYSREG_FIC64_SOFTRESET_MASK ( (uint32_t)0x01u << 26u )
/*----------------------------------------------------------------------------*/
/*-------------------------- CoreSF2Config Registers -------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct {
__IO uint32_t CONFIG_DONE;
__I uint32_t INIT_DONE;
__IO uint32_t CLR_INIT_DONE;
__I uint32_t CONFIG_SR;
__IO uint32_t SOFT_RESET_CR;
__I uint32_t IP_VERSION_SR;
} CoreSF2Config_TypeDef;
/******************************************************************************/
/* Peripheral memory map */
/******************************************************************************/
#define UART0_BASE 0x40000000u
#define SPI0_BASE 0x40001000u
#define I2C0_BASE 0x40002000u
#define PDMA_BASE 0x40003000u
#define TIMER_BASE 0x40004000u
#define WATCHDOG_BASE 0x40005000u
#define H2F_IRQ_CTRL_BASE 0x40006000u
#define UART1_BASE 0x40010000u
#define SPI1_BASE 0x40011000u
#define I2C1_BASE 0x40012000u
#define GPIO_BASE 0x40013000u
#define HPDMA_BASE 0x40014000u
#define CAN_BASE 0x40015000u
#define COMBLK_BASE 0x40016000u
#define RTC_BASE 0x40017000u
#define DDR0_CFG_BASE 0x40020800u
#define DDR1_CFG_BASE 0x40021000u
#define CORE_SF2_CFG_BASE 0x40022000u
#define SERDES0_CFG_BASE 0x40028000u
#define SERDES1_CFG_BASE 0x4002C000u
#define SERDES2_CFG_BASE 0x40030000u
#define SERDES3_CFG_BASE 0x40034000u
#define SYSREG_BASE 0x40038000u
#define ETHERNET_BASE 0x40041000u
#define USB_BASE 0x40043000u
#define ENVM1_BASE 0x60080000u
#define ENVM2_BASE 0x600C0000u
/******************************************************************************/
/* bitband address calculation macro */
/******************************************************************************/
#define BITBAND_ADDRESS(X) ((X & 0xF0000000U) + 0x02000000U + ((X & 0xFFFFFU) << 5))
/******************************************************************************/
/* Peripheral declaration */
/******************************************************************************/
#define UART0 ((UART_TypeDef *) UART0_BASE)
#define SPI0 ((SPI_TypeDef *) SPI0_BASE)
#define I2C0 ((I2C_TypeDef *) I2C0_BASE)
#define I2C0_BITBAND ((I2C_BitBand_TypeDef *) BITBAND_ADDRESS(I2C0_BASE))
#define MAC ((MAC_TypeDef *) ETHERNET_BASE)
#define PDMA ((PDMA_TypeDef *) PDMA_BASE)
#define TIMER ((TIMER_TypeDef *) TIMER_BASE)
#define TIMER_BITBAND ((TIMER_BitBand_TypeDef *) BITBAND_ADDRESS(TIMER_BASE))
#define WATCHDOG ((WATCHDOG_TypeDef *) WATCHDOG_BASE)
#define INTERRUPT_CTRL ((INTERRUPT_CTRL_TypeDef *) H2F_IRQ_CTRL_BASE)
#define INTERRUPT_CTRL_BITBAND ((INTERRUPT_CTRL_BitBand_TypeDef *) BITBAND_ADDRESS(H2F_IRQ_CTRL_BASE))
#define UART1 ((UART_TypeDef *) UART1_BASE)
#define SPI1 ((SPI_TypeDef *) SPI1_BASE)
#define I2C1 ((I2C_TypeDef *) I2C1_BASE)
#define I2C1_BITBAND ((I2C_BitBand_TypeDef *) BITBAND_ADDRESS(I2C1_BASE))
#define GPIO ((GPIO_TypeDef *) GPIO_BASE)
#define GPIO_BITBAND ((GPIO_BitBand_TypeDef *) BITBAND_ADDRESS(GPIO_BASE))
#define HPDMA ((HPDMA_TypeDef *) HPDMA_BASE)
#define HPDMA_BITBAND ((HPDMA_BitBand_TypeDef *) BITBAND_ADDRESS(HPDMA_BASE))
#define COMBLK ((COMBLK_TypeDef *) COMBLK_BASE)
#define RTC ((RTC_TypeDef *) RTC_BASE)
#define ENVM_1 ((NVM_TypeDef *) ENVM1_BASE)
#define ENVM_2 ((NVM_TypeDef *) ENVM2_BASE)
#define SYSREG ((SYSREG_TypeDef *) SYSREG_BASE)
#define MDDR ((MDDR_TypeDef *) DDR0_CFG_BASE)
#define FDDR ((FDDR_TypeDef *) DDR1_CFG_BASE)
#define USB ((MSS_USB_TypeDef *) USB_BASE)
#define SERDES0 ((SERDESIF_TypeDef *) SERDES0_CFG_BASE)
#define SERDES1 ((SERDESIF_TypeDef *) SERDES1_CFG_BASE)
#define SERDES2 ((SERDESIF_TypeDef *) SERDES2_CFG_BASE)
#define SERDES3 ((SERDESIF_TypeDef *) SERDES3_CFG_BASE)
#define CORE_SF2_CFG ((CoreSF2Config_TypeDef *) CORE_SF2_CFG_BASE)
#ifdef __cplusplus
}
#endif
#endif /* __SMARTFUSION2_CMSIS_PAL_H__ */