blob: ab389e05d79a546cd7f1136945ddefa0bf3e758c [file] [log] [blame] [edit]
/*******************************************************************************
* (c) Copyright 2009 Actel Corporation. All rights reserved.
*
* SmartFusion A2FxxxM3 Cortex Microcontroller Software Interface - Peripheral
* Access Layer.
*
* This file describes the interrupt assignment and peripheral registers for
* the SmartFusion A2FxxxM3 familly of devices.
*
* SVN $Revision: 2331 $
* SVN $Date: 2010-02-26 12:02:06 +0000 (Fri, 26 Feb 2010) $
*/
#ifndef __A2FXXXM3_H__
#define __A2FXXXM3_H__
#ifdef __cplusplus
extern "C" {
#endif
/*
* ==========================================================================
* ---------- Interrupt Number Definition -----------------------------------
* ==========================================================================
*/
typedef enum IRQn
{
/****** Cortex-M3 Processor Exceptions Numbers *********************************************************/
NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable 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 */
/****** SmartFusion specific Interrupt Numbers *********************************************************/
WdogWakeup_IRQn = 0, /*!< WatchDog wakeup interrupt */
BrownOut_1_5V_IRQn = 1, /*!< Supply dropped below 1.5V */
BrownOut_3_3V_IRQn = 2, /*!< Supply dropped below 1.5V */
RTC_Match_IRQn = 3, /*!< RTC match interrupt */
RTCIF_Pub_IRQn = 4, /*!< RTC interface push button interrupt */
EthernetMAC_IRQn = 5, /*!< Ethernet MAC interrupt */
IAP_IRQn = 6, /*!< In Application Programming (IAP) interrupt */
ENVM0_IRQn = 7, /*!< eNVM0 operation completion interrupt */
ENVM1_IRQn = 8, /*!< eNVM1 operation completion interrupt */
DMA_IRQn = 9, /*!< Peripheral DMA interrupt */
UART0_IRQn = 10, /*!< UART0 interrupt */
UART1_IRQn = 11, /*!< UART1 interrupt */
SPI0_IRQn = 12, /*!< SPI0 interrupt */
SPI1_IRQn = 13, /*!< SP1 interrupt */
I2C0_IRQn = 14, /*!< I2C0 interrupt */
I2C0_SMBAlert_IRQn = 15, /*!< I2C0 SMBus Alert interrupt */
I2C0_SMBus_IRQn = 16, /*!< I2C0 SMBus Suspend interrupt */
I2C1_IRQn = 17, /*!< I2C1 interrupt */
I2C1_SMBAlert_IRQn = 18, /*!< I2C1 SMBus Alert interrupt */
I2C1_SMBus_IRQn = 19, /*!< I2C1 SMBus Suspend interrupt */
Timer1_IRQn = 20, /*!< Timer1 interrupt */
Timer2_IRQn = 21, /*!< Timer2 interrupt */
PLL_Lock_IRQn = 22, /*!< PLL lock interrupt */
PLL_LockLost_IRQn = 23, /*!< PLL loss of lock interrupt */
CommError_IRQn = 24, /*!< Communications Matrix error interrupt */
Fabric_IRQn = 31, /*!< FPGA fabric interrupt */
GPIO0_IRQn = 32, /*!< GPIO 0 interrupt */
GPIO1_IRQn = 33, /*!< GPIO 1 interrupt */
GPIO2_IRQn = 34, /*!< GPIO 2 interrupt */
GPIO3_IRQn = 35, /*!< GPIO 3 interrupt */
GPIO4_IRQn = 36, /*!< GPIO 4 interrupt */
GPIO5_IRQn = 37, /*!< GPIO 5 interrupt */
GPIO6_IRQn = 38, /*!< GPIO 6 interrupt */
GPIO7_IRQn = 39, /*!< GPIO 7 interrupt */
GPIO8_IRQn = 40, /*!< GPIO 8 interrupt */
GPIO9_IRQn = 41, /*!< GPIO 9 interrupt */
GPIO10_IRQn = 42, /*!< GPIO 10 interrupt */
GPIO11_IRQn = 43, /*!< GPIO 11 interrupt */
GPIO12_IRQn = 44, /*!< GPIO 12 interrupt */
GPIO13_IRQn = 45, /*!< GPIO 13 interrupt */
GPIO14_IRQn = 46, /*!< GPIO 14 interrupt */
GPIO15_IRQn = 47, /*!< GPIO 15 interrupt */
GPIO16_IRQn = 48, /*!< GPIO 16 interrupt */
GPIO17_IRQn = 49, /*!< GPIO 17 interrupt */
GPIO18_IRQn = 50, /*!< GPIO 18 interrupt */
GPIO19_IRQn = 51, /*!< GPIO 19 interrupt */
GPIO20_IRQn = 52, /*!< GPIO 20 interrupt */
GPIO21_IRQn = 53, /*!< GPIO 21 interrupt */
GPIO22_IRQn = 54, /*!< GPIO 22 interrupt */
GPIO23_IRQn = 55, /*!< GPIO 23 interrupt */
GPIO24_IRQn = 56, /*!< GPIO 24 interrupt */
GPIO25_IRQn = 57, /*!< GPIO 25 interrupt */
GPIO26_IRQn = 58, /*!< GPIO 26 interrupt */
GPIO27_IRQn = 59, /*!< GPIO 27 interrupt */
GPIO28_IRQn = 60, /*!< GPIO 28 interrupt */
GPIO29_IRQn = 61, /*!< GPIO 29 interrupt */
GPIO30_IRQn = 62, /*!< GPIO 30 interrupt */
GPIO31_IRQn = 63, /*!< GPIO 31 interrupt */
ACE_PC0_Flag0_IRQn = 64, /*!< ACE SSE program counter 0 flag 0 interrupt */
ACE_PC0_Flag1_IRQn = 65, /*!< ACE SSE program counter 0 flag 1 interrupt */
ACE_PC0_Flag2_IRQn = 66, /*!< ACE SSE program counter 0 flag 2 interrupt */
ACE_PC0_Flag3_IRQn = 67, /*!< ACE SSE program counter 0 flag 3 interrupt */
ACE_PC1_Flag0_IRQn = 68, /*!< ACE SSE program counter 1 flag 0 interrupt */
ACE_PC1_Flag1_IRQn = 69, /*!< ACE SSE program counter 1 flag 1 interrupt */
ACE_PC1_Flag2_IRQn = 70, /*!< ACE SSE program counter 1 flag 2 interrupt */
ACE_PC1_Flag3_IRQn = 71, /*!< ACE SSE program counter 1 flag 3 interrupt */
ACE_PC2_Flag0_IRQn = 72, /*!< ACE SSE program counter 2 flag 0 interrupt */
ACE_PC2_Flag1_IRQn = 73, /*!< ACE SSE program counter 2 flag 1 interrupt */
ACE_PC2_Flag2_IRQn = 74, /*!< ACE SSE program counter 2 flag 2 interrupt */
ACE_PC2_Flag3_IRQn = 75, /*!< ACE SSE program counter 2 flag 3 interrupt */
ACE_ADC0_DataValid_IRQn = 76, /*!< ACE ADC0 data valid interrupt */
ACE_ADC1_DataValid_IRQn = 77, /*!< ACE ADC1 data valid interrupt */
ACE_ADC2_DataValid_IRQn = 78, /*!< ACE ADC2 data valid interrupt */
ACE_ADC0_CalDone_IRQn = 79, /*!< ACE ADC0 calibration done interrupt */
ACE_ADC1_CalDone_IRQn = 80, /*!< ACE ADC1 calibration done interrupt */
ACE_ADC2_CalDone_IRQn = 81, /*!< ACE ADC2 calibration done interrupt */
ACE_ADC0_CalStart_IRQn = 82, /*!< ACE ADC0 calibration start interrupt */
ACE_ADC1_CalStart_IRQn = 83, /*!< ACE ADC1 calibration start interrupt */
ACE_ADC2_CalStart_IRQn = 84, /*!< ACE ADC2 calibration start interrupt */
ACE_Comp0_Fall_IRQn = 85, /*!< ACE comparator 0 falling under reference interrupt */
ACE_Comp1_Fall_IRQn = 86, /*!< ACE comparator 1 falling under reference interrupt */
ACE_Comp2_Fall_IRQn = 87, /*!< ACE comparator 2 falling under reference interrupt */
ACE_Comp3_Fall_IRQn = 88, /*!< ACE comparator 3 falling under reference interrupt */
ACE_Comp4_Fall_IRQn = 89, /*!< ACE comparator 4 falling under reference interrupt */
ACE_Comp5_Fall_IRQn = 90, /*!< ACE comparator 5 falling under reference interrupt */
ACE_Comp6_Fall_IRQn = 91, /*!< ACE comparator 6 falling under reference interrupt */
ACE_Comp7_Fall_IRQn = 92, /*!< ACE comparator 7 falling under reference interrupt */
ACE_Comp8_Fall_IRQn = 93, /*!< ACE comparator 8 falling under reference interrupt */
ACE_Comp9_Fall_IRQn = 94, /*!< ACE comparator 9 falling under reference interrupt */
ACE_Comp10_Fall_IRQn = 95, /*!< ACE comparator 10 falling under reference interrupt */
ACE_Comp11_Fall_IRQn = 96, /*!< ACE comparator 11 falling under reference interrupt */
ACE_Comp0_Rise_IRQn = 97, /*!< ACE comparator 0 rising over reference interrupt */
ACE_Comp1_Rise_IRQn = 98, /*!< ACE comparator 1 rising over reference interrupt */
ACE_Comp2_Rise_IRQn = 99, /*!< ACE comparator 2 rising over reference interrupt */
ACE_Comp3_Rise_IRQn = 100, /*!< ACE comparator 3 rising over reference interrupt */
ACE_Comp4_Rise_IRQn = 101, /*!< ACE comparator 4 rising over reference interrupt */
ACE_Comp5_Rise_IRQn = 102, /*!< ACE comparator 5 rising over reference interrupt */
ACE_Comp6_Rise_IRQn = 103, /*!< ACE comparator 6 rising over reference interrupt */
ACE_Comp7_Rise_IRQn = 104, /*!< ACE comparator 7 rising over reference interrupt */
ACE_Comp8_Rise_IRQn = 105, /*!< ACE comparator 8 rising over reference interrupt */
ACE_Comp9_Rise_IRQn = 106, /*!< ACE comparator 9 rising over reference interrupt */
ACE_Comp10_Rise_IRQn = 107, /*!< ACE comparator 10 rising over reference interrupt */
ACE_Comp11_Rise_IRQn = 108, /*!< ACE comparator 11 rising over reference interrupt */
ACE_ADC0_FifoFull_IRQn = 109, /*!< ACE ADC0 FIFO full interrupt */
ACE_ADC0_FifoAFull_IRQn = 110, /*!< ACE ADC0 FIFO almost full interrupt */
ACE_ADC0_FifoEmpty_IRQn = 111, /*!< ACE ADC0 FIFO empty interrupt */
ACE_ADC1_FifoFull_IRQn = 112, /*!< ACE ADC1 FIFO full interrupt */
ACE_ADC1_FifoAFull_IRQn = 113, /*!< ACE ADC1 FIFO almost full interrupt */
ACE_ADC1_FifoEmpty_IRQn = 114, /*!< ACE ADC1 FIFO empty interrupt */
ACE_ADC2_FifoFull_IRQn = 115, /*!< ACE ADC2 FIFO full interrupt */
ACE_ADC2_FifoAFull_IRQn = 116, /*!< ACE ADC2 FIFO almost full interrupt */
ACE_ADC2_FifoEmpty_IRQn = 117, /*!< ACE ADC2 FIFO empty interrupt */
ACE_PPE_Flag0_IRQn = 118, /*!< ACE post processing engine flag 0 interrupt */
ACE_PPE_Flag1_IRQn = 119, /*!< ACE post processing engine flag 1 interrupt */
ACE_PPE_Flag2_IRQn = 120, /*!< ACE post processing engine flag 2 interrupt */
ACE_PPE_Flag3_IRQn = 121, /*!< ACE post processing engine flag 3 interrupt */
ACE_PPE_Flag4_IRQn = 122, /*!< ACE post processing engine flag 4 interrupt */
ACE_PPE_Flag5_IRQn = 123, /*!< ACE post processing engine flag 5 interrupt */
ACE_PPE_Flag6_IRQn = 124, /*!< ACE post processing engine flag 6 interrupt */
ACE_PPE_Flag7_IRQn = 125, /*!< ACE post processing engine flag 7 interrupt */
ACE_PPE_Flag8_IRQn = 126, /*!< ACE post processing engine flag 8 interrupt */
ACE_PPE_Flag9_IRQn = 127, /*!< ACE post processing engine flag 9 interrupt */
ACE_PPE_Flag10_IRQn = 128, /*!< ACE post processing engine flag 10 interrupt */
ACE_PPE_Flag11_IRQn = 129, /*!< ACE post processing engine flag 11 interrupt */
ACE_PPE_Flag12_IRQn = 130, /*!< ACE post processing engine flag 12 interrupt */
ACE_PPE_Flag13_IRQn = 131, /*!< ACE post processing engine flag 13 interrupt */
ACE_PPE_Flag14_IRQn = 132, /*!< ACE post processing engine flag 14 interrupt */
ACE_PPE_Flag15_IRQn = 133, /*!< ACE post processing engine flag 15 interrupt */
ACE_PPE_Flag16_IRQn = 134, /*!< ACE post processing engine flag 16 interrupt */
ACE_PPE_Flag17_IRQn = 135, /*!< ACE post processing engine flag 17 interrupt */
ACE_PPE_Flag18_IRQn = 136, /*!< ACE post processing engine flag 18 interrupt */
ACE_PPE_Flag19_IRQn = 137, /*!< ACE post processing engine flag 19 interrupt */
ACE_PPE_Flag20_IRQn = 138, /*!< ACE post processing engine flag 20 interrupt */
ACE_PPE_Flag21_IRQn = 139, /*!< ACE post processing engine flag 21 interrupt */
ACE_PPE_Flag22_IRQn = 140, /*!< ACE post processing engine flag 22 interrupt */
ACE_PPE_Flag23_IRQn = 141, /*!< ACE post processing engine flag 23 interrupt */
ACE_PPE_Flag24_IRQn = 142, /*!< ACE post processing engine flag 24 interrupt */
ACE_PPE_Flag25_IRQn = 143, /*!< ACE post processing engine flag 25 interrupt */
ACE_PPE_Flag26_IRQn = 144, /*!< ACE post processing engine flag 26 interrupt */
ACE_PPE_Flag27_IRQn = 145, /*!< ACE post processing engine flag 27 interrupt */
ACE_PPE_Flag28_IRQn = 146, /*!< ACE post processing engine flag 28 interrupt */
ACE_PPE_Flag29_IRQn = 147, /*!< ACE post processing engine flag 29 interrupt */
ACE_PPE_Flag30_IRQn = 148, /*!< ACE post processing engine flag 30 interrupt */
ACE_PPE_Flag31_IRQn = 149 /*!< ACE post processing engine flag 31 interrupt */
} IRQn_Type;
/*
* ==========================================================================
* ----------- Processor and Core Peripheral Section ------------------------
* ==========================================================================
*/
/* Configuration of the Cortex-M3 Processor and Core Peripherals */
#define __MPU_PRESENT 1 /*!< SmartFusion includes a MPU */
#define __NVIC_PRIO_BITS 5 /*!< SmartFusion uses 5 Bits for the 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 */
#include "system_a2fxxxm3.h" /* SmartFusion System */
/******************************************************************************/
/* 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;
uint16_t RESERVED4;
__IO uint8_t MCR;
uint8_t RESERVED5;
uint16_t RESERVED6;
__I uint8_t LSR;
uint8_t RESERVED7;
uint16_t RESERVED8;
__I uint8_t MSR;
uint8_t RESERVED9;
uint16_t RESERVED10;
__IO uint8_t SR;
uint8_t RESERVED11;
uint16_t RESERVED12;
} UART_TypeDef;
/*------------------------------------------------------------------------------
*
*/
typedef struct
{
uint32_t RESERVED0[32];
__IO uint32_t IER_ERBFI;
__IO uint32_t IER_ETBEI;
__IO uint32_t IER_ELSI;
__IO uint32_t IER_EDSSI;
uint32_t RESERVED1[28];
__IO uint32_t FCR_ENABLE;
__IO uint32_t FCR_CLEAR_RX_FIFO;
__IO uint32_t FCR_CLEAR_TX_FIFO;
__IO uint32_t FCR_RXRDY_TXRDYN_EN;
__IO uint32_t FCR_RESERVED0;
__IO uint32_t FCR_RESERVED1;
__IO uint32_t FCR_RX_TRIG0;
__IO uint32_t FCR_RX_TRIG1;
uint32_t RESERVED2[24];
__IO uint32_t LCR_WLS0;
__IO uint32_t LCR_WLS1;
__IO uint32_t LCR_STB;
__IO uint32_t LCR_PEN;
__IO uint32_t LCR_EPS;
__IO uint32_t LCR_SP;
__IO uint32_t LCR_SB;
__IO uint32_t LCR_DLAB;
uint32_t RESERVED3[24];
__IO uint32_t MCR_DTR;
__IO uint32_t MCR_RTS;
__IO uint32_t MCR_OUT1;
__IO uint32_t MCR_OUT2;
__IO uint32_t MCR_LOOP;
uint32_t RESERVED4[27];
__I uint32_t LSR_DR;
__I uint32_t LSR_OE;
__I uint32_t LSR_PE;
__I uint32_t LSR_FE;
__I uint32_t LSR_BI;
__I uint32_t LSR_THRE;
__I uint32_t LSR_TEMT;
__I uint32_t LSR_FIER;
uint32_t RESERVED5[24];
__I uint32_t MSR_DCTS;
__I uint32_t MSR_DDSR;
__I uint32_t MSR_TERI;
__I uint32_t MSR_DDCD;
__I uint32_t MSR_CTS;
__I uint32_t MSR_DSR;
__I uint32_t MSR_RI;
__I uint32_t MSR_DCD;
} UART_BitBand_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;
} I2C_TypeDef;
/*------------------------------------------------------------------------------
*
*/
typedef struct
{
uint32_t CTRL_CR0;
uint32_t CTRL_CR1;
uint32_t CTRL_AA;
uint32_t CTRL_SI;
uint32_t CTRL_STO;
uint32_t CTRL_STA;
uint32_t CTRL_ENS1;
uint32_t CTRL_CR2;
uint32_t RESERVED0[56];
uint32_t DATA_DIR;
uint32_t RESERVED1[31];
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;
} SPI_TypeDef;
typedef struct
{
__IO uint32_t CTRL_ENABLE;
__IO uint32_t CTRL_MASTER;
__IO uint32_t CTRL_MODE[2];
__IO uint32_t CTRL_RX_INT_EN;
__IO uint32_t CTRL_TX_INT_EN;
__IO uint32_t CTRL_RX_OVERFLOW_INT_EN;
__IO uint32_t CTRL_TX_UNDERRUN_INT_EN;
__IO uint32_t CTRL_TXRXDFCOUNT[16];
__IO uint32_t CTRL_SPO;
__IO uint32_t CTRL_SPH;
__IO uint32_t CTRL_RESERVED[6];
__IO uint32_t TXRXDF_SIZE[32];
__I uint32_t STATUS_TX_DONE;
__I uint32_t STATUS_RX_RDY;
__I uint32_t STATUS_RX_CH_OV;
__I uint32_t STATUS_TX_CH_UV;
__I uint32_t STATUS_RX_FIFO_FULL;
__I uint32_t STATUS_RX_FIFO_FULL_NEXT;
__I uint32_t STATUS_RX_FIFO_EMPTY;
__I uint32_t STATUS_RX_FIFO_EMPTY_NEXT;
__I uint32_t STATUS_TX_FIFO_FULL;
__I uint32_t STATUS_TX_FIFO_FULL_NEXT;
__I uint32_t STATUS_TX_FIFO_EMPTY;
__I uint32_t STATUS_TX_FIFO_EMPTY_NEXT;
__I uint32_t STATUS_RESERVED[20];
__O uint32_t INT_CLEAR_TX_DONE;
__O uint32_t INT_CLEAR_RX_RDY;
__O uint32_t INT_CLEAR_RX_OVER;
__O uint32_t INT_CLEAR_TX_UNDER;
__O uint32_t INT_CLEAR[28];
__I uint32_t RX_DATA[32];
__O uint32_t TX_DATA[32];
__IO uint32_t CLK_GEN[32];
__IO uint32_t SLAVE_SELECT[32];
__I uint32_t MIS_TX_DONE;
__I uint32_t MIS_RX_RDY;
__I uint32_t MIS_RX_OVER;
__I uint32_t MIS_TX_UNDER;
__I uint32_t MIS[28];
__I uint32_t RIS[32];
} SPI_BitBand_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;
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;
/*----------------------------------------------------------------------------*/
/*----------------------------------- RTC ------------------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint32_t COUNTER0_REG;
__IO uint32_t COUNTER1_REG;
__IO uint32_t COUNTER2_REG;
__IO uint32_t COUNTER3_REG;
__IO uint32_t COUNTER4_REG;
__IO uint32_t RESERVED0[3];
__IO uint32_t MATCHREG0_REG;
__IO uint32_t MATCHREG1_REG;
__IO uint32_t MATCHREG2_REG;
__IO uint32_t MATCHREG3_REG;
__IO uint32_t MATCHREG4_REG;
__IO uint32_t RESERVED1[3];
__IO uint32_t MATCHBITS0_REG;
__IO uint32_t MATCHBITS1_REG;
__IO uint32_t MATCHBITS2_REG;
__IO uint32_t MATCHBITS3_REG;
__IO uint32_t MATCHBITS4_REG;
__IO uint32_t RESERVED2[3];
__IO uint32_t CTRL_STAT_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;
__IO uint32_t WDOGLOAD;
__IO uint32_t WDOGMVRP;
__O uint32_t WDOGREFRESH;
__IO 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
{
__IO uint32_t CSR0;
uint32_t RESERVED0;
__IO uint32_t CSR1;
uint32_t RESERVED1;
__IO uint32_t CSR2;
uint32_t RESERVED2;
__IO uint32_t CSR3;
uint32_t RESERVED3;
__IO uint32_t CSR4;
uint32_t RESERVED4;
__IO uint32_t CSR5;
uint32_t RESERVED5;
__IO uint32_t CSR6;
uint32_t RESERVED6;
__IO uint32_t CSR7;
uint32_t RESERVED7;
__IO uint32_t CSR8;
uint32_t RESERVED8;
__IO uint32_t CSR9;
uint32_t RESERVED9;
uint32_t RESERVED10;
uint32_t RESERVED11;
__IO uint32_t CSR11;
} MAC_TypeDef;
/*----------------------------------------------------------------------------*/
/*---------------------- Analog Conversion Engine (ACE) ----------------------*/
/*----------------------------------------------------------------------------*/
/* Analog quad configuration */
typedef struct
{
__IO uint8_t b0;
uint8_t reserved0_0;
uint16_t reserved0_1;
__IO uint8_t b1;
uint8_t reserved1_0;
uint16_t reserved1_1;
__IO uint8_t b2;
uint8_t reserved2_0;
uint16_t reserved2_1;
__IO uint8_t b3;
uint8_t reserved3_0;
uint16_t reserved3_1;
__IO uint8_t b4;
uint8_t reserved4_0;
uint16_t reserved4_1;
__IO uint8_t b5;
uint8_t reserved5_0;
uint16_t reserved5_1;
__IO uint8_t b6;
uint8_t reserved6_0;
uint16_t reserved6_1;
__IO uint8_t b7;
uint8_t reserved7_0;
uint16_t reserved7_1;
__IO uint8_t b8;
uint8_t reserved8_0;
uint16_t reserved8_1;
__IO uint8_t b9;
uint8_t reserved9_0;
uint16_t reserved9_1;
__IO uint8_t b10;
uint8_t reserved10_0;
uint16_t reserved10_1;
__IO uint8_t b11;
uint8_t reserved11_0;
uint16_t reserved11_1;
} AQ_config_t;
/* ACE memory map layout */
typedef struct
{
__O uint32_t NOP;
__IO uint32_t SSE_TS_CTRL;
__IO uint32_t ADC_SYNC_CONV;
__IO uint32_t ANA_COMM_CTRL;
__IO uint32_t DAC_SYNC_CTRL;
__IO uint32_t PDMA_REQUEST;
uint32_t RESERVED0[10];
__O uint32_t PC0_LO;
__O uint32_t PC0_HI;
__IO uint32_t PC0_CTRL;
__IO uint32_t PC0_DLY;
__IO uint32_t ADC0_CONV_CTRL;
__IO uint32_t ADC0_STC;
__IO uint32_t ADC0_TVC;
__IO uint32_t ADC0_MISC_CTRL;
__IO uint32_t DAC0_CTRL;
__IO uint32_t DAC0_BYTE0;
__IO uint32_t DAC0_BYTE1;
__IO uint32_t DAC0_BYTE2;
__IO uint32_t LC0;
__O uint32_t LC0_JMP_LO;
__O uint32_t LC0_JMP_HI;
__O uint32_t PC0_FLAGS;
__O uint32_t PC1_LO;
__O uint32_t PC1_HI;
__IO uint32_t PC1_CTRL;
__IO uint32_t PC1_DLY;
__IO uint32_t ADC1_CONV_CTRL;
__IO uint32_t ADC1_STC;
__IO uint32_t ADC1_TVC;
__IO uint32_t ADC1_MISC_CTRL;
__IO uint32_t DAC1_CTRL;
__IO uint32_t DAC1_BYTE0;
__IO uint32_t DAC1_BYTE1;
__IO uint32_t DAC1_BYTE2;
__IO uint32_t LC1;
__O uint32_t LC1_JMP_LO;
__O uint32_t LC1_JMP_HI;
__O uint32_t PC1_FLAGS;
__O uint32_t PC2_LO;
__O uint32_t PC2_HI;
__IO uint32_t PC2_CTRL;
__IO uint32_t PC2_DLY;
__IO uint32_t ADC2_CONV_CTRL;
__IO uint32_t ADC2_STC;
__IO uint32_t ADC2_TVC;
__IO uint32_t ADC2_MISC_CTRL;
__IO uint32_t DAC2_CTRL;
__IO uint32_t DAC2_BYTE0;
__IO uint32_t DAC2_BYTE1;
__IO uint32_t DAC2_BYTE2;
__IO uint32_t LC2;
__O uint32_t LC2_JMP_LO;
__O uint32_t LC2_JMP_HI;
__O uint32_t PC2_FLAGS;
uint32_t RESERVED1;
uint32_t RESERVED2;
__IO uint32_t SSE_RAM_LO_IDATA;
__IO uint32_t SSE_RAM_HI_IDATA;
uint32_t RESERVED3[61];
AQ_config_t ACB_DATA[6];
uint32_t RESERVED4[59];
__IO uint32_t SSE_PC0;
__IO uint32_t SSE_PC1;
__IO uint32_t SSE_PC2;
uint32_t RESERVED5[57];
__IO uint32_t SSE_DAC0_BYTES01;
__IO uint32_t SSE_DAC1_BYTES01;
__IO uint32_t SSE_DAC2_BYTES01;
uint32_t RESERVED6[61];
__O uint32_t SSE_ADC0_RESULTS;
__O uint32_t SSE_ADC1_RESULTS;
__O uint32_t SSE_ADC2_RESULTS;
uint32_t RESERVED7[61];
__O uint32_t SSE_PDMA_DATAIN;
uint32_t RESERVED8[63];
__IO uint32_t SSE_RAM_DATA[512];
__I uint32_t ADC0_STATUS;
__I uint32_t ADC1_STATUS;
__I uint32_t ADC2_STATUS;
__I uint32_t COMPARATOR_STATUS;
uint32_t RESERVED9[124];
__IO uint32_t SSE_IRQ_EN;
__I uint32_t SSE_IRQ;
__O uint32_t SSE_IRQ_CLR;
__IO uint32_t COMP_IRQ_EN;
__I uint32_t COMP_IRQ;
__O uint32_t COMP_IRQ_CLR;
__IO uint32_t PPE_FIFO_IRQ_EN;
__I uint32_t PPE_FIFO_IRQ;
__O uint32_t PPE_FIFO_IRQ_CLR;
__IO uint32_t PPE_FLAGS0_IRQ_EN;
__I uint32_t PPE_FLAGS0_IRQ;
__O uint32_t PPE_FLAGS0_IRQ_CLR;
__IO uint32_t PPE_FLAGS1_IRQ_EN;
__I uint32_t PPE_FLAGS1_IRQ;
__O uint32_t PPE_FLAGS1_IRQ_CLR;
__IO uint32_t PPE_FLAGS2_IRQ_EN;
__I uint32_t PPE_FLAGS2_IRQ;
__O uint32_t PPE_FLAGS2_IRQ_CLR;
__IO uint32_t PPE_FLAGS3_IRQ_EN;
__I uint32_t PPE_FLAGS3_IRQ;
__O uint32_t PPE_FLAGS3_IRQ_CLR;
__IO uint32_t PPE_SFFLAGS_IRQ_EN;
__I uint32_t PPE_SFFLAGS_IRQ;
__O uint32_t PPE_SFFLAGS_IRQ_CLR;
__IO uint32_t FPGA_FLAGS_SEL;
uint32_t RESERVED10[39];
__IO uint32_t PPE_PDMA_CTRL;
__I uint32_t PDMA_STATUS;
__IO uint32_t PPE_PDMA_DATAOUT;
uint32_t RESERVED11[61];
__I uint32_t PPE_NOP;
__IO uint32_t PPE_CTRL;
__IO uint32_t PPE_PC_ETC;
__IO uint32_t PPE_SF;
__IO uint32_t PPE_SCRATCH;
uint32_t RESERVED12;
__IO uint32_t ALU_CTRL;
__I uint32_t ALU_STATUS;
__IO uint32_t ALU_A;
uint32_t RESERVED50;
__IO uint32_t ALU_B;
uint32_t RESERVED53;
__IO uint32_t ALU_C;
uint32_t RESERVED51;
__IO uint32_t ALU_D;
uint32_t RESERVED52;
__IO uint32_t ALU_E;
uint32_t RESERVED54;
__IO uint32_t PPE_FPTR;
uint32_t RESERVED55;
__IO uint32_t PPE_FLAGS0;
__IO uint32_t PPE_FLAGS1;
__IO uint32_t PPE_FLAGS2;
__IO uint32_t PPE_FLAGS3;
__IO uint32_t PPE_SFFLAGS;
uint32_t RESERVED13[11];
__IO uint32_t ADC0_FIFO_CTRL;
__I uint32_t ADC0_FIFO_STATUS;
__IO uint32_t ADC0_FIFO_DATA;
__IO uint32_t ADC1_FIFO_CTRL;
__I uint32_t ADC1_FIFO_STATUS;
__IO uint32_t ADC1_FIFO_DATA;
__IO uint32_t ADC2_FIFO_CTRL;
__I uint32_t ADC2_FIFO_STATUS;
__IO uint32_t ADC2_FIFO_DATA;
uint32_t RESERVED14[19];
__I uint32_t ADC0_FIFO_DATA_PEEK;
__I uint32_t ADC0_FIFO_DATA0;
__I uint32_t ADC0_FIFO_DATA1;
__I uint32_t ADC0_FIFO_DATA2;
__I uint32_t ADC0_FIFO_DATA3;
__I uint32_t ADC1_FIFO_DATA_PEEK;
__I uint32_t ADC1_FIFO_DATA0;
__I uint32_t ADC1_FIFO_DATA1;
__I uint32_t ADC1_FIFO_DATA2;
__I uint32_t ADC1_FIFO_DATA3;
__I uint32_t ADC2_FIFO_DATA_PEEK;
__I uint32_t ADC2_FIFO_DATA0;
__I uint32_t ADC2_FIFO_DATA1;
__I uint32_t ADC2_FIFO_DATA2;
__I uint32_t ADC2_FIFO_DATA3;
uint32_t RESERVED15[177];
__IO uint32_t PPE_RAM_DATA[512];
} ACE_TypeDef;
/*----------------------------------------------------------------------------*/
/*------------------------ In Application Programming ------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint32_t IAP_IR;
__IO uint32_t IAP_DR2;
__IO uint32_t IAP_DR3;
__IO uint32_t IAP_DR5;
__IO uint32_t IAP_DR26;
__IO uint32_t IAP_DR32;
__IO uint32_t IAP_DR;
__IO uint32_t IAP_DR_LENGTH;
__IO uint32_t IAP_TAP_NEW_STATE;
__IO uint32_t IAP_TAP_CONTROL;
__I uint32_t IAP_STATUS;
} IAP_TypeDef;
/*----------------------------------------------------------------------------*/
/*---------------------- eNVM Special Function Registers ---------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint32_t STATUS;
__IO uint32_t CONTROL;
__IO uint32_t ENABLE;
uint32_t RESERVED0;
__IO uint32_t CONFIG_0;
__IO uint32_t CONFIG_1;
__IO uint32_t PAGE_STATUS_0;
__IO uint32_t PAGE_STATUS_1;
__IO uint32_t SEGMENT;
__IO uint32_t ENVM_SELECT;
} NVM_TypeDef;
/*----------------------------------------------------------------------------*/
/*---------------------- eNVM Special Function Registers ---------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint32_t MSSIRQ_EN0;
__IO uint32_t MSSIRQ_EN1;
__IO uint32_t MSSIRQ_EN2;
__IO uint32_t MSSIRQ_EN3;
__IO uint32_t MSSIRQ_EN4;
__IO uint32_t MSSIRQ_EN5;
__IO uint32_t MSSIRQ_EN6;
__IO uint32_t MSSIRQ_EN7;
__I uint32_t MSSIRQ_SRC0;
__I uint32_t MSSIRQ_SRC1;
__I uint32_t MSSIRQ_SRC2;
__I uint32_t MSSIRQ_SRC3;
__I uint32_t MSSIRQ_SRC4;
__I uint32_t MSSIRQ_SRC5;
__I uint32_t MSSIRQ_SRC6;
__I uint32_t MSSIRQ_SRC7;
__IO uint32_t FIIC_MR;
} MSS_IRQ_CTRL_TypeDef;
/*----------------------------------------------------------------------------*/
/*------------------------------ System Registers ----------------------------*/
/*----------------------------------------------------------------------------*/
typedef struct
{
__IO uint32_t ESRAM_CR;
__IO uint32_t ENVM_CR;
__IO uint32_t ENVM_REMAP_SYS_CR;
__IO uint32_t ENVM_REMAP_FAB_CR;
__IO uint32_t FAB_PROT_SIZE_CR;
__IO uint32_t FAB_PROT_BASE_CR;
__IO uint32_t AHB_MATRIX_CR;
__IO uint32_t MSS_SR;
__IO uint32_t CLR_MSS_SR;
__IO uint32_t EFROM_CR;
__IO uint32_t IAP_CR;
__IO uint32_t SOFT_IRQ_CR;
__IO uint32_t SOFT_RST_CR;
__IO uint32_t DEVICE_SR;
__IO uint32_t SYSTICK_CR;
__IO uint32_t EMC_MUX_CR;
__IO uint32_t EMC_CS_0_CR;
__IO uint32_t EMC_CS_1_CR;
__IO uint32_t MSS_CLK_CR;
__IO uint32_t MSS_CCC_DIV_CR;
__IO uint32_t MSS_CCC_MUX_CR;
__IO uint32_t MSS_CCC_PLL_CR;
__IO uint32_t MSS_CCC_DLY_CR;
__IO uint32_t MSS_CCC_SR;
__IO uint32_t MSS_RCOSC_CR;
__IO uint32_t VRPSM_CR;
__IO uint32_t RESERVED;
__IO uint32_t FAB_IF_CR;
__IO uint32_t FAB_APB_HIWORD_DR;
__IO uint32_t LOOPBACK_CR;
__IO uint32_t MSS_IO_BANK_CR;
__IO uint32_t GPIN_SOURCE_CR;
__IO uint32_t TEST_SR;
__IO uint32_t RED_REP_ADDR0;
__I uint32_t RED_REP_LOW_LOCS0;
__I uint32_t RED_REP_HIGH_LOCS0;
__IO uint32_t RED_REP_ADDR1;
__I uint32_t RED_REP_LOW_LOCS1;
__I uint32_t RED_REP_HIGH_LOCS1;
__IO uint32_t FABRIC_CR;
uint32_t RESERVED1[24];
__IO uint32_t IOMUX_CR[83];
} SYSREG_TypeDef;
#define SYSREG_ENVM_SOFTRESET_MASK (uint32_t)0x00000001
#define SYSREG_ESRAM0_SOFTRESET_MASK (uint32_t)0x00000002
#define SYSREG_ESRAM1_SOFTRESET_MASK (uint32_t)0x00000004
#define SYSREG_EMC_SOFTRESET_MASK (uint32_t)0x00000008
#define SYSREG_MAC_SOFTRESET_MASK (uint32_t)0x00000010
#define SYSREG_PDMA_SOFTRESET_MASK (uint32_t)0x00000020
#define SYSREG_TIMER_SOFTRESET_MASK (uint32_t)0x00000040
#define SYSREG_UART0_SOFTRESET_MASK (uint32_t)0x00000080
#define SYSREG_UART1_SOFTRESET_MASK (uint32_t)0x00000100
#define SYSREG_SPI0_SOFTRESET_MASK (uint32_t)0x00000200
#define SYSREG_SPI1_SOFTRESET_MASK (uint32_t)0x00000400
#define SYSREG_I2C0_SOFTRESET_MASK (uint32_t)0x00000800
#define SYSREG_I2C1_SOFTRESET_MASK (uint32_t)0x00001000
#define SYSREG_ACE_SOFTRESET_MASK (uint32_t)0x00002000
#define SYSREG_GPIO_SOFTRESET_MASK (uint32_t)0x00004000
#define SYSREG_IAP_SOFTRESET_MASK (uint32_t)0x00008000
#define SYSREG_EXT_SOFTRESET_MASK (uint32_t)0x00010000
#define SYSREG_FPGA_SOFTRESET_MASK (uint32_t)0x00020000
#define SYSREG_F2M_RESET_ENABLE_MASK (uint32_t)0x00040000
#define SYSREG_PADRESET_ENABLE_MASK (uint32_t)0x00080000
/******************************************************************************/
/* Peripheral memory map */
/******************************************************************************/
#define UART0_BASE 0x40000000U
#define SPI0_BASE 0x40001000U
#define I2C0_BASE 0x40002000U
#define MAC_BASE 0x40003000U
#define PDMA_BASE 0x40004000U
#define TIMER_BASE 0x40005000U
#define WATCHDOG_BASE 0x40006000U
#define H2F_IRQ_CTRL_BASE 0x40007000U
#define UART1_BASE 0x40010000U
#define SPI1_BASE 0x40011000U
#define I2C1_BASE 0x40012000U
#define GPIO_BASE 0x40013000U
#define RTC_BASE 0x40014100U
#define FROM_BASE 0x40015000U
#define IAP_BASE 0x40016000U
#define ACE_BASE 0x40020000U
#define FPGA_FABRIC_RAM_BASE 0x40040000U
#define FPGA_FABRIC_BASE 0x40050000U
#define ENVM_BASE 0x60000000U
#define ENVM_REGS_BASE 0x60100000U
#define SYSREG_BASE 0xE0042000U
/******************************************************************************/
/* bitband address calcualtion macro */
/******************************************************************************/
#define BITBAND_ADDRESS(X) ((X & 0xF0000000U) + 0x02000000U + ((X & 0xFFFFFU) << 5))
/******************************************************************************/
/* Peripheral declaration */
/******************************************************************************/
#define UART0 ((UART_TypeDef *) UART0_BASE)
#define UART0_BITBAND ((UART_BitBand_TypeDef *) BITBAND_ADDRESS(UART0_BASE))
#define SPI0 ((SPI_TypeDef *) SPI0_BASE)
#define SPI0_BITBAND ((SPI_BitBand_TypeDef *) BITBAND_ADDRESS(SPI0_BASE))
#define I2C0 ((I2C_TypeDef *) I2C0_BASE)
#define I2C0_BITBAND ((I2C_BitBand_TypeDef *) BITBAND_ADDRESS(I2C0_BASE))
#define MAC ((MAC_TypeDef *) MAC_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 MSS_IRQ_CTRL ((MSS_IRQ_CTRL_TypeDef *) H2F_IRQ_CTRL_BASE)
#define UART1 ((UART_TypeDef *) UART1_BASE)
#define UART1_BITBAND ((UART_BitBand_TypeDef *) BITBAND_ADDRESS(UART1_BASE))
#define SPI1 ((SPI_TypeDef *) SPI1_BASE)
#define SPI1_BITBAND ((SPI_BitBand_TypeDef *) BITBAND_ADDRESS(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 RTC ((RTC_TypeDef *) RTC_BASE)
#define FROM ((void *) FROM_BASE)
#define IAP ((IAP_TypeDef *) IAP_BASE)
#define ACE ((ACE_TypeDef *) ACE_BASE)
#define FPGA_FABRIC_RAM ((void *) FPGA_FABRIC_RAM_BASE)
#define FPGA_FABRIC ((void *) FPGA_FABRIC_BASE)
#define ENVM ((void *) ENVM_BASE)
#define ENVM_REGS ((NVM_TypeDef *) ENVM_REGS_BASE)
#define SYSREG ((SYSREG_TypeDef *) SYSREG_BASE)
#ifdef __cplusplus
}
#endif
#endif /* __A2FXXXM3_H__ */