974 lines
44 KiB
C
974 lines
44 KiB
C
/**
|
||
* @file wm_regs.h
|
||
*
|
||
* @brief register & operation file
|
||
*
|
||
* @author winnermicro
|
||
*
|
||
* Copyright (c) 2015 Winner Microelectronics Co., Ltd.
|
||
*/
|
||
#ifndef WM_REGS_H
|
||
#define WM_REGS_H
|
||
|
||
typedef volatile unsigned char vu8;
|
||
typedef volatile unsigned short vu16;
|
||
typedef volatile unsigned long vu32;
|
||
|
||
#define M8(adr) (*((vu8 *) (adr)))
|
||
#define M16(adr) (*((vu16*) (adr)))
|
||
#define M32(adr) (*((vu32*) (adr)))
|
||
|
||
#define ATTRIBUTE_ISR __attribute__((isr))
|
||
|
||
typedef enum IRQn
|
||
{
|
||
/****** W800 specific Interrupt Numbers *********************************************************/
|
||
SDIO_IRQn = 0, /*!< SDIO Receiver/Transmit/Command Receiver/SDIO Command Transmit Interrupt */
|
||
MAC_IRQn = 1, /*!< MAC Interrupt */
|
||
RF_CFG_IRQn = 2, /*!< RF_CFG Interrupt */
|
||
SEC_IRQn = 3, /*!< SEC RX/TX_MNGT/TX_DATA Interrupt */
|
||
DMA_Channel0_IRQn = 4, /*!< DMA Channel 0 global Interrupt */
|
||
DMA_Channel1_IRQn = 5, /*!< DMA Channel 1 global Interrupt */
|
||
DMA_Channel2_IRQn = 6, /*!< DMA Channel 2 global Interrupt */
|
||
DMA_Channel3_IRQn = 7, /*!< DMA Channel 3 global Interrupt */
|
||
DMA_Channel4_7_IRQn = 8, /*!< DMA Channel 4~7 global Interrupt */
|
||
DMA_BRUST_IRQn = 9, /*!< DMA Burst global Interrupt */
|
||
I2C_IRQn = 10, /*!< I2C Interrupts */
|
||
ADC_IRQn = 11, /*!< ADC Convert Interrupts */
|
||
SPI_LS_IRQn = 12, /*!< Low Speed SPI Interrupt */
|
||
SPI_HS_IRQn = 13, /*!< High Speed SPI Interrupt */
|
||
GPIOA_IRQn = 14, /*!< GPIO A Interrupt */
|
||
GPIOB_IRQn = 15, /*!< GPIO B Interrupt */
|
||
UART0_IRQn = 16, /*!< UART0 Interrupts */
|
||
UART1_IRQn = 17, /*!< UART1 Interrupt */
|
||
TOUCH_IRQn = 18, /*!< Touch Sensor Iterrupt */
|
||
UART24_IRQn = 19, /*!< UART2/3/4/5 Interrupt */
|
||
BLE_IRQn = 20, /*!< BLE Interrupt */
|
||
BT_IRQn = 21, /*!< BT Interrupt */
|
||
PWM_IRQn = 22, /*!< PWM Interrupt */
|
||
I2S_IRQn = 23, /*!< I2S Interrupts */
|
||
SIDO_HOST_IRQn = 24, /*!< SDIO Host Interrupts */
|
||
SYS_TICK_IRQn = 25, /*!< SYS Tick Interrupts */
|
||
RSA_IRQn = 26, /*!< RSA Interrupts */
|
||
CRYPTION_IRQn = 27, /*!< GPSEC Interrupts */
|
||
FLASH_IRQn = 28, /*!< Flash Interrupt */
|
||
PMU_IRQn = 29, /*!< PMU Interrupt */
|
||
TIMER_IRQn = 30, /*!< Timer0~5 Trigger */
|
||
WDG_IRQn = 31, /*!< Watch Dog Interrupt */
|
||
} IRQn_Type;
|
||
|
||
//#include "core_cm3.h"
|
||
#include "wm_type_def.h"
|
||
#ifdef __cplusplus
|
||
#define __I volatile /*!< Defines 'read only' permissions */
|
||
#else
|
||
#define __I volatile const /*!< Defines 'read only' permissions */
|
||
#endif
|
||
#define __O volatile /*!< Defines 'write only' permissions */
|
||
#define __IO volatile /*!< Defines 'read / write' permissions */
|
||
|
||
|
||
typedef enum {DISABLE = 0, ENABLE = !DISABLE} FunctionalState;
|
||
typedef volatile unsigned int TLS_REG; /* Hardware register definition */
|
||
|
||
#ifndef BIT
|
||
#define BIT(x) (1UL << (x))
|
||
#endif
|
||
|
||
#define APB_CLK (40000000) /* 40MHz */
|
||
|
||
#define DEVICE_BASE_ADDR 0x40000000
|
||
|
||
|
||
/***************************************************************
|
||
* SDIO Reg
|
||
***************************************************************/
|
||
#define HR_SDIO_BASE_ADDR (DEVICE_BASE_ADDR + 0x2400)
|
||
#define HR_SDIO_CIS0 (HR_SDIO_BASE_ADDR + 0x008)
|
||
#define HR_SDIO_CIS1 (HR_SDIO_BASE_ADDR + 0x00C)
|
||
#define HR_SDIO_CSA (HR_SDIO_BASE_ADDR + 0x010)
|
||
#define HR_SDIO_READ (HR_SDIO_BASE_ADDR + 0x014)
|
||
#define HR_SDIO_WRITE (HR_SDIO_BASE_ADDR + 0x018)
|
||
#define HR_SDIO_INTEN (HR_SDIO_BASE_ADDR + 0x030)
|
||
#define HR_SDIO_OCR (HR_SDIO_BASE_ADDR + 0x034)
|
||
#define HR_SDIO_CIA (HR_SDIO_BASE_ADDR + 0x024)
|
||
#define HR_SDIO_PROG (HR_SDIO_BASE_ADDR + 0x028)
|
||
|
||
/***************************************************************
|
||
* SDIO HOST Reg
|
||
***************************************************************/
|
||
#define HR_SDIO_HOST_BASE_ADDR (DEVICE_BASE_ADDR + 0xA00)
|
||
#define HR_SDIO_HOST_MMC_CTRL (HR_SDIO_HOST_BASE_ADDR + 0x0)
|
||
|
||
/***************************************************************
|
||
* HSPI Reg
|
||
***************************************************************/
|
||
#define HR_HSPI_BASE_ADDR (DEVICE_BASE_ADDR + 0x2600)
|
||
#define HR_HSPI_CLEAR_FIFO (HR_HSPI_BASE_ADDR)
|
||
#define HR_HSPI_SPI_CFG (HR_HSPI_BASE_ADDR + 0x04)
|
||
#define HR_HSPI_MODE_CFG (HR_HSPI_BASE_ADDR + 0x08)
|
||
#define HR_HSPI_INT_MASK (HR_HSPI_BASE_ADDR + 0x0C)
|
||
#define HR_HSPI_INT_STTS (HR_HSPI_BASE_ADDR + 0x10)
|
||
#define HR_HSPI_RXDAT_LEN (HR_HSPI_BASE_ADDR + 0x18)
|
||
|
||
/***************************************************************
|
||
* Inner Flash Reg
|
||
***************************************************************/
|
||
#define HR_FLASH_BASE_ADDR (DEVICE_BASE_ADDR + 0x2000)
|
||
#define HR_FLASH_CMD_ADDR (HR_FLASH_BASE_ADDR + 0x000)
|
||
#define HR_FLASH_CMD_START (HR_FLASH_BASE_ADDR + 0x004)
|
||
#define HR_FLASH_CR (HR_FLASH_BASE_ADDR + 0x008)
|
||
#define HR_FLASH_ADDR (HR_FLASH_BASE_ADDR + 0x010)
|
||
#define HR_FLASH_ENCRYPT_CTRL (HR_FLASH_BASE_ADDR + 0x014)
|
||
#define HR_FLASH_KEY_STATUS (HR_FLASH_BASE_ADDR + 0x018)
|
||
/***************************************************************
|
||
* SDIO WRAPPER Register
|
||
***************************************************************/
|
||
#define HR_SDIO_WRAPPER_BASE_ADDR (DEVICE_BASE_ADDR + 0x2800)
|
||
#define HR_SDIO_INT_SRC (HR_SDIO_WRAPPER_BASE_ADDR + 0x000)
|
||
#define HR_SDIO_INT_MASK (HR_SDIO_WRAPPER_BASE_ADDR + 0x004)
|
||
#define HR_SDIO_UPCMDVALID (HR_SDIO_WRAPPER_BASE_ADDR + 0x008)
|
||
#define HR_SDIO_DOWNCMDVALID (HR_SDIO_WRAPPER_BASE_ADDR + 0x00C)
|
||
#define HR_SDIO_TXBD_LINKEN (HR_SDIO_WRAPPER_BASE_ADDR + 0x010)
|
||
#define HR_SDIO_TXBD_ADDR (HR_SDIO_WRAPPER_BASE_ADDR + 0x014)
|
||
#define HR_SDIO_TXEN (HR_SDIO_WRAPPER_BASE_ADDR + 0x018)
|
||
#define HR_SDIO_TX_STTS (HR_SDIO_WRAPPER_BASE_ADDR + 0x01C)
|
||
#define HR_SDIO_RXBD_LINKEN (HR_SDIO_WRAPPER_BASE_ADDR + 0x020)
|
||
#define HR_SDIO_RXBD_ADDR (HR_SDIO_WRAPPER_BASE_ADDR + 0x024)
|
||
#define HR_SDIO_RXEN (HR_SDIO_WRAPPER_BASE_ADDR + 0x028)
|
||
#define HR_SDIO_RX_STTS (HR_SDIO_WRAPPER_BASE_ADDR + 0x02C)
|
||
#define HR_SDIO_CMD_ADDR (HR_SDIO_WRAPPER_BASE_ADDR + 0x030)
|
||
#define HR_SDIO_CMD_SIZE (HR_SDIO_WRAPPER_BASE_ADDR + 0x034)
|
||
|
||
/* SDIO interrupt bit definition */
|
||
#define SDIO_WP_INT_SRC_CMD_DOWN (1UL<<3)
|
||
#define SDIO_WP_INT_SRC_CMD_UP (1UL<<2)
|
||
#define SDIO_WP_INT_SRC_DATA_DOWN (1UL<<1)
|
||
#define SDIO_WP_INT_SRC_DATA_UP (1UL<<0)
|
||
|
||
|
||
/***************************************************************
|
||
* DMA Reg
|
||
***************************************************************/
|
||
#define HR_DMA_BASE_ADDR (DEVICE_BASE_ADDR + 0x800)
|
||
#define HR_DMA_INT_MASK (HR_DMA_BASE_ADDR + 0x0)
|
||
#define HR_DMA_INT_SRC (HR_DMA_BASE_ADDR + 0x4)
|
||
#define HR_DMA_CHNL_SEL (HR_DMA_BASE_ADDR + 0x08)
|
||
#define HR_DMA_CHNL0_SRC_ADDR (HR_DMA_BASE_ADDR + 0x10)
|
||
#define HR_DMA_CHNL0_DEST_ADDR (HR_DMA_BASE_ADDR + 0x14)
|
||
#define HR_DMA_CHNL0_SRC_WRAP_ADDR (HR_DMA_BASE_ADDR + 0x18)
|
||
#define HR_DMA_CHNL0_DEST_WRAP_ADDR (HR_DMA_BASE_ADDR + 0x1C)
|
||
#define HR_DMA_CHNL0_WRAP_SIZE (HR_DMA_BASE_ADDR + 0x20)
|
||
#define HR_DMA_CHNL0_CHNL_CTRL (HR_DMA_BASE_ADDR + 0x24)
|
||
#define HR_DMA_CHNL0_DMA_MODE (HR_DMA_BASE_ADDR + 0x28)
|
||
#define HR_DMA_CHNL0_DMA_CTRL (HR_DMA_BASE_ADDR + 0x2C)
|
||
#define HR_DMA_CHNL0_DMA_STATUS (HR_DMA_BASE_ADDR + 0x30)
|
||
#define HR_DMA_CHNL0_LINK_DEST_ADDR (HR_DMA_BASE_ADDR + 0x34)
|
||
#define HR_DMA_CHNL0_CURRENT_DEST_ADDR (HR_DMA_BASE_ADDR + 0x38)
|
||
|
||
#define DMA_STARTADDRESS HR_DMA_BASE_ADDR
|
||
#define DMA_INTMASK_REG (*(volatile unsigned int*)(DMA_STARTADDRESS+0x000))
|
||
#define DMA_INTSRC_REG (*(volatile unsigned int*)(DMA_STARTADDRESS+0x004))
|
||
#define DMA_CHANNEL_SEL (*(volatile unsigned int*)(DMA_STARTADDRESS+0x008))
|
||
#define DMA_CHNL_REG_BASE (DMA_STARTADDRESS+0x010)
|
||
#define DMA_SRCADDR_REG(ch) (*(volatile unsigned int*)(DMA_CHNL_REG_BASE + 0x30 * (ch /*- 1*/) +0x00))
|
||
#define DMA_DESTADDR_REG(ch) (*(volatile unsigned int*)(DMA_CHNL_REG_BASE + 0x30 * (ch /*- 1*/) +0x04))
|
||
#define DMA_SRCWRAPADDR_REG(ch) (*(volatile unsigned int*)(DMA_CHNL_REG_BASE + 0x30 * (ch /*- 1*/) +0x08))
|
||
#define DMA_DESTWRAPADDR_REG(ch) (*(volatile unsigned int*)(DMA_CHNL_REG_BASE + 0x30 * (ch /*- 1*/) +0x0C))
|
||
#define DMA_WRAPSIZE_REG(ch) (*(volatile unsigned int*)(DMA_CHNL_REG_BASE + 0x30 * (ch /*- 1*/) +0x10))
|
||
#define DMA_CHNLCTRL_REG(ch) (*(volatile unsigned int*)(DMA_CHNL_REG_BASE + 0x30 * (ch /*- 1*/) +0x14))
|
||
#define DMA_MODE_REG(ch) (*(volatile unsigned int*)(DMA_CHNL_REG_BASE + 0x30 * (ch /*- 1*/) +0x18))
|
||
#define DMA_CTRL_REG(ch) (*(volatile unsigned int*)(DMA_CHNL_REG_BASE + 0x30 * (ch /*- 1*/) +0x1C))
|
||
#define DMA_STATUS_REG(ch) (*(volatile unsigned int*)(DMA_CHNL_REG_BASE + 0x30 * (ch /*- 1*/) +0x20))
|
||
#define DMA_DESC_ADDR_REG(ch) (*(volatile unsigned int*)(DMA_CHNL_REG_BASE + 0x30 * (ch /*- 1*/) +0x24))
|
||
#define DMA_CURRDESTADDR_REG(ch) (*(volatile unsigned int*)(DMA_CHNL_REG_BASE + 0x30 * (ch /*- 1*/) +0x28))
|
||
|
||
#define DMA_CHNL_CTRL_CHNL_ON (1<<0)
|
||
#define DMA_CHNL_CTRL_CHNL_OFF (1<<1)
|
||
|
||
#define DMA_MODE_HARD_MODE (1<<0)
|
||
#define DMA_MODE_CHAIN_MODE (1<<1)
|
||
|
||
#define DMA_MODE_SEL_MASK (0xF<<2)
|
||
#define DMA_MODE_SEL_UART_RX (0<<2)
|
||
#define DMA_MODE_SEL_UART_TX (1<<2)
|
||
#define DMA_MODE_SEL_PWM0 (2<<2)
|
||
#define DMA_DODE_SEL_PWM1 (3<<2)
|
||
#define DMA_MODE_SEL_LSSPI_RX (4<<2)
|
||
#define DMA_MODE_SEL_LSSPI_TX (5<<2)
|
||
#define DMA_MODE_SEL_SDADC_CH0 (6<<2)
|
||
#define DMA_MODE_SEL_SDADC_CH1 (7<<2)
|
||
#define DMA_MODE_SEL_SDADC_CH2 (8<<2)
|
||
#define DMA_MODE_SEL_SDADC_CH3 (9<<2)
|
||
#define DMA_MODE_SEL_I2S_RX (10<<2)
|
||
#define DMA_MODE_SEL_I2S_TX (11<<2)
|
||
#define DMA_MODE_SEL_SDIOHOST (12<<2)
|
||
|
||
#define DMA_MODE_CHAIN_LINK_EN (1<<6)
|
||
|
||
#define DMA_CTRL_AUTO_RELOAD (1<<0)
|
||
#define DMA_CTRL_SRC_ADDR_INC (1<<1)
|
||
#define DMA_CTRL_SRC_ADDR_CIR (3<<1)
|
||
#define DMA_CTRL_DEST_ADDR_INC (1<<3)
|
||
#define DMA_CTRL_DEST_ADDR_CIR (3<<3)
|
||
#define DMA_CTRL_DATA_SIZE_BYTE (0<<5)
|
||
#define DMA_CTRL_DATA_SIZE_SHORT (1<<5)
|
||
#define DMA_CTRL_DATA_SIZE_WORD (2<<5)
|
||
#define DMA_CTRL_BURST_SIZE1 (0<<7)
|
||
#define DMA_CTRL_BURST_SIZE4 (1<<7)
|
||
|
||
#define DMA_CTRL_TOTAL_MASK (0xFFF<<8)
|
||
#define DMA_CTRL_TOTAL_SIZE(n) (n<<8)
|
||
|
||
/***************************************************************
|
||
* PMU Reg
|
||
***************************************************************/
|
||
#define HR_PMU_BASE_ADDR (DEVICE_BASE_ADDR + 0xD00)
|
||
#define HR_PMU_PS_CR (HR_PMU_BASE_ADDR + 0x00)
|
||
#define HR_PMU_TIMER0 (HR_PMU_BASE_ADDR + 0x04)
|
||
#define HR_PMU_TIMER1 (HR_PMU_BASE_ADDR + 0x08)
|
||
#define HR_PMU_RTC_CTRL1 (HR_PMU_BASE_ADDR + 0x0C)
|
||
#define HR_PMU_RTC_CTRL2 (HR_PMU_BASE_ADDR + 0x10)
|
||
#define HR_PMU_INTERRUPT_SRC (HR_PMU_BASE_ADDR + 0x14)
|
||
#define HR_PMU_INTERRUPT_MASK (HR_PMU_BASE_ADDR + 0x18)
|
||
#define HR_PMU_WLAN_STTS (HR_PMU_BASE_ADDR + 0x1C)
|
||
#define HR_PMU_BK_REG (HR_PMU_BASE_ADDR + 0x20)
|
||
|
||
#define PMU_TIMER0_NTERRUPT_SRC (1UL << 0)
|
||
#define PMU_TIMER1_NTERRUPT_SRC (1UL << 1)
|
||
#define PMU_GPIO_NTERRUPT_SRC (1UL << 2)
|
||
|
||
|
||
/***************************************************************
|
||
* system clock and bus clock Reg
|
||
***************************************************************/
|
||
#define HR_CLK_BASE_ADDR (DEVICE_BASE_ADDR + 0xE00)
|
||
#define HR_CLK_GATE_EN HR_CLK_BASE_ADDR
|
||
#define HR_CLK_SOFT_CLK_MASK (HR_CLK_BASE_ADDR + 0x04)
|
||
#define HR_CLK_BBP_CLT_CTRL (HR_CLK_BASE_ADDR + 0x08)
|
||
#define HR_CLK_RST_CTL (HR_CLK_BASE_ADDR + 0x0c)
|
||
#define HR_CLK_DIV_CTL (HR_CLK_BASE_ADDR + 0x10)
|
||
#define HR_CLK_SEL_CTL (HR_CLK_BASE_ADDR + 0x14)
|
||
#define HR_OSC_32K_REG (HR_CLK_BASE_ADDR + 0x14)
|
||
#define HR_CLK_I2S_CTL (HR_CLK_BASE_ADDR + 0x18)
|
||
#define HR_CLK_RST_STA (HR_CLK_BASE_ADDR + 0x1C)
|
||
|
||
/***************************************************************
|
||
* <20>ڴ<EFBFBD>ģ<EFBFBD><C4A3><EFBFBD>Ĵ<EFBFBD><C4B4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
***************************************************************/
|
||
#define HR_MEM_BASE_ADDR (DEVICE_BASE_ADDR + 0xF00)
|
||
#define HR_MEM_TXBUF_BASE_ADDR (HR_MEM_BASE_ADDR + 0x00)
|
||
#define HR_MEM_RXBUF_BASE_ADDR (HR_MEM_BASE_ADDR + 0x04)
|
||
#define HR_MEM_BUF_NUM_CFG (HR_MEM_BASE_ADDR + 0x08)
|
||
#define HR_MEM_BUF_SIZE_CFG (HR_MEM_BASE_ADDR + 0x0C)
|
||
#define HR_MEM_AGGR_CFG (HR_MEM_BASE_ADDR + 0x10)
|
||
#define HR_MEM_BUF_EN (HR_MEM_BASE_ADDR + 0x14)
|
||
|
||
/***************************************************************
|
||
* PSRAM CTRL Register
|
||
****************************************************************/
|
||
#define HR_PSRRAM_BASE_ADDR (DEVICE_BASE_ADDR + 0x2200)
|
||
#define HR_PSRAM_CTRL_ADDR (HR_PSRRAM_BASE_ADDR+ 0x00)
|
||
#define HR_PSRAM_OVERTIMER_ADDR (HR_PSRRAM_BASE_ADDR+ 0x04)
|
||
|
||
/* APB BaseAddr*/
|
||
#define HR_APB_BASE_ADDR 0x40010000
|
||
|
||
/***************************************************************
|
||
* I2C Reg
|
||
***************************************************************/
|
||
#define HR_I2C_BASE_ADDR (HR_APB_BASE_ADDR)
|
||
#define HR_I2C_PRER_LO (HR_I2C_BASE_ADDR + 0x0)
|
||
#define HR_I2C_PRER_HI (HR_I2C_BASE_ADDR + 0x04)
|
||
#define HR_I2C_CTRL (HR_I2C_BASE_ADDR + 0x08)
|
||
#define HR_I2C_TX_RX (HR_I2C_BASE_ADDR + 0x0C)
|
||
#define HR_I2C_CR_SR (HR_I2C_BASE_ADDR + 0x10)
|
||
#define HR_I2C_TXR (HR_I2C_BASE_ADDR + 0x14)
|
||
#define HR_I2C_CR (HR_I2C_BASE_ADDR + 0x18)
|
||
|
||
|
||
#define I2C_CTRL_INT_DISABLE (0x1UL<<6)
|
||
#define I2C_CTRL_ENABLE (0x1UL<<7)
|
||
|
||
#define I2C_CR_STA (0x1UL<<7)
|
||
#define I2C_CR_STO (0x1UL<<6)
|
||
#define I2C_CR_RD (0x1UL<<5)
|
||
#define I2C_CR_WR (0x1UL<<4)
|
||
#define I2C_CR_NAK (0x1UL<<3)
|
||
#define I2C_CR_IACK (0x1UL)
|
||
|
||
#define I2C_SR_NAK (0x1UL<<7)
|
||
#define I2C_SR_BUSY (0x1UL<<6)
|
||
#define I2C_SR_TIP (0x1UL<<1)
|
||
#define I2C_SR_IF (0x1UL)
|
||
|
||
|
||
/***************************************************************
|
||
* SD ADC Reg
|
||
***************************************************************/
|
||
#define HR_SD_ADC_BASE_ADDR (HR_APB_BASE_ADDR + 0x200)
|
||
#define HR_SD_ADC_RESULT_REG ((HR_SD_ADC_BASE_ADDR+0x000))
|
||
#define HR_SD_ADC_ANA_CTRL ((HR_SD_ADC_BASE_ADDR+0x004))
|
||
#define HR_SD_ADC_PGA_CTRL ((HR_SD_ADC_BASE_ADDR+0x008))
|
||
#define HR_SD_ADC_TEMP_CTRL ((HR_SD_ADC_BASE_ADDR+0x00C))
|
||
#define HR_SD_ADC_CTRL ((HR_SD_ADC_BASE_ADDR+0x010))
|
||
#define HR_SD_ADC_INT_STATUS ((HR_SD_ADC_BASE_ADDR+0x014))
|
||
#define HR_SD_ADC_CMP_VALUE ((HR_SD_ADC_BASE_ADDR+0x018))
|
||
|
||
|
||
/***************************************************************
|
||
*Low Speed SPI Reg
|
||
***************************************************************/
|
||
#define HR_SPI_BASE_ADDR (HR_APB_BASE_ADDR + 0x400)
|
||
#define HR_SPI_CHCFG_REG (HR_SPI_BASE_ADDR + 0x000)
|
||
#define HR_SPI_SPICFG_REG (HR_SPI_BASE_ADDR + 0x004)
|
||
#define HR_SPI_CLKCFG_REG (HR_SPI_BASE_ADDR + 0x008)
|
||
#define HR_SPI_MODECFG_REG (HR_SPI_BASE_ADDR + 0x00C)
|
||
#define HR_SPI_INT_MASK_REG (HR_SPI_BASE_ADDR + 0x010)
|
||
#define HR_SPI_INT_STATUS_REG (HR_SPI_BASE_ADDR + 0x014)
|
||
#define HR_SPI_STATUS_REG (HR_SPI_BASE_ADDR + 0x018)
|
||
#define HR_SPI_TIMEOUT_REG (HR_SPI_BASE_ADDR + 0x01C)
|
||
#define HR_SPI_TXDATA_REG (HR_SPI_BASE_ADDR + 0x020)
|
||
#define HR_SPI_TRANSLEN_REG (HR_SPI_BASE_ADDR + 0x024)
|
||
#define HR_SPI_SLV_XMIT_LEN_REG (HR_SPI_BASE_ADDR + 0x028)
|
||
#define HR_SPI_RXDATA_REG (HR_SPI_BASE_ADDR + 0x030)
|
||
|
||
|
||
#define SPIM_STARTADDRESS (HR_APB_BASE_ADDR + 0x400)
|
||
#define SPIM_CHCFG_REG (*(volatile unsigned int*)(SPIM_STARTADDRESS+0x000))
|
||
#define SPIM_SPICFG_REG (*(volatile unsigned int*)(SPIM_STARTADDRESS+0x004))
|
||
#define SPIM_CLKCFG_REG (*(volatile unsigned int*)(SPIM_STARTADDRESS+0x008))
|
||
#define SPIM_MODECFG_REG (*(volatile unsigned int*)(SPIM_STARTADDRESS+0x00C))
|
||
#define SPIM_INTEN_REG (*(volatile unsigned int*)(SPIM_STARTADDRESS+0x010))
|
||
#define SPIM_INTSRC_REG (*(volatile unsigned int*)(SPIM_STARTADDRESS+0x014))
|
||
#define SPIM_SPISTATUS_REG (*(volatile unsigned int*)(SPIM_STARTADDRESS+0x018))
|
||
#define SPIM_SPITIMEOUT_REG (*(volatile unsigned int*)(SPIM_STARTADDRESS+0x01C))
|
||
#define SPIM_TXDATA_REG (*(volatile unsigned int*)(SPIM_STARTADDRESS+0x020))
|
||
#define SPIM_TRANSLEN_REG (*(volatile unsigned int*)(SPIM_STARTADDRESS+0x024))
|
||
#define SPIM_RXDATA_REG (*(volatile unsigned int*)(SPIM_STARTADDRESS+0x030))
|
||
|
||
|
||
/*RSA Reg*/
|
||
#define RSA_BASE_ADDRESS 0x40000000
|
||
#define RSAXBUF (*((volatile unsigned long *) (RSA_BASE_ADDRESS + 0x0 )))
|
||
#define RSAYBUF (*((volatile unsigned long *) (RSA_BASE_ADDRESS + 0x100 )))
|
||
#define RSAMBUF (*((volatile unsigned long *) (RSA_BASE_ADDRESS + 0x200 )))
|
||
#define RSADBUF (*((volatile unsigned long *) (RSA_BASE_ADDRESS + 0x300 )))
|
||
#define RSACON (*((volatile unsigned long *) (RSA_BASE_ADDRESS + 0x400 )))
|
||
#define RSAMC (*((volatile unsigned long *) (RSA_BASE_ADDRESS + 0x404 )))
|
||
#define RSAN (*((volatile unsigned long *) (RSA_BASE_ADDRESS + 0x408 )))
|
||
|
||
|
||
|
||
/* Bits Definitions of "CH_CFG" */
|
||
#define SPI_RX_INVALID_BITS(n) ((n) << 23)
|
||
#define SPI_CLEAR_FIFOS (1U << 22)
|
||
#define SPI_CONTINUE_MODE (1U << 21)
|
||
#define SPI_RX_CHANNEL_ON (1U << 20)
|
||
#define SPI_RX_CHANNEL_OFF (0U << 20)
|
||
#define SPI_TX_CHANNEL_ON (1U << 19)
|
||
#define SPI_TX_CHANNEL_OFF (0U << 19)
|
||
#define SPI_VALID_CLKS_NUM(n) ((n) << 3)
|
||
#define SPI_CS_LOW (0U << 2)
|
||
#define SPI_CS_HIGH (1U << 2)
|
||
#define SPI_FORCE_SPI_CS_OUT (1U << 1)
|
||
#define SPI_START (1U << 0)
|
||
|
||
/* Bits Definitions of "SPI_CFG" */
|
||
#define SPI_FRAME_FORMAT_MOTO (0U << 17)
|
||
#define SPI_FRAME_FORMAT_TI (1U << 17)
|
||
#define SPI_FRAME_FORMAT_MICROWAIRE (2U << 17)
|
||
#define SPI_TX_PIN_ALWS_DRIVER (1U << 16)
|
||
#define SPI_CS_HOLD(n) ((n) << 12)
|
||
#define CS_HOLD_1_CLKS 0
|
||
#define CS_HOLD_2_CLKS 1
|
||
#define CS_HOLD_4_CLKS 2
|
||
#define CS_HOLD_8_CLKS 3
|
||
#define CS_HOLD_16_CLKS 4
|
||
#define CS_HOLD_32_CLKS 5
|
||
#define CS_HOLD_64_CLKS 6
|
||
#define CS_HOLD_127_CLKS 7
|
||
#define SPI_CS_SETUP(n) ((n) << 9)
|
||
#define CS_SETUP_1_CLKS 0
|
||
#define CS_SETUP_2_CLKS 1
|
||
#define CS_SETUP_4_CLKS 2
|
||
#define CS_SETUP_8_CLKS 3
|
||
#define CS_SETUP_16_CLKS 4
|
||
#define CS_SETUP_32_CLKS 5
|
||
#define CS_SETUP_64_CLKS 6
|
||
#define CS_SETUP_127_CLKS 7
|
||
#define SPI_DATA_OUT_DELAY(n) ((n) << 7)
|
||
#define DATA_OUT_DELAY_1_CLKS 0
|
||
#define DATA_OUT_DELAY_2_CLKS 1
|
||
#define DATA_OUT_DELAY_3_CLKS 2
|
||
#define DATA_OUT_DELAY_0_CLKS 3
|
||
#define SPI_FRAME_DELAY(n) ((n) << 4)
|
||
#define FRAME_DELAY_1_CLKS 0
|
||
#define FRAME_DELAY_2_CLKS 1
|
||
#define FRAME_DELAY_4_CLKS 2
|
||
#define FRAME_DELAY_8_CLKS 3
|
||
#define FRAME_DELAY_16_CLKS 4
|
||
#define FRAME_DELAY_32_CLKS 5
|
||
#define FRAME_DELAY_64_CLKS 6
|
||
#define FRAME_DELAY_127_CLKS 7
|
||
#define SPI_LITTLE_ENDIAN (0 << 3)
|
||
#define SPI_BIG_ENDIAN (1 << 3)
|
||
#define SPI_SET_MASTER_SLAVE(mode) ((mode) << 2)
|
||
#define SPI_MASTER 1
|
||
#define SPI_SLAVE 0
|
||
#define SPI_SET_CPHA(n) ((n) << 1)
|
||
#define SPI_SET_CPOL(n) ((n) << 0)
|
||
|
||
/* Bits Definitions of "CLK_CFG" */
|
||
#define SPI_GET_SCLK_DIVIDER(clk) ((APB_CLK)/((clk) * 2) - 1)/*In HZ*/
|
||
#define SPI_SCLK_DIVIDER(n) ((n) << 0)
|
||
|
||
/* Bits Definitions of "MODE_CFG" */
|
||
#define SPI_RX_TRIGGER_LEVEL(n) ((n) << 6)
|
||
#define SPI_TX_TRIGGER_LEVEL(n) ((n) << 2)
|
||
#define SPI_RX_DMA_ON (1 << 1)
|
||
#define SPI_RX_DMA_OFF (0 << 1)
|
||
#define SPI_TX_DMA_ON (1 << 0)
|
||
#define SPI_TX_DMA_OFF (0 << 0)
|
||
|
||
/* Bits Definitions of SPI interrupt register(SPI_INT_MASK and SPI_INT_SOURCE) */
|
||
#define SPI_INT_MASK_ALL 0xffU
|
||
#define SPI_INT_CLEAR_ALL 0xffU
|
||
#define SPI_INT_TIMEOUT (1U << 7)
|
||
#define SPI_INT_TRANSFER_DONE (1U << 6)
|
||
#define SPI_INT_RX_OVERRUN (1U << 5)
|
||
#define SPI_INT_RX_UNDERRUN (1U << 4)
|
||
#define SPI_INT_TX_OVERRUN (1U << 3)
|
||
#define SPI_INT_TX_UNDERRUN (1U << 2)
|
||
#define SPI_INT_RX_FIFO_RDY (1U << 1)
|
||
#define SPI_INT_TX_FIFO_RDY (1U << 0)
|
||
|
||
/* Bits Definitions of "SPI_STATUS" */
|
||
#define SPI_IS_BUSY(value) ((((value) & (1 << 12)) != 0) ? 1 : 0)
|
||
#define SPI_GET_RX_FIFO_CNT(value) (((value) & 0xFC0) >> 6)
|
||
#define SPI_GET_TX_FIFO_CNT(value) ((value) & 0x3F)
|
||
|
||
/* Bits Definitions of "SPI_TIMEOUT" */
|
||
#define SPI_TIMER_EN (1U << 31)
|
||
#define SPI_TIME_OUT(n) (((((n) * (APB_CLK)) / 1000) & ~(0x01U << 31)) << 0)
|
||
|
||
/***************************************************************
|
||
* UART Reg
|
||
***************************************************************/
|
||
#define HR_UART0_BASE_ADDR (HR_APB_BASE_ADDR + 0x600)
|
||
#define HR_UART1_BASE_ADDR (HR_APB_BASE_ADDR + 0x800)
|
||
#define HR_UART2_BASE_ADDR (HR_APB_BASE_ADDR + 0xA00)
|
||
#define HR_UART3_BASE_ADDR (HR_APB_BASE_ADDR + 0xC00)
|
||
#define HR_UART4_BASE_ADDR (HR_APB_BASE_ADDR + 0xE00)
|
||
|
||
#define HR_UART0_LINE_CTRL (HR_UART0_BASE_ADDR + 0x0)
|
||
#define HR_UART0_FLOW_CTRL (HR_UART0_BASE_ADDR + 0x04)
|
||
#define HR_UART0_DMA_CTRL (HR_UART0_BASE_ADDR + 0x08)
|
||
#define HR_UART0_FIFO_CTRL (HR_UART0_BASE_ADDR + 0x0C)
|
||
#define HR_UART0_BAUD_RATE_CTRL (HR_UART0_BASE_ADDR + 0x10)
|
||
#define HR_UART0_INT_MASK (HR_UART0_BASE_ADDR + 0x14)
|
||
#define HR_UART0_INT_SRC (HR_UART0_BASE_ADDR + 0x18)
|
||
#define HR_UART0_FIFO_STATUS (HR_UART0_BASE_ADDR + 0x1C)
|
||
#define HR_UART0_TX_WIN (HR_UART0_BASE_ADDR + 0x20)
|
||
#define HR_UART0_RX_WIN (HR_UART0_BASE_ADDR + 0x30)
|
||
|
||
#define HR_UART1_LINE_CTRL (HR_UART1_BASE_ADDR + 0x0)
|
||
#define HR_UART1_FLOW_CTRL (HR_UART1_BASE_ADDR + 0x04)
|
||
#define HR_UART1_DMA_CTRL (HR_UART1_BASE_ADDR + 0x08)
|
||
#define HR_UART1_FIFO_CTRL (HR_UART1_BASE_ADDR + 0x0C)
|
||
#define HR_UART1_BAUD_RATE_CTRL (HR_UART1_BASE_ADDR + 0x10)
|
||
#define HR_UART1_INT_MASK (HR_UART1_BASE_ADDR + 0x14)
|
||
#define HR_UART1_INT_SRC (HR_UART1_BASE_ADDR + 0x18)
|
||
#define HR_UART1_FIFO_STATUS (HR_UART1_BASE_ADDR + 0x1C)
|
||
#define HR_UART1_TX_WIN (HR_UART1_BASE_ADDR + 0x20)
|
||
#define HR_UART1_RX_WIN (HR_UART1_BASE_ADDR + 0x30)
|
||
|
||
#define HR_UART2_LINE_CTRL (HR_UART2_BASE_ADDR + 0x0)
|
||
#define HR_UART2_FLOW_CTRL (HR_UART2_BASE_ADDR + 0x04)
|
||
#define HR_UART2_DMA_CTRL (HR_UART2_BASE_ADDR + 0x08)
|
||
#define HR_UART2_FIFO_CTRL (HR_UART2_BASE_ADDR + 0x0C)
|
||
#define HR_UART2_BAUD_RATE_CTRL (HR_UART2_BASE_ADDR + 0x10)
|
||
#define HR_UART2_INT_MASK (HR_UART2_BASE_ADDR + 0x14)
|
||
#define HR_UART2_INT_SRC (HR_UART2_BASE_ADDR + 0x18)
|
||
#define HR_UART2_FIFO_STATUS (HR_UART2_BASE_ADDR + 0x1C)
|
||
#define HR_UART2_TX_WIN (HR_UART2_BASE_ADDR + 0x20)
|
||
#define HR_UART2_RX_WIN (HR_UART2_BASE_ADDR + 0x30)
|
||
#define HR_UART2_GUARD_TIME (HR_UART2_BASE_ADDR + 0x40)
|
||
#define HR_UART2_WAIT_TIME (HR_UART2_BASE_ADDR + 0x44)
|
||
#define HR_UART2_GT (HR_UART2_BASE_ADDR + 0x40)
|
||
#define HR_UART2_WT (HR_UART2_BASE_ADDR + 0x44)
|
||
|
||
#define HR_UART3_LINE_CTRL (HR_UART3_BASE_ADDR + 0x0)
|
||
#define HR_UART3_FLOW_CTRL (HR_UART3_BASE_ADDR + 0x04)
|
||
#define HR_UART3_DMA_CTRL (HR_UART3_BASE_ADDR + 0x08)
|
||
#define HR_UART3_FIFO_CTRL (HR_UART3_BASE_ADDR + 0x0C)
|
||
#define HR_UART3_BAUD_RATE_CTRL (HR_UART3_BASE_ADDR + 0x10)
|
||
#define HR_UART3_INT_MASK (HR_UART3_BASE_ADDR + 0x14)
|
||
#define HR_UART3_INT_SRC (HR_UART3_BASE_ADDR + 0x18)
|
||
#define HR_UART3_FIFO_STATUS (HR_UART3_BASE_ADDR + 0x1C)
|
||
#define HR_UART3_TX_WIN (HR_UART3_BASE_ADDR + 0x20)
|
||
#define HR_UART3_RX_WIN (HR_UART3_BASE_ADDR + 0x30)
|
||
|
||
#define HR_UART4_LINE_CTRL (HR_UART4_BASE_ADDR + 0x0)
|
||
#define HR_UART4_FLOW_CTRL (HR_UART4_BASE_ADDR + 0x04)
|
||
#define HR_UART4_DMA_CTRL (HR_UART4_BASE_ADDR + 0x08)
|
||
#define HR_UART4_FIFO_CTRL (HR_UART4_BASE_ADDR + 0x0C)
|
||
#define HR_UART4_BAUD_RATE_CTRL (HR_UART4_BASE_ADDR + 0x10)
|
||
#define HR_UART4_INT_MASK (HR_UART4_BASE_ADDR + 0x14)
|
||
#define HR_UART4_INT_SRC (HR_UART4_BASE_ADDR + 0x18)
|
||
#define HR_UART4_FIFO_STATUS (HR_UART4_BASE_ADDR + 0x1C)
|
||
#define HR_UART4_TX_WIN (HR_UART4_BASE_ADDR + 0x20)
|
||
#define HR_UART4_RX_WIN (HR_UART4_BASE_ADDR + 0x30)
|
||
|
||
/*
|
||
* Line Control Register bits definition
|
||
* ULCON0 ULCON1 Register
|
||
*/
|
||
/* bit 0-1 : Word length */
|
||
#define ULCON_WL5 0x00
|
||
#define ULCON_WL6 0x01
|
||
#define ULCON_WL7 0x02
|
||
#define ULCON_WL8 0x03
|
||
#define ULCON_WL_MASK 0x03
|
||
/* bit 2 : Number of stop bits */
|
||
#define ULCON_STOP_2 0x04 /* 2 stop bit */
|
||
/* bit 3-4 : Parity mode */
|
||
#define ULCON_PMD_MASK 0x18
|
||
#define ULCON_PMD_EN 0x08 /* no parity */
|
||
#define ULCON_PMD_ODD 0x18 /* odd parity */
|
||
#define ULCON_PMD_EVEN 0x08 /* even parity */
|
||
/* bit 6 uart tx enable */
|
||
#define ULCON_TX_EN 0x40
|
||
#define ULCON_RX_EN 0x80
|
||
/* bit 6 : Infra-red mode */
|
||
#define ULCON_INFRA_RED 0x80
|
||
|
||
/*
|
||
* auto flow control register bits definition
|
||
*/
|
||
#define UFC_ENABLE 0x01
|
||
#define UFC_SW_RTS_SET 0x02
|
||
#define UFC_RTS_TRIGGER_LVL_4_BYTE (0<<2)
|
||
#define UFC_RTS_TRIGGER_LVL_8_BYTE (1<<2)
|
||
#define UFC_RTS_TRIGGER_LVL_12_BYTE (2<<2)
|
||
#define UFC_RTS_TRIGGER_LVL_16_BYTE (3<<2)
|
||
#define UFC_RTS_TRIGGER_LVL_20_BYTE (4<<2)
|
||
#define UFC_RTS_TRIGGER_LVL_24_BYTE (5<<2)
|
||
#define UFC_RTS_TRIGGER_LVL_28_BYTE (6<<2)
|
||
#define UFC_RTS_TRIGGER_LVL_31_BYTE (7<<2)
|
||
|
||
#define UFC_TX_FIFO_RESET 0x01
|
||
#define UFC_RX_FIFO_RESET 0x02
|
||
#define UFC_TX_FIFO_LVL_ZERO (0<<2)
|
||
#define UFC_TX_FIFO_LVL_4_BYTE (1<<2)
|
||
#define UFC_TX_FIFO_LVL_8_BYTE (2<<2)
|
||
#define UFC_TX_FIFO_LVL_16_BYTE (3<<2)
|
||
#define UFC_RX_FIFO_LVL_ZERO (0<<4)
|
||
#define UFC_RX_FIFO_LVL_4_BYTE (1<<4)
|
||
#define UFC_RX_FIFO_LVL_8_BYTE (2<<4)
|
||
#define UFC_RX_FIFO_LVL_16_BYTE (3<<4)
|
||
|
||
/* dma control */
|
||
#define UDMA_RX_FIFO_TIMEOUT (1<<2)
|
||
#define UDMA_RX_FIFO_TIMEOUT_SHIFT (3)
|
||
|
||
/*
|
||
* uart interrupt source register bits definition
|
||
*/
|
||
#define UIS_TX_FIFO_EMPTY (1UL<<0)
|
||
#define UIS_TX_FIFO (1UL<<1)
|
||
#define UIS_RX_FIFO (1UL<<2)
|
||
#define UIS_RX_FIFO_TIMEOUT (1UL<<3)
|
||
#define UIS_CTS_CHNG (1UL<<4)
|
||
#define UIS_BREAK (1UL<<5)
|
||
#define UIS_FRM_ERR (1UL<<6)
|
||
#define UIS_PARITY_ERR (1UL<<7)
|
||
#define UIS_OVERRUN (1UL<<8)
|
||
|
||
/*
|
||
* fifo status register bits definition
|
||
*/
|
||
/* bit 0-5 : tx fifo count */
|
||
#define UFS_TX_FIFO_CNT_MASK 0x3F
|
||
/* bit 6-11 : rx fifo count */
|
||
#define UFS_RX_FIFO_CNT_MASK 0x3C0
|
||
#define UFS_CST_STS (1UL<<12)
|
||
|
||
/***************************************************************
|
||
* GPIO Reg
|
||
***************************************************************/
|
||
#define HR_GPIO_BASE_ADDR (HR_APB_BASE_ADDR + 0x1200)
|
||
#define HR_GPIO_DATA (HR_GPIO_BASE_ADDR + 0x0)
|
||
#define HR_GPIO_DATA_EN (HR_GPIO_BASE_ADDR + 0x04)
|
||
#define HR_GPIO_DIR (HR_GPIO_BASE_ADDR + 0x08)
|
||
#define HR_GPIO_PULLUP_EN (HR_GPIO_BASE_ADDR + 0x0C)
|
||
#define HR_GPIO_AF_SEL (HR_GPIO_BASE_ADDR + 0x10)
|
||
#define HR_GPIO_AF_S1 (HR_GPIO_BASE_ADDR + 0x14)
|
||
#define HR_GPIO_AF_S0 (HR_GPIO_BASE_ADDR + 0x18)
|
||
#define HR_GPIO_PULLDOWN_EN (HR_GPIO_BASE_ADDR + 0x1C)
|
||
#define HR_GPIO_IS (HR_GPIO_BASE_ADDR + 0x20)
|
||
#define HR_GPIO_IBE (HR_GPIO_BASE_ADDR + 0x24)
|
||
#define HR_GPIO_IEV (HR_GPIO_BASE_ADDR + 0x28)
|
||
#define HR_GPIO_IE (HR_GPIO_BASE_ADDR + 0x2c)
|
||
#define HR_GPIO_RIS (HR_GPIO_BASE_ADDR + 0x30)
|
||
#define HR_GPIO_MIS (HR_GPIO_BASE_ADDR + 0x34)
|
||
#define HR_GPIO_IC (HR_GPIO_BASE_ADDR + 0x38)
|
||
|
||
#define HR_GPIOA_BASE_ADDR (HR_APB_BASE_ADDR + 0x1200)
|
||
#define HR_GPIOA_DATA (HR_GPIOA_BASE_ADDR + 0x0)
|
||
#define HR_GPIOA_DATA_EN (HR_GPIOA_BASE_ADDR + 0x04)
|
||
#define HR_GPIOA_DATA_DIR (HR_GPIOA_BASE_ADDR + 0x08)
|
||
#define HR_GPIOA_DATA_PULLEN (HR_GPIOA_BASE_ADDR + 0x0c)
|
||
#define HR_GPIOA_AFSEL (HR_GPIOA_BASE_ADDR + 0x10)
|
||
#define HR_GPIOA_AFS1 (HR_GPIOA_BASE_ADDR + 0x14)
|
||
#define HR_GPIOA_AFS0 (HR_GPIOA_BASE_ADDR + 0x18)
|
||
#define HR_GPIOA_IS (HR_GPIOA_BASE_ADDR + 0x20)
|
||
#define HR_GPIOA_IBE (HR_GPIOA_BASE_ADDR + 0x24)
|
||
#define HR_GPIOA_IEV (HR_GPIOA_BASE_ADDR + 0x28)
|
||
#define HR_GPIOA_IE (HR_GPIOA_BASE_ADDR + 0x2C)
|
||
#define HR_GPIOA_RIS (HR_GPIOA_BASE_ADDR + 0x30)
|
||
#define HR_GPIOA_MIS (HR_GPIOA_BASE_ADDR + 0x34)
|
||
#define HR_GPIOA_IC (HR_GPIOA_BASE_ADDR + 0x38)
|
||
|
||
#define HR_GPIOB_BASE_ADDR (HR_APB_BASE_ADDR + 0x1400)
|
||
#define HR_GPIOB_DATA (HR_GPIOB_BASE_ADDR + 0x0)
|
||
#define HR_GPIOB_DATA_EN (HR_GPIOB_BASE_ADDR + 0x04)
|
||
#define HR_GPIOB_DATA_DIR (HR_GPIOB_BASE_ADDR + 0x08)
|
||
#define HR_GPIOB_DATA_PULLEN (HR_GPIOB_BASE_ADDR + 0x0c)
|
||
#define HR_GPIOB_AFSEL (HR_GPIOB_BASE_ADDR + 0x10)
|
||
#define HR_GPIOB_AFS1 (HR_GPIOB_BASE_ADDR + 0x14)
|
||
#define HR_GPIOB_AFS0 (HR_GPIOB_BASE_ADDR + 0x18)
|
||
#define HR_GPIOB_IS (HR_GPIOB_BASE_ADDR + 0x20)
|
||
#define HR_GPIOB_IBE (HR_GPIOB_BASE_ADDR + 0x24)
|
||
#define HR_GPIOB_IEV (HR_GPIOB_BASE_ADDR + 0x28)
|
||
#define HR_GPIOB_IE (HR_GPIOB_BASE_ADDR + 0x2C)
|
||
#define HR_GPIOB_RIS (HR_GPIOB_BASE_ADDR + 0x30)
|
||
#define HR_GPIOB_MIS (HR_GPIOB_BASE_ADDR + 0x34)
|
||
#define HR_GPIOB_IC (HR_GPIOB_BASE_ADDR + 0x38)
|
||
|
||
|
||
#define IO_PA_BASE_ADDR (HR_APB_BASE_ADDR + 0x1200)
|
||
#define IO_PA_DATA (*(volatile unsigned int*)(IO_PA_BASE_ADDR + 0x0))
|
||
#define IO_PA_EN (*(volatile unsigned int*)(IO_PA_BASE_ADDR + 0x4))
|
||
#define IO_PA_DIR (*(volatile unsigned int*)(IO_PA_BASE_ADDR + 0x8))
|
||
#define IO_PA_REN (*(volatile unsigned int*)(IO_PA_BASE_ADDR + 0xC))
|
||
#define IO_PA_AFSEL (*(volatile unsigned int*)(IO_PA_BASE_ADDR + 0x10))
|
||
#define IO_PA_AFS1 (*(volatile unsigned int*)(IO_PA_BASE_ADDR + 0x14))
|
||
#define IO_PA_AFS0 (*(volatile unsigned int*)(IO_PA_BASE_ADDR + 0x18))
|
||
|
||
#define IO_PB_BASE_ADDR (HR_APB_BASE_ADDR + 0x1400)
|
||
#define IO_PB_DATA (*(volatile unsigned int*)(IO_PB_BASE_ADDR + 0x0))
|
||
#define IO_PB_EN (*(volatile unsigned int*)(IO_PB_BASE_ADDR + 0x4))
|
||
#define IO_PB_DIR (*(volatile unsigned int*)(IO_PB_BASE_ADDR + 0x8))
|
||
#define IO_PB_REN (*(volatile unsigned int*)(IO_PB_BASE_ADDR + 0xC))
|
||
#define IO_PB_AFSEL (*(volatile unsigned int*)(IO_PB_BASE_ADDR + 0x10))
|
||
#define IO_PB_AFS1 (*(volatile unsigned int*)(IO_PB_BASE_ADDR + 0x14))
|
||
#define IO_PB_AFS0 (*(volatile unsigned int*)(IO_PB_BASE_ADDR + 0x18))
|
||
|
||
/***************************************************************
|
||
* TIMER Reg
|
||
***************************************************************/
|
||
#define HR_TIMER_BASE_ADDR (HR_APB_BASE_ADDR + 0x1800)
|
||
#define HR_TIMER_CFG (HR_TIMER_BASE_ADDR + 0x0)
|
||
#define HR_TIMER0_5_CSR (HR_TIMER_BASE_ADDR + 0x04)
|
||
#define HR_TIMER0_PRD (HR_TIMER_BASE_ADDR + 0x08)
|
||
#define HR_TIMER1_PRD (HR_TIMER_BASE_ADDR + 0x0C)
|
||
#define HR_TIMER2_PRD (HR_TIMER_BASE_ADDR + 0x10)
|
||
#define HR_TIMER3_PRD (HR_TIMER_BASE_ADDR + 0x14)
|
||
#define HR_TIMER4_PRD (HR_TIMER_BASE_ADDR + 0x18)
|
||
#define HR_TIMER5_PRD (HR_TIMER_BASE_ADDR + 0x1C)
|
||
#define HR_TIMER0_CNT (HR_TIMER_BASE_ADDR + 0x20)
|
||
#define HR_TIMER1_CNT (HR_TIMER_BASE_ADDR + 0x24)
|
||
#define HR_TIMER2_CNT (HR_TIMER_BASE_ADDR + 0x28)
|
||
#define HR_TIMER3_CNT (HR_TIMER_BASE_ADDR + 0x2C)
|
||
#define HR_TIMER4_CNT (HR_TIMER_BASE_ADDR + 0x30)
|
||
#define HR_TIMER5_CNT (HR_TIMER_BASE_ADDR + 0x34)
|
||
|
||
/* timer csr bits defintion */
|
||
#define TLS_TIMER_MS_UNIT(n) (1UL<<(0+5*n))
|
||
#define TLS_TIMER_ONE_TIME(n) (1UL<<(1+5*n))
|
||
#define TLS_TIMER_EN(n) (1UL<<(2+5*n))
|
||
#define TLS_TIMER_INT_EN(n) (1UL<<(3+5*n))
|
||
#define TLS_TIMER_INT_CLR(n) (1UL<<(4+5*n))
|
||
|
||
/***************************************************************
|
||
* WATCH DOG Reg
|
||
***************************************************************/
|
||
#define HR_WDG_BASE_ADDR (HR_APB_BASE_ADDR + 0x1600)
|
||
#define HR_WDG_LOAD_VALUE (HR_WDG_BASE_ADDR + 0x00)
|
||
#define HR_WDG_CUR_VALUE (HR_WDG_BASE_ADDR + 0x04)
|
||
#define HR_WDG_CTRL (HR_WDG_BASE_ADDR + 0x08)
|
||
#define HR_WDG_INT_CLR (HR_WDG_BASE_ADDR + 0x0C)
|
||
#define HR_WDG_INT_SRC (HR_WDG_BASE_ADDR + 0x10)
|
||
#define HR_WDG_INT_MIS (HR_WDG_BASE_ADDR + 0x14)
|
||
#define HR_WDG_LOCK (HR_WDG_BASE_ADDR + 0x40)
|
||
|
||
/** bit field of the lcd gate control in CLK gating register */
|
||
#define HR_CLK_LCD_GATE_Pos (14)
|
||
|
||
/***********************************************************//**
|
||
* LCD Reg
|
||
***************************************************************/
|
||
|
||
#define HR_LCD_REG_BASE (HR_APB_BASE_ADDR + 0x1C00) //(0x4001 1C00)
|
||
#define HR_LCD_CR (HR_LCD_REG_BASE+0x000)
|
||
#define HR_LCD_FRAME_CNT (HR_LCD_REG_BASE+0x004)
|
||
#define HR_LCD_COM0_SEG (HR_LCD_REG_BASE+0x008)
|
||
#define HR_LCD_COM1_SEG (HR_LCD_REG_BASE+0x00C)
|
||
#define HR_LCD_COM2_SEG (HR_LCD_REG_BASE+0x010)
|
||
#define HR_LCD_COM3_SEG (HR_LCD_REG_BASE+0x014)
|
||
#define HR_LCD_COM4_SEG (HR_LCD_REG_BASE+0x018)
|
||
#define HR_LCD_COM5_SEG (HR_LCD_REG_BASE+0x01C)
|
||
#define HR_LCD_COM6_SEG (HR_LCD_REG_BASE+0x020)
|
||
#define HR_LCD_COM7_SEG (HR_LCD_REG_BASE+0x024)
|
||
#define HR_LCD_COM_EN (HR_LCD_REG_BASE+0x028)
|
||
#define HR_LCD_SEG_EN (HR_LCD_REG_BASE+0x02C)
|
||
|
||
#define LCD_CR_EN_Pos (8)
|
||
#define LCD_CR_PD_Pos (9)
|
||
|
||
#define LCD_VDD_ON (1UL<<9)
|
||
#define LCD_VDD_OFF (0UL<<9)
|
||
#define LCD_EN (1UL<<8)
|
||
|
||
#define LCD_BIAS_MASK (3UL<<6)
|
||
#define LCD_BIAS_MASK_Pos (6)
|
||
#define LCD_BIAS_ONEFOURTH (0UL<<6)
|
||
#define LCD_BIAS_ONEHALF (1UL<<6)
|
||
#define LCD_BIAS_ONETHIRD (2UL<<6)
|
||
#define LCD_BIAS_STATIC (3UL<<6)
|
||
|
||
#define LCD_VLCD_MASK (7UL<<3)
|
||
#define LCD_VLCD_MASK_Pos (3)
|
||
#define LCD_VLCD_27 (0UL<<3)
|
||
#define LCD_VLCD_29 (1UL<<3)
|
||
#define LCD_VLCD_31 (2UL<<3)
|
||
#define LCD_VLCD_33 (3UL<<3)
|
||
|
||
#define LCD_DUTY_MASK (7UL<<0)
|
||
#define LCD_DUTY_MASK_Pos (0)
|
||
#define LCD_DUTY_STATIC (0UL<<0)
|
||
#define LCD_DUTY_ONEHALF (1UL<<0)
|
||
#define LCD_DUTY_ONETHIRD (2UL<<0)
|
||
#define LCD_DUTY_ONEFOURTH (3UL<<0)
|
||
#define LCD_DUTY_ONEFIFTH (4UL<<0)
|
||
#define LCD_DUTY_ONESIXTH (5UL<<0)
|
||
#define LCD_DUTY_ONESEVENTH (6UL<<0)
|
||
#define LCD_DUTY_ONEEIGHTH (7UL<<0)
|
||
|
||
/***********************************************************//**
|
||
* I2S Reg
|
||
***************************************************************/
|
||
#define HR_CLK_I2S_GATE_Pos (10)
|
||
|
||
|
||
#define HR_I2S_REG_BASE (HR_APB_BASE_ADDR+0x2000)
|
||
#define HR_I2S_CTRL (HR_I2S_REG_BASE+0x000)
|
||
#define HR_I2S_INT_MASK (HR_I2S_REG_BASE+0x004)
|
||
#define HR_I2S_INT_SRC (HR_I2S_REG_BASE+0x008)
|
||
#define HR_I2S_STATUS (HR_I2S_REG_BASE+0x00C)
|
||
#define HR_I2S_TX (HR_I2S_REG_BASE+0x010)
|
||
#define HR_I2S_RX (HR_I2S_REG_BASE+0x014)
|
||
|
||
/*****************************************************************/
|
||
/* APB2SPI modem spi access register definition(BT) */
|
||
/*****************************************************************/
|
||
#define APB2SPI_REG_BASE (HR_APB_BASE_ADDR+ 0x2200)
|
||
#define APB2SPI_REG_CFG (APB2SPI_REG_BASE+ 0x0000)
|
||
#define APB2SPI_REG_PS_CR (APB2SPI_REG_BASE+ 0x0004)
|
||
#define APB2SPI_REG_TX_DATA (APB2SPI_REG_BASE+ 0x0008)
|
||
#define APB2SPI_REG_RX_DATA (APB2SPI_REG_BASE+ 0x000C)
|
||
|
||
/******************************************************************************/
|
||
/* */
|
||
/* PWM */
|
||
/* */
|
||
/******************************************************************************/
|
||
#define HR_PWM_REG_BASE (HR_APB_BASE_ADDR+0x1E00)
|
||
#define HR_PWM_CLKDIV01 (HR_PWM_REG_BASE+0x0000)
|
||
#define HR_PWM_CLKDIV23 (HR_PWM_REG_BASE+0x0004)
|
||
#define HR_PWM_CTL (HR_PWM_REG_BASE+0x0008)
|
||
#define HR_PWM_PERIOD (HR_PWM_REG_BASE+0x000C)
|
||
#define HR_PWM_PNUM (HR_PWM_REG_BASE+0x0010)
|
||
#define HR_PWM_CMPDAT (HR_PWM_REG_BASE+0x0014)
|
||
#define HR_PWM_DTCTL (HR_PWM_REG_BASE+0x0018)
|
||
#define HR_PWM_INTEN (HR_PWM_REG_BASE+0x001C)
|
||
#define HR_PWM_INTSTS (HR_PWM_REG_BASE+0x0020)
|
||
#define HR_PWM_CAPDAT (HR_PWM_REG_BASE+0x0024)
|
||
#define HR_PWM_BRKCTL (HR_PWM_REG_BASE+0x0028)
|
||
#define HR_PWM_CH4_REG1 (HR_PWM_REG_BASE+0x002C)
|
||
#define HR_PWM_CH4_REG2 (HR_PWM_REG_BASE+0x0030)
|
||
#define HR_PWM_CAP2DAT (HR_PWM_REG_BASE+0x0034)
|
||
#define HR_PWM_CAP2CTL (HR_PWM_REG_BASE+0x0038)
|
||
|
||
|
||
/******************************************************************************/
|
||
/* */
|
||
/* TOUCH SENSOR */
|
||
/* */
|
||
/******************************************************************************/
|
||
#define HR_TC_REG_BASE (HR_APB_BASE_ADDR+0x2400)
|
||
|
||
#define HR_TC_CONFIG (HR_TC_REG_BASE+0x0000)
|
||
#define SCAN_PERID_SHIFT_BIT (26)
|
||
#define CAPDET_CNT_SHIFT_BIT (20)
|
||
#define TOUCH_SENSOR_SEL_SHIFT_BIT (4)
|
||
#define TOUCH_SENSOR_EN_BIT (0)
|
||
|
||
#define HR_TC1_TRESHOLD_REG (HR_TC_REG_BASE+0x0004)
|
||
#define HR_TC1_COUNT_REG (HR_TC_REG_BASE+0x0004)
|
||
|
||
#define HR_TC2_TRESHOLD_REG (HR_TC_REG_BASE+0x0008)
|
||
#define HR_TC2_COUNT_REG (HR_TC_REG_BASE+0x0008)
|
||
|
||
#define HR_TC3_TRESHOLD_REG (HR_TC_REG_BASE+0x000C)
|
||
#define HR_TC3_COUNT_REG (HR_TC_REG_BASE+0x000C)
|
||
|
||
#define HR_TC4_TRESHOLD_REG (HR_TC_REG_BASE+0x0010)
|
||
#define HR_TC4_COUNT_REG (HR_TC_REG_BASE+0x0010)
|
||
|
||
#define HR_TC5_TRESHOLD_REG (HR_TC_REG_BASE+0x0014)
|
||
#define HR_TC5_COUNT_REG (HR_TC_REG_BASE+0x0014)
|
||
|
||
#define HR_TC6_TRESHOLD_REG (HR_TC_REG_BASE+0x0018)
|
||
#define HR_TC6_COUNT_REG (HR_TC_REG_BASE+0x0018)
|
||
|
||
#define HR_TC7_TRESHOLD_REG (HR_TC_REG_BASE+0x001C)
|
||
#define HR_TC7_COUNT_REG (HR_TC_REG_BASE+0x001C)
|
||
|
||
#define HR_TC8_TRESHOLD_REG (HR_TC_REG_BASE+0x0020)
|
||
#define HR_TC8_COUNT_REG (HR_TC_REG_BASE+0x0020)
|
||
|
||
#define HR_TC9_TRESHOLD_REG (HR_TC_REG_BASE+0x0024)
|
||
#define HR_TC9_COUNT_REG (HR_TC_REG_BASE+0x0024)
|
||
|
||
#define HR_TC10_TRESHOLD_REG (HR_TC_REG_BASE+0x0028)
|
||
#define HR_TC10_COUNT_REG (HR_TC_REG_BASE+0x0028)
|
||
|
||
#define HR_TC11_TRESHOLD_REG (HR_TC_REG_BASE+0x002C)
|
||
#define HR_TC11_COUNT_REG (HR_TC_REG_BASE+0x002C)
|
||
|
||
#define HR_TC12_TRESHOLD_REG (HR_TC_REG_BASE+0x0030)
|
||
#define HR_TC12_COUNT_REG (HR_TC_REG_BASE+0x0030)
|
||
|
||
#define HR_TC13_TRESHOLD_REG (HR_TC_REG_BASE+0x0034)
|
||
#define HR_TC13_COUNT_REG (HR_TC_REG_BASE+0x0034)
|
||
|
||
#define HR_TC14_TRESHOLD_REG (HR_TC_REG_BASE+0x0038)
|
||
#define HR_TC14_COUNT_REG (HR_TC_REG_BASE+0x0038)
|
||
|
||
#define HR_TC15_TRESHOLD_REG (HR_TC_REG_BASE+0x003C)
|
||
#define HR_TC15_COUNT_REG (HR_TC_REG_BASE+0x003C)
|
||
|
||
#define HR_TC16_TRESHOLD_REG (HR_TC_REG_BASE+0x0040)
|
||
#define HR_TC16_COUNT_REG (HR_TC_REG_BASE+0x0040)
|
||
|
||
#define HR_TC_INT_EN (HR_TC_REG_BASE+0x0044) /*bit 31:16*/
|
||
#define HR_TC_INT_STATUS (HR_TC_REG_BASE+0x0044) /*bit 15:0*/
|
||
|
||
|
||
/**
|
||
* @defgroup System_APIs System APIs
|
||
* @brief System APIs
|
||
*/
|
||
|
||
/**
|
||
* @addtogroup System_APIs
|
||
* @{
|
||
*/
|
||
|
||
/**
|
||
* @defgroup REG_APIs REG APIs
|
||
* @brief Register operate APIs
|
||
*/
|
||
|
||
/**
|
||
* @addtogroup REG_APIs
|
||
* @{
|
||
*/
|
||
|
||
/**
|
||
* @brief This function is used to write value to register or memory
|
||
*
|
||
* @param[in] reg address to be written
|
||
* @param[in] val value to write
|
||
*
|
||
* @return None
|
||
*
|
||
* @note None
|
||
*/
|
||
static __inline void tls_reg_write32(unsigned int reg, unsigned int val)
|
||
{
|
||
*(TLS_REG *)reg = val;
|
||
}
|
||
|
||
|
||
/**
|
||
* @brief This function is used to read value from register or memory
|
||
*
|
||
* @param[in] reg address to read
|
||
*
|
||
* @retval val read from register or memory
|
||
*
|
||
* @note None
|
||
*/
|
||
static __inline unsigned int tls_reg_read32(unsigned int reg)
|
||
{
|
||
unsigned int val = *(TLS_REG *)reg;
|
||
return val;
|
||
}
|
||
|
||
|
||
/**
|
||
* @brief This function is used to write specified bit through
|
||
bit-band alias region
|
||
*
|
||
* @param[in] addr 32-bit aligned byte address where the bit exists.
|
||
* @param[in] bit Bit position.
|
||
* @param[in] val The value that the bit is set to, 0 or 1.
|
||
*
|
||
* @return None
|
||
*
|
||
* @note Only when bit-band mechnism is supported, you can use it
|
||
*/
|
||
static __inline void tls_bitband_write(volatile unsigned int addr, unsigned int bit, unsigned int val)
|
||
{
|
||
unsigned int temp;
|
||
|
||
temp = (M32(addr) & ~(1 << bit)) | (val << bit);
|
||
|
||
*((volatile unsigned int * )addr) = temp;
|
||
}
|
||
|
||
/**
|
||
* @brief This function is used to read a single bit from address
|
||
by bit-band alias region
|
||
*
|
||
* @param[in] addr 32-bit aligned byte address where the bit exists
|
||
* @param[in] bit Bit position
|
||
*
|
||
* @retval The value of the requested bit
|
||
*
|
||
* @note Only when bit-band mechnism is supported, you can use it
|
||
*/
|
||
static __inline unsigned int tls_bitband_read(volatile unsigned int addr, unsigned int bit)
|
||
{
|
||
unsigned int temp;
|
||
|
||
temp = (M32(addr) >> bit) & 0x1;
|
||
|
||
return *((volatile unsigned int *)temp);
|
||
}
|
||
|
||
|
||
/**
|
||
* @}
|
||
*/
|
||
|
||
/**
|
||
* @}
|
||
*/
|
||
|
||
#endif /* WM_REGS_H */
|
||
|