bl602: Update register defines and drivers

This commit is contained in:
Brennan Ashton 2020-12-27 10:53:42 -08:00 committed by Xiang Xiao
parent 1473768ffc
commit e062bd08ce
45 changed files with 7734 additions and 7717 deletions

View File

@ -18,26 +18,6 @@ config BL602_UART0
bool
default n
config BL602_UART0_TX_PIN
int "UART0 tx pin num"
default 16
depends on BL602_UART0
config BL602_UART0_RX_PIN
int "UART0 rx pin num"
default 7
depends on BL602_UART0
config BL602_UART0_RTS_PIN
int "UART0 rts pin num"
default -1
depends on BL602_UART0
config BL602_UART0_CTS_PIN
int "UART0 cts pin num"
default -1
depends on BL602_UART0
config BL602_HAVE_UART1
bool "UART1"
select BL602_UART1
@ -48,26 +28,6 @@ config BL602_HAVE_UART1
config BL602_UART1
bool
default n
config BL602_UART1_TX_PIN
int "UART1 tx pin num"
default 4
depends on BL602_UART1
config BL602_UART1_RX_PIN
int "UART1 rx pin num"
default 3
depends on BL602_UART1
config BL602_UART1_RTS_PIN
int "UART1 rts pin num"
default -1
depends on BL602_UART1
config BL602_UART1_CTS_PIN
int "UART1 cts pin num"
default -1
depends on BL602_UART1
config BL602_TIMER0
bool "TIMER0"

View File

@ -33,22 +33,15 @@
/* Partition table error type definition */
#define PT_ERROR_SUCCESS 0 /* Partition table error type:success */
#define PT_ERROR_TABLE_NOT_VALID \
1 /* Partition table error type:entry not found */
#define PT_ERROR_ENTRY_NOT_FOUND \
2 /* Partition table error type:entry not found */
#define PT_ERROR_ENTRY_UPDATE_FAIL \
3 /* Partition table error type:entry update fail */
#define PT_ERROR_CRC32 4 /* Partition table error type:crc32 error */
#define PT_ERROR_PARAMETER \
5 /* Partition table error type:input parameter error */
#define PT_ERROR_FALSH_READ \
6 /* Partition table error type:flash read error */
#define PT_ERROR_FALSH_WRITE \
7 /* Partition table error type:flash write error */
#define PT_ERROR_FALSH_ERASE \
8 /* Partition table error type:flash erase error */
#define PT_ERROR_SUCCESS 0 /* Success */
#define PT_ERROR_TABLE_NOT_VALID 1 /* Table not valid */
#define PT_ERROR_ENTRY_NOT_FOUND 2 /* Entry not found */
#define PT_ERROR_ENTRY_UPDATE_FAIL 3 /* Entry update fail */
#define PT_ERROR_CRC32 4 /* CRC32 error */
#define PT_ERROR_PARAMETER 5 /* Input parameter error */
#define PT_ERROR_FALSH_READ 6 /* Flash read error */
#define PT_ERROR_FALSH_WRITE 7 /* Flash write error */
#define PT_ERROR_FALSH_ERASE 8 /* Flash erase error */
/* Partition id type definition */
@ -70,10 +63,10 @@
/* Partition table config definition */
struct pt_table_config_s
struct pt_config_s
{
uint32_t magic_code; /* Partition table magic code */
uint16_t version; /* Partition table verdion */
uint16_t version; /* Partition table version */
uint16_t entry_cnt; /* Partition table entry count */
uint32_t age; /* Partition table age */
uint32_t crc32; /* Partition table CRC32 value */
@ -81,7 +74,7 @@ struct pt_table_config_s
/* Partition table entry config definition */
struct pt_table_entry_config_s
struct pt_entry_config_s
{
uint8_t type; /* Partition entry type */
uint8_t device; /* Partition entry device */
@ -95,12 +88,11 @@ struct pt_table_entry_config_s
/* Partition table stuff config definition */
struct pt_table_stuff_config_s
struct pt_stuff_config_s
{
struct pt_table_config_s pt_table; /* Partition table */
struct pt_table_entry_config_s
pt_entries[PT_ENTRY_MAX]; /* Partition entries */
uint32_t crc32; /* Partition entries crc32 */
struct pt_config_s table; /* Partition table */
struct pt_entry_config_s entries[PT_ENTRY_MAX]; /* Entries */
uint32_t crc32; /* Entries crc32 */
};
#endif /* __ASSEMBLY__ */

View File

@ -22,87 +22,52 @@
* Included Files
****************************************************************************/
#include "hardware/bl602_glb.h"
#include <nuttx/config.h>
#include <stdint.h>
#include "riscv_arch.h"
#include "hardware/bl602_glb.h"
/****************************************************************************
* Pre-Processor Declarations
****************************************************************************/
#define nop() asm volatile ("nop")
/****************************************************************************
* Public Functions
****************************************************************************/
/****************************************************************************
* Name: bl602_glb_uart_fun_sel
* Name: bl602_swrst_ahb_slave1
*
* Description:
* Select UART signal function.
* SW Reset ahb slave.
*
* Input Parameters:
* sig: UART signal
* fun: UART function
* slave1: reset signal
*
* Returned Value:
* None
*
****************************************************************************/
void bl602_glb_uart_fun_sel(int sig, int fun)
void bl602_swrst_ahb_slave1(uint32_t slave1)
{
uint32_t sig_pos = 0;
uint32_t tmp_val = 0;
tmp_val = getreg32(GLB_BASE + GLB_UART_SIG_SEL_0_OFFSET);
sig_pos = (sig * 4);
/* Clear original val */
tmp_val = tmp_val & (~(0xf << sig_pos));
/* Set new value */
tmp_val = tmp_val | (fun << sig_pos);
putreg32(tmp_val, GLB_BASE + GLB_UART_SIG_SEL_0_OFFSET);
}
/****************************************************************************
* Name: bl602_glb_ahb_slave1_reset
*
* Description:
* Select UART signal function.
*
* Input Parameters:
* sig: UART signal
* fun: UART function
*
* Returned Value:
* None
*
****************************************************************************/
void bl602_glb_ahb_slave1_reset(uint32_t slave1)
{
uint32_t tmp_val = 0;
tmp_val = getreg32(GLB_BASE + GLB_SWRST_CFG1_OFFSET);
tmp_val &= (~(1 << slave1));
putreg32(tmp_val, GLB_BASE + GLB_SWRST_CFG1_OFFSET);
/* It is to prevent glitch, which cannot be accessed via bus immediately
* after certain register operations, so some nop is added
/* To prevent glitch from accessing bus immediately
* after certain register operations, so some nop delay is added
*/
BL_DRV_DUMMY();
tmp_val = getreg32(GLB_BASE + GLB_SWRST_CFG1_OFFSET);
tmp_val |= (1 << slave1);
putreg32(tmp_val, GLB_BASE + GLB_SWRST_CFG1_OFFSET);
/* It is to prevent glitch, which cannot be accessed via bus immediately
* after certain register operations, so some nop is added
*/
BL_DRV_DUMMY();
tmp_val = getreg32(GLB_BASE + GLB_SWRST_CFG1_OFFSET);
tmp_val &= (~(1 << slave1));
putreg32(tmp_val, GLB_BASE + GLB_SWRST_CFG1_OFFSET);
modifyreg32(BL602_SWRST_CFG1, slave1, 0);
nop();
nop();
nop();
nop();
modifyreg32(BL602_SWRST_CFG1, 0, slave1);
nop();
nop();
nop();
nop();
modifyreg32(BL602_SWRST_CFG1, slave1, 0);
}

View File

@ -1,5 +1,5 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_clint.h
* arch/risc-v/src/bl602/bl602_glb.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
@ -18,23 +18,56 @@
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_CLINT_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_CLINT_H
#ifndef __ARCH_RISCV_SRC_BL602_BL602_GLB_H
#define __ARCH_RISCV_SRC_BL602_BL602_GLB_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include <stdint.h>
/****************************************************************************
* Pre-processor Definitions
* Public Data
****************************************************************************/
#define BL602_CLINT_BASE (0x02000000)
#ifndef __ASSEMBLY__
#define BL602_MTIMER_HIGH ((uint32_t *)(BL602_CLINT_BASE + 0xBFFC))
#define BL602_MTIMER_LOW ((uint32_t *)(BL602_CLINT_BASE + 0xBFF8))
#define BL602_MTIMER_CMP ((uint64_t *)(BL602_CLINT_BASE + 0x4000))
#undef EXTERN
#if defined(__cplusplus)
#define EXTERN extern "C"
extern "C"
{
#else
#define EXTERN extern
#endif
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_CLINT_H */
/****************************************************************************
* Public Function Prototypes
****************************************************************************/
/****************************************************************************
* Name: bl602_swrst_ahb_slave1
*
* Description:
* SW Reset ahb slave.
*
* Input Parameters:
* slave1: reset signal
*
* Returned Value:
* None
*
****************************************************************************/
void bl602_swrst_ahb_slave1(uint32_t slave1);
#undef EXTERN
#if defined(__cplusplus)
}
#endif
#endif /* __ASSEMBLY__ */
#endif /* __ARCH_RISCV_SRC_BL602_BL602_GLB_H */

View File

@ -23,122 +23,183 @@
****************************************************************************/
#include <stdint.h>
#include "hardware/bl602_gpio.h"
#include "hardware/bl602_glb.h"
#include "riscv_arch.h"
#include "hardware/bl602_glb.h"
#include "bl602_gpio.h"
/****************************************************************************
* Public Data
****************************************************************************/
const uintptr_t g_gpio_base[] =
{
BL602_GPIO_CFGCTL0,
BL602_GPIO_CFGCTL1,
BL602_GPIO_CFGCTL2,
BL602_GPIO_CFGCTL3,
BL602_GPIO_CFGCTL4,
BL602_GPIO_CFGCTL5,
BL602_GPIO_CFGCTL6,
BL602_GPIO_CFGCTL7,
BL602_GPIO_CFGCTL8,
BL602_GPIO_CFGCTL9,
BL602_GPIO_CFGCTL10,
BL602_GPIO_CFGCTL11,
BL602_GPIO_CFGCTL12,
BL602_GPIO_CFGCTL13,
BL602_GPIO_CFGCTL14
};
/****************************************************************************
* Public Functions
****************************************************************************/
/****************************************************************************
* Name: bl602_gpio_init
* Name: bl602_configgpio
*
* Description:
* Init a gpio pin.
*
* Input Parameters:
* cfg: gpio configuration
* Configure a GPIO pin based on bit-encoded description of the pin.
*
* Returned Value:
* Description of the value returned by this function (if any),
* including an enumeration of all possible error values.
*
* Assumptions/Limitations:
* Anything else that one might need to know to use this function.
* OK on success
* ERROR on invalid port.
*
****************************************************************************/
void bl602_gpio_init(struct gpio_cfg_s *cfg)
int bl602_configgpio(gpio_pinset_t cfgset)
{
uint8_t gpio_pin = cfg->gpio_pin;
uint32_t *p_out;
uint32_t pos;
uint32_t tmp_out;
uint32_t tmp_val;
uint32_t mask;
uintptr_t regaddr;
uint32_t cfg = 0;
uint8_t pin = (cfgset & GPIO_PIN_MASK) >> GPIO_PIN_SHIFT;
p_out = (uint32_t *)(GLB_BASE + GLB_GPIO_OUTPUT_EN_OFFSET +
((gpio_pin >> 5) << 2));
pos = gpio_pin % 32;
tmp_out = *p_out;
/* Disable output anyway */
tmp_out &= (~(1 << pos));
*p_out = tmp_out;
tmp_val = getreg32(GLB_BASE + GLB_GPIO_OFFSET + gpio_pin / 2 * 4);
if (gpio_pin % 2 == 0)
if (pin > 27)
{
/* Set input or output */
return ERROR;
}
if (cfg->gpio_mode == GPIO_MODE_OUTPUT)
{
tmp_val = tmp_val & GLB_REG_GPIO_0_IE_UMSK;
tmp_out |= (1 << pos);
}
else
{
tmp_val = tmp_val | (1 << GLB_REG_GPIO_0_IE_POS);
}
/* The configuration masks will just use the defines for GPIO0 which is
* the same as all GPIO config bit fields besides the offset.
*/
/* Set pull up or down */
if (cfgset & GPIO_INPUT)
{
cfg |= GPIO_CFGCTL0_GPIO_0_IE;
}
tmp_val &= GLB_REG_GPIO_0_PU_UMSK;
tmp_val &= GLB_REG_GPIO_0_PD_UMSK;
if (cfg->pull_type == GPIO_PULL_UP)
{
tmp_val = tmp_val | (1 << GLB_REG_GPIO_0_PU_POS);
}
else if (cfg->pull_type == GPIO_PULL_DOWN)
{
tmp_val = tmp_val | (1 << GLB_REG_GPIO_0_PD_POS);
}
if (cfgset & GPIO_PULLUP)
{
cfg |= GPIO_CFGCTL0_GPIO_0_PU;
}
tmp_val = (tmp_val & GLB_REG_GPIO_0_DRV_UMSK) |
(cfg->drive << GLB_REG_GPIO_0_DRV_POS);
tmp_val = (tmp_val & GLB_REG_GPIO_0_SMT_UMSK) |
(cfg->smt_ctrl << GLB_REG_GPIO_0_SMT_POS);
tmp_val = (tmp_val & GLB_REG_GPIO_0_FUNC_SEL_UMSK) |
(cfg->gpio_fun << GLB_REG_GPIO_0_FUNC_SEL_POS);
if (cfgset & GPIO_PULLDOWN)
{
cfg |= GPIO_CFGCTL0_GPIO_0_PD;
}
if (cfgset & GPIO_DRV_MASK)
{
cfg |= ((cfgset & GPIO_DRV_MASK) >> GPIO_DRV_SHIFT) << \
GPIO_CFGCTL0_GPIO_0_DRV_SHIFT;
}
if (cfgset & GPIO_SMT_EN)
{
cfg |= GPIO_CFGCTL0_GPIO_0_SMT;
}
if (cfgset & GPIO_FUNC_MASK)
{
cfg |= ((cfgset & GPIO_FUNC_MASK) >> GPIO_FUNC_SHIFT) << \
GPIO_CFGCTL0_GPIO_0_FUNC_SEL_SHIFT;
}
/* Grab the register that contains the pin config, this is shared between
* two pins so we must shift accordingly.
*/
regaddr = g_gpio_base[pin / 2];
mask = 0xffff;
if ((pin & 1) == 1)
{
cfg = cfg << 16;
mask = mask << 16;
}
modifyreg32(regaddr, mask, cfg);
return OK;
}
/****************************************************************************
* Name: bl602_config_uart_sel
*
* Description:
* Configure the GPIO UART pin selection mux based on bit-encoded
* description of the pin and the selection signal
*
* Returned Value:
* OK on success
* ERROR on invalid port.
*
****************************************************************************/
int bl602_config_uart_sel(gpio_pinset_t pinset, uint8_t sig_sel)
{
irqstate_t flags;
uint8_t pin = (pinset & GPIO_PIN_MASK) >> GPIO_PIN_SHIFT;
uint8_t sel_idx;
uint32_t reg;
if ((pin > 27) || sig_sel > UART_SIG_SEL_UART1_RXD)
{
return ERROR;
}
sel_idx = pin % 8;
flags = enter_critical_section();
reg = getreg32(BL602_UART_SIG_SEL_0);
reg &= ~(0xf << (sel_idx * 4));
reg |= sig_sel << (sel_idx * 4);
putreg32(reg, BL602_UART_SIG_SEL_0);
leave_critical_section(flags);
return OK;
}
/****************************************************************************
* Name: bl602_gpiowrite
*
* Description:
* Write one or zero to the selected GPIO pin
*
****************************************************************************/
void bl602_gpiowrite(gpio_pinset_t pinset, bool value)
{
uint8_t pin = (pinset & GPIO_PIN_MASK) >> GPIO_PIN_SHIFT;
if (value)
{
modifyreg32(BL602_GPIO_CFGCTL32, 0, (1 << pin));
}
else
{
/* Set input or output */
if (cfg->gpio_mode == GPIO_MODE_OUTPUT)
{
tmp_val &= GLB_REG_GPIO_1_IE_UMSK;
tmp_out |= (1 << pos);
}
else
{
tmp_val = tmp_val | (1 << GLB_REG_GPIO_1_IE_POS);
}
/* Set pull up or down */
tmp_val &= GLB_REG_GPIO_1_PU_UMSK;
tmp_val &= GLB_REG_GPIO_1_PD_UMSK;
if (cfg->pull_type == GPIO_PULL_UP)
{
tmp_val = tmp_val | (1 << GLB_REG_GPIO_1_PU_POS);
}
else if (cfg->pull_type == GPIO_PULL_DOWN)
{
tmp_val = tmp_val | (1 << GLB_REG_GPIO_1_PD_POS);
}
tmp_val = (tmp_val & GLB_REG_GPIO_1_DRV_UMSK) |
(cfg->drive << GLB_REG_GPIO_1_DRV_POS);
tmp_val = (tmp_val & GLB_REG_GPIO_1_SMT_UMSK) |
(cfg->smt_ctrl << GLB_REG_GPIO_1_SMT_POS);
tmp_val = (tmp_val & GLB_REG_GPIO_1_FUNC_SEL_UMSK) |
(cfg->gpio_fun << GLB_REG_GPIO_1_FUNC_SEL_POS);
modifyreg32(BL602_GPIO_CFGCTL32, (1 << pin), 0);
}
putreg32(tmp_val, GLB_BASE + GLB_GPIO_OFFSET + gpio_pin / 2 * 4);
*p_out = tmp_out;
}
/****************************************************************************
* Name: bl602_gpioread
*
* Description:
* Read one or zero from the selected GPIO pin
*
****************************************************************************/
bool bl602_gpioread(gpio_pinset_t pinset)
{
uint8_t pin = (pinset & GPIO_PIN_MASK) >> GPIO_PIN_SHIFT;
return (getreg32(BL602_GPIO_CFGCTL30) & (1 << pin)) == 1;
}

View File

@ -0,0 +1,297 @@
/****************************************************************************
* arch/risc-v/src/bl602/bl602_gpio.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_BL602_GPIO_H
#define __ARCH_RISCV_SRC_BL602_BL602_GPIO_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#ifndef __ASSEMBLY__
# include <stdint.h>
# include <stdbool.h>
#endif
#include <nuttx/irq.h>
#include "chip.h"
#include "hardware/bl602_glb.h"
/****************************************************************************
* Pre-Processor Declarations
****************************************************************************/
/* Bit-encoded input to bl602_configgpio() */
/* Each port bit of the general-purpose I/O (GPIO) ports can be individually
* configured by software in several modes:
*
* - Input floating
* - Input pull-up
* - Input-pull-down
* - Output floating
* - Output with pull-up
* - Output with pull-down
* - Alternate function (Digital and Analog)
*
* 16-bit Encoding: 1111 1100 0000 0000
* 5432 1098 7654 3210
* ---- ---- ---- ----
* .MUU DDSF FFFP PPPP
*/
/* Mode:
*
* 1111 1100 0000 0000
* 5432 1098 7654 3210
* ---- ---- ---- ----
* .M.. .... .... ....
*/
#define GPIO_MODE_SHIFT (14) /* Bits 14: Port Mode */
#define GPIO_MODE_MASK (1 << GPIO_MODE_SHIFT)
# define GPIO_INPUT (1 << GPIO_MODE_SHIFT) /* Input Enable */
/* Input/output pull-ups/downs:
*
* 1111 1100 0000 0000
* 5432 1098 7654 3210
* ---- ---- ---- ----
* ..UU .... .... ....
*/
#define GPIO_PUPD_SHIFT (12) /* Bits 16-17: Pull-up/down */
#define GPIO_PUPD_MASK (3 << GPIO_PUPD_SHIFT)
# define GPIO_FLOAT (0 << GPIO_PUPD_SHIFT) /* No pull-up, pull-down */
# define GPIO_PULLUP (1 << GPIO_PUPD_SHIFT) /* Pull-up */
# define GPIO_PULLDOWN (2 << GPIO_PUPD_SHIFT) /* Pull-down */
/* Drive:
*
* 1111 1100 0000 0000
* 5432 1098 7654 3210
* ---- ---- ---- ----
* .... DD.. .... ....
*/
#define GPIO_DRV_SHIFT (10) /* Bits 10-11: Drive */
#define GPIO_DRV_MASK (3 << GPIO_DRV_SHIFT)
# define GPIO_DRV_0 (0 << GPIO_DRV_SHIFT)
# define GPIO_DRV_1 (1 << GPIO_DRV_SHIFT)
# define GPIO_DRV_2 (2 << GPIO_DRV_SHIFT)
# define GPIO_DRV_3 (3 << GPIO_DRV_SHIFT)
/* Input Schmitt trigger:
*
* 1111 1100 0000 0000
* 5432 1098 7654 3210
* ---- ---- ---- ----
* .... ..S. .... ....
*/
#define GPIO_SMT_SHIFT (9) /* Bits 9: SMT Enable */
#define GPIO_SMT_MASK (3 << GPIO_SMT_SHIFT)
# define GPIO_SMT_DIS (0 << GPIO_SMT_SHIFT)
# define GPIO_SMT_EN (1 << GPIO_SMT_SHIFT)
/* GPIO type selection:
*
* 1111 1100 0000 0000
* 5432 1098 7654 3210
* ---- ---- ---- ----
* .... ...F FFF. ....
*/
#define GPIO_FUNC_SHIFT (5) /* Bits 5-8: GPIO Type */
#define GPIO_FUNC_MASK (15 << GPIO_FUNC_SHIFT)
# define GPIO_FUNC_SDIO (1 << GPIO_FUNC_SHIFT) /* SDIO */
# define GPIO_FUNC_FLASH (2 << GPIO_FUNC_SHIFT) /* Flash */
# define GPIO_FUNC_SPI (4 << GPIO_FUNC_SHIFT) /* SPI */
# define GPIO_FUNC_I2C (6 << GPIO_FUNC_SHIFT) /* I2C */
# define GPIO_FUNC_UART (7 << GPIO_FUNC_SHIFT) /* UART */
# define GPIO_FUNC_PWM (8 << GPIO_FUNC_SHIFT) /* PWM */
# define GPIO_FUNC_EXT_PA (9 << GPIO_FUNC_SHIFT) /* Analog */
# define GPIO_FUNC_ANA (10 << GPIO_FUNC_SHIFT) /* Analog */
# define GPIO_FUNC_SWGPIO (11 << GPIO_FUNC_SHIFT) /* Software GPIO */
# define GPIO_FUNC_JTAG (14 << GPIO_FUNC_SHIFT) /* JTAG */
/* This identifies the bit in the port:
*
* 1111 1100 0000 0000
* 5432 1098 7654 3210
* ---- ---- ---- ----
* .... .... ...P PPPP
*/
#define GPIO_PIN_SHIFT (0) /* Bits 0-4: GPIO number: 0-28 */
#define GPIO_PIN_MASK (0x1f << GPIO_PIN_SHIFT)
# define GPIO_PIN0 (0 << GPIO_PIN_SHIFT)
# define GPIO_PIN1 (1 << GPIO_PIN_SHIFT)
# define GPIO_PIN2 (2 << GPIO_PIN_SHIFT)
# define GPIO_PIN3 (3 << GPIO_PIN_SHIFT)
# define GPIO_PIN4 (4 << GPIO_PIN_SHIFT)
# define GPIO_PIN5 (5 << GPIO_PIN_SHIFT)
# define GPIO_PIN6 (6 << GPIO_PIN_SHIFT)
# define GPIO_PIN7 (7 << GPIO_PIN_SHIFT)
# define GPIO_PIN8 (8 << GPIO_PIN_SHIFT)
# define GPIO_PIN9 (9 << GPIO_PIN_SHIFT)
# define GPIO_PIN10 (10 << GPIO_PIN_SHIFT)
# define GPIO_PIN11 (11 << GPIO_PIN_SHIFT)
# define GPIO_PIN12 (12 << GPIO_PIN_SHIFT)
# define GPIO_PIN13 (13 << GPIO_PIN_SHIFT)
# define GPIO_PIN14 (14 << GPIO_PIN_SHIFT)
# define GPIO_PIN15 (15 << GPIO_PIN_SHIFT)
# define GPIO_PIN16 (16 << GPIO_PIN_SHIFT)
# define GPIO_PIN17 (17 << GPIO_PIN_SHIFT)
# define GPIO_PIN18 (18 << GPIO_PIN_SHIFT)
# define GPIO_PIN19 (19 << GPIO_PIN_SHIFT)
# define GPIO_PIN20 (20 << GPIO_PIN_SHIFT)
# define GPIO_PIN21 (21 << GPIO_PIN_SHIFT)
# define GPIO_PIN22 (22 << GPIO_PIN_SHIFT)
# define GPIO_PIN23 (23 << GPIO_PIN_SHIFT)
# define GPIO_PIN24 (24 << GPIO_PIN_SHIFT)
# define GPIO_PIN25 (25 << GPIO_PIN_SHIFT)
# define GPIO_PIN26 (26 << GPIO_PIN_SHIFT)
# define GPIO_PIN27 (27 << GPIO_PIN_SHIFT)
# define GPIO_PIN28 (28 << GPIO_PIN_SHIFT)
/****************************************************************************
* Public Types
****************************************************************************/
/* The smallest integer type that can hold the GPIO encoding */
typedef uint16_t gpio_pinset_t;
/****************************************************************************
* Public Data
****************************************************************************/
#ifndef __ASSEMBLY__
#undef EXTERN
#if defined(__cplusplus)
#define EXTERN extern "C"
extern "C"
{
#else
#define EXTERN extern
#endif
/****************************************************************************
* Public Function Prototypes
****************************************************************************/
/****************************************************************************
* Name: bl602_configgpio
*
* Description:
* Configure a GPIO pin based on bit-encoded description of the pin.
*
* Returned Value:
* OK on success
* ERROR on invalid port.
*
****************************************************************************/
int bl602_configgpio(gpio_pinset_t cfgset);
/****************************************************************************
* Name: bl602_config_uart_sel
*
* Description:
* Configure the GPIO UART pin selection mux based on bit-encoded
* description of the pin and the selection signal
*
* Returned Value:
* OK on success
* ERROR on invalid port.
*
****************************************************************************/
int bl602_config_uart_sel(gpio_pinset_t cfgset, uint8_t sig_sel);
/****************************************************************************
* Name: bl602_gpiowrite
*
* Description:
* Write one or zero to the selected GPIO pin
*
****************************************************************************/
void bl602_gpiowrite(gpio_pinset_t pinset, bool value);
/****************************************************************************
* Name: bl602_gpioread
*
* Description:
* Read one or zero from the selected GPIO pin
*
****************************************************************************/
bool bl602_gpioread(gpio_pinset_t pinset);
/****************************************************************************
* Name: bl602_gpiosetevent
*
* Description:
* Sets/clears GPIO based event and interrupt triggers.
*
* Input Parameters:
* - pinset: GPIO pin configuration
* - risingedge: Enables interrupt on rising edges
* - fallingedge: Enables interrupt on falling edges
* - event: Generate event when set
* - func: When non-NULL, generate interrupt
* - arg: Argument passed to the interrupt callback
*
* Returned Value:
* Zero (OK) on success; a negated errno value on failure indicating the
* nature of the failure.
*
****************************************************************************/
int bl602_gpiosetevent(gpio_pinset_t pinset, bool risingedge,
bool fallingedge, bool event, xcpt_t func, void *arg);
/****************************************************************************
* Function: bl602_dumpgpio
*
* Description:
* Dump all GPIO registers associated with the provided base address
*
****************************************************************************/
#ifdef CONFIG_DEBUG_GPIO_INFO
int bl602_dumpgpio(gpio_pinset_t pinset, const char *msg);
#else
# define bl602_dumpgpio(p,m)
#endif
#undef EXTERN
#if defined(__cplusplus)
}
#endif
#endif /* __ASSEMBLY__ */
#endif /* __ARCH_RISCV_SRC_BL602_BL602_GPIO_H */

View File

@ -36,7 +36,7 @@
* Select uart clock source.
*
* Input Parameters:
* clk_sel: uart clock type selection
* clk_sel: uart clock type selection, 0 for FCLK or 1 for 160MHz CLK
*
* Returned Value:
* Description of the value returned by this function (if any),
@ -47,12 +47,14 @@
*
****************************************************************************/
void bl602_hbn_set_uart_clk_sel(int clk_sel)
void bl602_set_uart_clk_sel(int clk_sel)
{
uint32_t tmp_val;
tmp_val = getreg32(HBN_BASE + HBN_GLB_OFFSET);
tmp_val &= ~(1 << 2);
tmp_val |= (clk_sel << 2);
putreg32(tmp_val, HBN_BASE + HBN_GLB_OFFSET);
if (clk_sel)
{
modifyreg32(BL602_HBN_GLB, 0, HBN_GLB_HBN_UART_CLK_SEL);
}
else
{
modifyreg32(BL602_HBN_GLB, HBN_GLB_HBN_UART_CLK_SEL, 0);
}
}

View File

@ -0,0 +1,77 @@
/****************************************************************************
* arch/risc-v/src/bl602/bl602_hbn.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_BL602_HBN_H
#define __ARCH_RISCV_SRC_BL602_BL602_HBN_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include <stdint.h>
/****************************************************************************
* Public Data
****************************************************************************/
#ifndef __ASSEMBLY__
#undef EXTERN
#if defined(__cplusplus)
#define EXTERN extern "C"
extern "C"
{
#else
#define EXTERN extern
#endif
/****************************************************************************
* Public Function Prototypes
****************************************************************************/
/****************************************************************************
* Name: bl602_hbn_set_uart_clk_sel
*
* Description:
* Select uart clock source.
*
* Input Parameters:
* clk_sel: uart clock type selection, 0 for FCLK or 1 for 160MHz CLK
*
* Returned Value:
* Description of the value returned by this function (if any),
* including an enumeration of all possible error values.
*
* Assumptions/Limitations:
* Anything else that one might need to know to use this function.
*
****************************************************************************/
void bl602_set_uart_clk_sel(int clk_sel);
#undef EXTERN
#if defined(__cplusplus)
}
#endif
#endif /* __ASSEMBLY__ */
#endif /* __ARCH_RISCV_SRC_BL602_BL602_HBN_H */

View File

@ -36,7 +36,7 @@
#include "riscv_internal.h"
#include "riscv_arch.h"
#include "hardware/clic.h"
#include "hardware/bl602_clic.h"
#include "chip.h"
@ -46,22 +46,22 @@
static inline void bl_irq_enable(unsigned int source)
{
putreg8(1, CLIC_HART0_ADDR + CLIC_INTIE + source);
putreg8(1, BL602_CLIC_INTIE + source);
}
static inline void bl_irq_disable(unsigned int source)
{
putreg8(0, CLIC_HART0_ADDR + CLIC_INTIE + source);
putreg8(0, BL602_CLIC_INTIE + source);
}
static inline void bl_irq_pending_set(unsigned int source)
{
putreg8(1, CLIC_HART0_ADDR + CLIC_INTIP + source);
putreg8(1, BL602_CLIC_INTIP + source);
}
static inline void bl_irq_pending_clear(unsigned int source)
{
putreg8(0, CLIC_HART0_ADDR + CLIC_INTIP + source);
putreg8(0, BL602_CLIC_INTIP + source);
}
/****************************************************************************

View File

@ -37,12 +37,12 @@
#include <arch/board/board.h>
#include "hardware/bl602_gpio.h"
#include "hardware/bl602_glb.h"
#include "hardware/bl602_hbn.h"
#include "hardware/bl602_uart.h"
#include "bl602_lowputc.h"
#include "bl602_gpio.h"
#include "bl602_hbn.h"
#include "riscv_arch.h"
#include "riscv_internal.h"
@ -53,12 +53,15 @@
* Pre-processor Definitions
****************************************************************************/
#define UART_PARITY_NONE (0)
#define UART_PARITY_ODD (1)
#define UART_PARITY_EVEN (2)
/* Select UART parameters for the selected console */
#ifdef HAVE_SERIAL_CONSOLE
#if defined(CONFIG_UART0_SERIAL_CONSOLE)
#define BL602_CONSOLE_IDX 0
#define BL602_CONSOLE_BASE UART0_BASE
#define BL602_CONSOLE_BAUD CONFIG_UART0_BAUD
#define BL602_CONSOLE_BITS CONFIG_UART0_BITS
#define BL602_CONSOLE_PARITY CONFIG_UART0_PARITY
@ -73,14 +76,10 @@
#else
#define BL602_CONSOLE_OFLOWCTL 0
#endif
#define BL602_CONSOLE_TX_PIN CONFIG_BL602_UART0_TX_PIN
#define BL602_CONSOLE_RX_PIN CONFIG_BL602_UART0_RX_PIN
#define BL602_CONSOLE_RTS_PIN CONFIG_BL602_UART0_RTS_PIN
#define BL602_CONSOLE_CTS_PIN CONFIG_BL602_UART0_CTS_PIN
#endif
#define HAVE_UART
#elif defined(CONFIG_UART1_SERIAL_CONSOLE)
#define BL602_CONSOLE_IDX 1
#define BL602_CONSOLE_BASE UART1_BASE
#define BL602_CONSOLE_BAUD CONFIG_UART1_BAUD
#define BL602_CONSOLE_BITS CONFIG_UART1_BITS
#define BL602_CONSOLE_PARITY CONFIG_UART1_PARITY
@ -95,15 +94,11 @@
#else
#define BL602_CONSOLE_OFLOWCTL 0
#endif
#define BL602_CONSOLE_TX_PIN CONFIG_BL602_UART1_TX_PIN
#define BL602_CONSOLE_RX_PIN CONFIG_BL602_UART1_RX_PIN
#define BL602_CONSOLE_RTS_PIN CONFIG_BL602_UART1_RTS_PIN
#define BL602_CONSOLE_CTS_PIN CONFIG_BL602_UART1_CTS_PIN
#define HAVE_UART
#endif
#endif /* HAVE_CONSOLE */
#define _BL602_UART_CLOCK (160 * 1000 * 1000UL) /* UART clock */
#define HBN_UART_CLK_160M (1)
/****************************************************************************
* Private Data
@ -128,10 +123,6 @@ static const struct uart_config_s g_bl602_console_config =
#else
.oflow_ctl = 0,
#endif
.tx_pin = BL602_CONSOLE_TX_PIN,
.rx_pin = BL602_CONSOLE_RX_PIN,
.rts_pin = BL602_CONSOLE_RTS_PIN,
.cts_pin = BL602_CONSOLE_CTS_PIN,
};
#endif /* HAVE_SERIAL_CONSOLE */
@ -139,145 +130,99 @@ static const struct uart_config_s g_bl602_console_config =
* Private Functions
****************************************************************************/
static void uart_gpio_init(uint8_t id,
uint8_t tx_pin,
uint8_t rx_pin,
uint8_t cts_pin,
uint8_t rts_pin)
static void bl602_uart_gpio_init(uint8_t id)
{
struct gpio_cfg_s cfg;
int tx_sigfun;
int rx_sigfun;
cfg.drive = 1;
cfg.smt_ctrl = 1;
cfg.gpio_fun = 7;
cfg.gpio_pin = rx_pin;
cfg.gpio_mode = GPIO_MODE_AF;
cfg.pull_type = GPIO_PULL_UP;
bl602_gpio_init(&cfg);
cfg.gpio_pin = tx_pin;
cfg.gpio_mode = GPIO_MODE_AF;
cfg.pull_type = GPIO_PULL_UP;
bl602_gpio_init(&cfg);
/* select uart gpio function */
if (id == 0)
{
tx_sigfun = GLB_UART_SIG_FUN_UART0_TXD;
rx_sigfun = GLB_UART_SIG_FUN_UART0_RXD;
#ifdef BOARD_UART_0_TX_PIN
bl602_config_uart_sel(BOARD_UART_0_TX_PIN, UART_SIG_SEL_UART0_TXD);
bl602_configgpio(BOARD_UART_0_TX_PIN);
#endif
#ifdef BOARD_UART_0_RX_PIN
bl602_config_uart_sel(BOARD_UART_0_RX_PIN, UART_SIG_SEL_UART0_RXD);
bl602_configgpio(BOARD_UART_0_RX_PIN);
#endif
#ifdef BOARD_UART_0_CTS_PIN
bl602_config_uart_sel(BOARD_UART_0_CTS_PIN, UART_SIG_SEL_UART0_CTS);
bl602_configgpio(BOARD_UART_0_CTS_PIN);
#endif
#ifdef BOARD_UART_0_RTS_PIN
bl602_config_uart_sel(BOARD_UART_0_RTS_PIN, UART_SIG_SEL_UART0_RTS);
bl602_configgpio(BOARD_UART_0_RTS_PIN);
#endif
}
else
{
tx_sigfun = GLB_UART_SIG_FUN_UART1_TXD;
rx_sigfun = GLB_UART_SIG_FUN_UART1_RXD;
#ifdef BOARD_UART_1_TX_PIN
bl602_config_uart_sel(BOARD_UART_1_TX_PIN, UART_SIG_SEL_UART1_TXD);
bl602_configgpio(BOARD_UART_1_TX_PIN);
#endif
#ifdef BOARD_UART_1_RX_PIN
bl602_config_uart_sel(BOARD_UART_1_RX_PIN, UART_SIG_SEL_UART1_RXD);
bl602_configgpio(BOARD_UART_1_RX_PIN);
#endif
#ifdef BOARD_UART_1_CTS_PIN
bl602_config_uart_sel(BOARD_UART_1_CTS_PIN, UART_SIG_SEL_UART1_CTS);
bl602_configgpio(BOARD_UART_1_CTS_PIN);
#endif
#ifdef BOARD_UART_1_RTS_PIN
bl602_config_uart_sel(BOARD_UART_1_RTS_PIN, UART_SIG_SEL_UART1_RTS);
bl602_configgpio(BOARD_UART_1_RTS_PIN);
#endif
}
bl602_glb_uart_fun_sel(tx_pin % 8, tx_sigfun);
bl602_glb_uart_fun_sel(rx_pin % 8, rx_sigfun);
}
static void bl602_enable_uart_clk(uint8_t enable, int clk_sel, uint8_t div)
{
uint32_t tmp_val;
/* disable UART clock first */
bl602_up_serialmodify(GLB_BASE, GLB_CLK_CFG2_OFFSET, (1 << 4), 0);
modifyreg32(BL602_CLK_CFG2, CLK_CFG2_UART_CLK_EN, 0);
/* Set div */
bl602_up_serialmodify(GLB_BASE, GLB_CLK_CFG2_OFFSET, 0x7, div);
modifyreg32(BL602_CLK_CFG2, CLK_CFG2_UART_CLK_DIV_MASK, div);
/* Select clock source for uart */
bl602_hbn_set_uart_clk_sel(clk_sel);
bl602_set_uart_clk_sel(clk_sel);
/* Set enable or disable */
tmp_val = bl602_up_serialin(GLB_BASE, GLB_CLK_CFG2_OFFSET);
if (enable)
{
tmp_val |= (1 << 4);
modifyreg32(BL602_CLK_CFG2, 0, CLK_CFG2_UART_CLK_EN);
}
else
{
tmp_val &= ~(1 << 4);
}
bl602_up_serialout(GLB_BASE, GLB_CLK_CFG2_OFFSET, tmp_val);
}
/****************************************************************************
* Public Functions
****************************************************************************/
uint32_t bl602_up_serialin(uint32_t reg_base, int offset)
void bl602_uart_configure(const struct uart_config_s *config)
{
return getreg32(reg_base + offset);
}
uint32_t div;
uint32_t fraction;
uint32_t tx_cfg;
uint32_t rx_cfg;
uint8_t clk_div = 3;
void bl602_up_serialout(uint32_t reg_base, int offset, uint32_t value)
{
putreg32(value, reg_base + offset);
}
bl602_enable_uart_clk(1, HBN_UART_CLK_160M, clk_div);
void bl602_up_serialmodify(uint32_t reg_base,
int offset,
uint32_t clearbits,
uint32_t setbits)
{
modifyreg32(reg_base + offset, clearbits, setbits);
}
/****************************************************************************
* Name: bl602_data_setbits
****************************************************************************/
static uint32_t bl602_data_setbits(uint32_t data,
uint32_t start,
uint32_t len,
uint32_t value)
{
return (((data) & ~((~((~0) << (len))) << (start))) |
(((value) & ((~((~0) << (len))))) << (start)));
}
void bl602_uart_configure(uint32_t uartbase,
const struct uart_config_s *config)
{
uint32_t tmp_val;
uint32_t div = 0;
uint32_t fraction = 0;
uint32_t tmp_tx_cfg = 0;
uint32_t tmp_rx_cfg = 0;
int data_bits;
int stop_bits;
bl602_enable_uart_clk(1, HBN_UART_CLK_160M, 3);
uart_gpio_init(config->idx,
config->tx_pin,
config->rx_pin,
config->cts_pin,
config->rts_pin);
bl602_uart_gpio_init(config->idx);
/* Disable all interrupt */
bl602_up_serialmodify(uartbase, UART_INT_MASK_OFFSET, 0, 0xff);
modifyreg32(BL602_UART_INT_MASK(config->idx), 0, 0xff);
/* Disable uart before config */
bl602_up_serialmodify(uartbase, UART_UTX_CONFIG_OFFSET, 1, 0);
bl602_up_serialmodify(uartbase, UART_URX_CONFIG_OFFSET, 1, 0);
modifyreg32(BL602_UART_UTX_CONFIG(config->idx), UART_UTX_CONFIG_CR_EN, 0);
modifyreg32(BL602_UART_URX_CONFIG(config->idx), UART_URX_CONFIG_CR_EN, 0);
/* cal the baud rate divisor */
fraction = (_BL602_UART_CLOCK / (3 + 1)) * 10 / config->baud % 10;
div = (_BL602_UART_CLOCK / (3 + 1)) / config->baud;
fraction = (_BL602_UART_CLOCK / (clk_div + 1)) * 10 / config->baud % 10;
div = (_BL602_UART_CLOCK / (clk_div + 1)) / config->baud;
if (fraction >= 5)
{
++div;
@ -285,120 +230,106 @@ void bl602_uart_configure(uint32_t uartbase,
/* set the baud rate register value */
bl602_up_serialout(uartbase,
UART_BIT_PRD_OFFSET,
((div - 1) << 0x10) | ((div - 1) & 0xffff));
putreg32(((div - 1) << 0x10) | ((div - 1) & 0xffff),
BL602_UART_BIT_PRD(config->idx));
/* configure parity type */
tmp_tx_cfg = bl602_up_serialin(uartbase, UART_UTX_CONFIG_OFFSET);
tmp_rx_cfg = bl602_up_serialin(uartbase, UART_URX_CONFIG_OFFSET);
tx_cfg = getreg32(BL602_UART_UTX_CONFIG(config->idx));
rx_cfg = getreg32(BL602_UART_URX_CONFIG(config->idx));
switch (config->parity)
{
case UART_PARITY_NONE:
tmp_tx_cfg &= ~(1 << 4);
tmp_rx_cfg &= ~(1 << 4);
tx_cfg &= ~UART_UTX_CONFIG_CR_PRT_EN;
rx_cfg &= ~UART_URX_CONFIG_CR_PRT_EN;
break;
case UART_PARITY_ODD:
tmp_tx_cfg |= 1 << 4;
tmp_tx_cfg |= 1 << 5;
tmp_rx_cfg |= 1 << 4;
tmp_rx_cfg |= 1 << 5;
tx_cfg |= UART_UTX_CONFIG_CR_PRT_EN;
tx_cfg |= UART_UTX_CONFIG_CR_PRT_SEL;
rx_cfg |= UART_URX_CONFIG_CR_PRT_EN;
rx_cfg |= UART_URX_CONFIG_CR_PRT_SEL;
break;
case UART_PARITY_EVEN:
tmp_tx_cfg |= 1 << 4;
tmp_tx_cfg &= ~(1 << 5);
tmp_rx_cfg |= 1 << 4;
tmp_rx_cfg &= ~(1 << 5);
tx_cfg |= UART_UTX_CONFIG_CR_PRT_EN;
tx_cfg &= ~UART_UTX_CONFIG_CR_PRT_SEL;
rx_cfg |= UART_URX_CONFIG_CR_PRT_EN;
rx_cfg &= ~UART_URX_CONFIG_CR_PRT_SEL;
break;
default:
break;
}
if (config->data_bits == 5)
{
data_bits = UART_DATABITS_5;
}
else if (config->data_bits == 6)
{
data_bits = UART_DATABITS_6;
}
else if (config->data_bits == 7)
{
data_bits = UART_DATABITS_7;
}
else
{
data_bits = UART_DATABITS_8;
}
/* Configure data and stop bits */
if (config->stop_bits == 1)
{
stop_bits = UART_STOPBITS_2;
}
else
{
stop_bits = UART_STOPBITS_1;
}
rx_cfg &= ~UART_URX_CONFIG_CR_BIT_CNT_D_MASK;
rx_cfg |= ((uint32_t)config->data_bits - 1) << \
UART_URX_CONFIG_CR_BIT_CNT_D_SHIFT;
/* Configure data bits */
tmp_tx_cfg = bl602_data_setbits(tmp_tx_cfg, 8, 3, (data_bits + 4));
tmp_rx_cfg = bl602_data_setbits(tmp_tx_cfg, 8, 3, (data_bits + 4));
/* Configure tx stop bits */
tmp_tx_cfg = bl602_data_setbits(tmp_tx_cfg, 12, 2, (stop_bits + 1));
tx_cfg &= ~(UART_UTX_CONFIG_CR_BIT_CNT_D_MASK | \
UART_UTX_CONFIG_CR_BIT_CNT_P_MASK);
tx_cfg |= (((uint32_t)config->data_bits - 1) << \
UART_UTX_CONFIG_CR_BIT_CNT_D_SHIFT) | \
(((uint32_t)config->stop_bits + 1) << \
UART_UTX_CONFIG_CR_BIT_CNT_P_SHIFT);
/* Configure tx cts flow control function */
if (config->oflow_ctl)
{
tmp_tx_cfg |= 1 << 1;
tx_cfg |= UART_UTX_CONFIG_CR_CTS_EN;
}
else
{
tmp_tx_cfg &= ~(1 << 1);
tx_cfg &= ~(UART_UTX_CONFIG_CR_CTS_EN);
}
/* Disable rx input de-glitch function */
tmp_rx_cfg &= ~(1 << 11);
rx_cfg &= ~(UART_URX_CONFIG_CR_DEG_EN);
/* Configure rx rts flow control function */
/* TODO: What about UART_URX_CONFIG_CR_RTS_SW_VAL? */
if (config->iflow_ctl)
{
tmp_rx_cfg |= 1 << 1;
rx_cfg |= UART_URX_CONFIG_CR_RTS_SW_MODE;
}
else
{
tmp_rx_cfg &= ~(1 << 1);
rx_cfg &= ~(UART_URX_CONFIG_CR_RTS_SW_MODE);
}
/* Write back */
bl602_up_serialout(uartbase, UART_UTX_CONFIG_OFFSET, tmp_tx_cfg);
bl602_up_serialout(uartbase, UART_URX_CONFIG_OFFSET, tmp_rx_cfg);
putreg32(rx_cfg, BL602_UART_URX_CONFIG(config->idx));
putreg32(tx_cfg, BL602_UART_UTX_CONFIG(config->idx));
/* Configure LSB-first */
bl602_up_serialmodify(uartbase, UART_DATA_CONFIG_OFFSET, 1, 0);
modifyreg32(BL602_UART_DATA_CONFIG(config->idx),
UART_DATA_CONFIG_CR_UART_BIT_INV, 0);
/* Enable tx free run mode */
bl602_up_serialmodify(uartbase, UART_UTX_CONFIG_OFFSET, 0, 1 << 2);
modifyreg32(BL602_UART_UTX_CONFIG(config->idx), 0,
UART_UTX_CONFIG_CR_FRM_EN);
/* Deal with uart fifo configure register */
/* Configure FIFO thresholds */
tmp_val = bl602_up_serialin(uartbase, UART_FIFO_CONFIG_1_OFFSET);
tmp_val = bl602_data_setbits(tmp_val, UART_TX_FIFO_TH_POS, 5, 0x10 - 1);
tmp_val = bl602_data_setbits(tmp_val, UART_RX_FIFO_TH_POS, 5, 0x10 - 1);
bl602_up_serialout(uartbase, UART_FIFO_CONFIG_1_OFFSET, tmp_val);
modifyreg32(BL602_UART_FIFO_CONFIG_1(config->idx),
(UART_FIFO_CONFIG_1_RX_TH_MASK | \
UART_FIFO_CONFIG_1_TX_TH_MASK),
((0x10 - 1) << UART_FIFO_CONFIG_1_RX_TH_SHIFT) | \
((0x10 - 1) << UART_FIFO_CONFIG_1_TX_TH_SHIFT));
/* Enable UART tx rx unit */
bl602_up_serialmodify(uartbase, UART_UTX_CONFIG_OFFSET, 0, 1);
bl602_up_serialmodify(uartbase, UART_URX_CONFIG_OFFSET, 0, 1);
modifyreg32(BL602_UART_UTX_CONFIG(config->idx), 0,
UART_UTX_CONFIG_CR_EN);
modifyreg32(BL602_UART_URX_CONFIG(config->idx), 0,
UART_URX_CONFIG_CR_EN);
}
/****************************************************************************
@ -414,13 +345,10 @@ void up_lowputc(char ch)
#ifdef HAVE_SERIAL_CONSOLE
/* Wait for FIFO */
while (
((bl602_up_serialin(BL602_CONSOLE_BASE, UART_FIFO_CONFIG_1_OFFSET)) >>
(UART_TX_FIFO_CNT_POS)) &
(~((~0) << (6))))
;
while ((getreg32(BL602_UART_FIFO_CONFIG_1(BL602_CONSOLE_IDX)) & \
UART_FIFO_CONFIG_1_TX_CNT_MASK) == 0);
bl602_up_serialout(BL602_CONSOLE_BASE, UART_FIFO_WDATA_OFFSET, ch);
putreg32(ch, BL602_UART_FIFO_WDATA(BL602_CONSOLE_IDX));
#endif /* HAVE_CONSOLE */
}
@ -429,7 +357,7 @@ void bl602_lowsetup(void)
#ifdef HAVE_SERIAL_CONSOLE
/* Configure the console UART (if any) */
bl602_uart_configure(BL602_CONSOLE_BASE, &g_bl602_console_config);
bl602_uart_configure(&g_bl602_console_config);
#endif /* HAVE_SERIAL_CONSOLE */
}

View File

@ -44,10 +44,6 @@ struct uart_config_s
uint8_t data_bits; /* Number of bits per word */
bool stop_bits; /* true=2 stop bits; false=1 stop bit */
uint8_t parity; /* Parity selection: 0=none, 1=odd, 2=even */
uint8_t tx_pin; /* TX pin */
uint8_t rx_pin; /* RX pin */
uint8_t cts_pin; /* CTS pin */
uint8_t rts_pin; /* RTS pin */
};
#undef EXTERN
@ -59,20 +55,9 @@ extern "C"
#define EXTERN extern
#endif
EXTERN uint32_t bl602_up_serialin(uint32_t reg_base, int offset);
EXTERN void bl602_up_serialout(uint32_t reg_base, int offset,
uint32_t value);
EXTERN void bl602_up_serialmodify(uint32_t reg_base,
int offset,
uint32_t clearbits,
uint32_t setbits);
EXTERN void bl602_lowsetup(void);
EXTERN void bl602_uart_configure(uint32_t base_addr,
const struct uart_config_s *config);
EXTERN void bl602_uart_configure(const struct uart_config_s *config);
#undef EXTERN
#if defined(__cplusplus)

View File

@ -37,6 +37,7 @@
#include "riscv_internal.h"
#include <hardware/bl602_timer.h>
#include "bl602_tim.h"
#include "bl602_oneshot_lowerhalf.h"
/****************************************************************************
@ -72,7 +73,7 @@ struct bl602_oneshot_lowerhalf_s
oneshot_callback_t callback; /* Internal handler that receives callback */
FAR void * arg; /* Argument that is passed to the handler */
uint8_t tim; /* timer tim 0,1 */
uint8_t irq; /* IRQ associated with this UART */
uint8_t irq; /* IRQ associated with this timer */
bool started; /* True: Timer has been started */
};
@ -132,18 +133,27 @@ static int bl602_oneshot_handler(int irq, FAR void *context, FAR void *arg)
/* Clear Interrupt Bits */
uint32_t int_id;
uint32_t tmp_val;
uint32_t tmp_addr;
uint32_t ticr_val;
uint32_t ticr_addr;
int_id = getreg32(TIMER_BASE + TIMER_TMSR2_OFFSET + 4 * priv->tim);
tmp_addr = TIMER_BASE + TIMER_TICR2_OFFSET + 4 * priv->tim;
tmp_val = getreg32(tmp_addr);
if (priv->tim == 0)
{
int_id = getreg32(BL602_TIMER_TMSR2);
ticr_addr = BL602_TIMER_TICR2;
}
else
{
int_id = getreg32(BL602_TIMER_TMSR3);
ticr_addr = BL602_TIMER_TICR3;
}
ticr_val = getreg32(ticr_addr);
/* Comparator 0 match interrupt */
if (((int_id) & (1 << (TIMER_TMSR_0_POS))) != 0)
if ((int_id & TIMER_TMSR2_TMSR_0) != 0)
{
putreg32(tmp_val | (1 << TIMER_TCLR_0_POS), tmp_addr);
putreg32(ticr_val | TIMER_TICR2_TCLR_0, ticr_addr);
callback = priv->callback;
cbarg = priv->arg;
@ -155,16 +165,16 @@ static int bl602_oneshot_handler(int irq, FAR void *context, FAR void *arg)
/* Comparator 1 match interrupt */
if (((int_id) & (1 << (TIMER_TMSR_1_POS))) != 0)
if ((int_id & TIMER_TMSR2_TMSR_1) != 0)
{
putreg32(tmp_val | (1 << TIMER_TCLR_1_POS), tmp_addr);
putreg32(ticr_val | TIMER_TICR2_TCLR_1, ticr_addr);
}
/* Comparator 2 match interrupt */
if (((int_id) & (1 << (TIMER_TMSR_2_POS))) != 0)
if ((int_id & TIMER_TMSR2_TMSR_2) != 0)
{
putreg32(tmp_val | (1 << TIMER_TCLR_2_POS), tmp_addr);
putreg32(ticr_val | TIMER_TICR2_TCLR_2, ticr_addr);
}
return 0;
@ -353,7 +363,7 @@ FAR struct oneshot_lowerhalf_s *oneshot_initialize(int chan,
uint16_t resolution)
{
FAR struct bl602_oneshot_lowerhalf_s *priv;
timer_cfg_t timstr;
struct timer_cfg_s timstr;
/* Allocate an instance of the lower half driver */
@ -372,7 +382,7 @@ FAR struct oneshot_lowerhalf_s *oneshot_initialize(int chan,
priv->lh.ops = &g_oneshot_ops;
priv->freq = TIMER_CLK_FREQ / resolution;
priv->tim = chan;
if (priv->tim == 0)
if (priv->tim == TIMER_CH0)
{
priv->irq = BL602_IRQ_TIMER_CH0;
}
@ -387,12 +397,12 @@ FAR struct oneshot_lowerhalf_s *oneshot_initialize(int chan,
timstr.clk_src = TIMER_CLKSRC_FCLK; /* Timer clock source */
timstr.pl_trig_src =
TIMER_PRELOAD_TRIG_COMP0; /* Timer count register preload trigger source
* slelect */
* select */
timstr.count_mode = TIMER_COUNT_PRELOAD; /* Timer count mode */
timstr.clock_division =
(TIMER_CLK_DIV * resolution) - 1; /* Timer clock divison value */
(TIMER_CLK_DIV * resolution) - 1; /* Timer clock division value */
timstr.match_val0 = TIMER_MAX_VALUE; /* Timer match 0 value 0 */
timstr.match_val1 = TIMER_MAX_VALUE; /* Timer match 1 value 0 */

View File

@ -36,11 +36,9 @@
#include <nuttx/irq.h>
#include <nuttx/serial/serial.h>
#include <arch/board/board.h>
#include "bl602_lowputc.h"
#include "bl602_gpio.h"
#include "hardware/bl602_gpio.h"
#include "hardware/bl602_uart.h"
#include "hardware/bl602_glb.h"
@ -77,6 +75,7 @@
#define HAVE_UART
#endif
#endif /* HAVE_CONSOLE */
/* If we are not using the serial driver for the console, then we still must
* provide some minimal implementation of up_putc.
*/
@ -122,9 +121,8 @@
* Private Types
****************************************************************************/
struct up_dev_s
struct bl602_uart_s
{
const uint32_t uartbase; /* Base address of UART registers */
uint8_t irq; /* IRQ associated with this UART */
struct uart_config_s config;
};
@ -135,18 +133,18 @@ struct up_dev_s
/* Serial driver methods */
static int up_setup(struct uart_dev_s *dev);
static void up_shutdown(struct uart_dev_s *dev);
static int up_attach(struct uart_dev_s *dev);
static void up_detach(struct uart_dev_s *dev);
static int up_ioctl(struct file *filep, int cmd, unsigned long arg);
static int up_receive(struct uart_dev_s *dev, unsigned int *status);
static void up_rxint(struct uart_dev_s *dev, bool enable);
static bool up_rxavailable(struct uart_dev_s *dev);
static void up_send(struct uart_dev_s *dev, int ch);
static void up_txint(struct uart_dev_s *dev, bool enable);
static bool up_txready(struct uart_dev_s *dev);
static bool up_txempty(struct uart_dev_s *dev);
static int bl602_setup(struct uart_dev_s *dev);
static void bl602_shutdown(struct uart_dev_s *dev);
static int bl602_attach(struct uart_dev_s *dev);
static void bl602_detach(struct uart_dev_s *dev);
static int bl602_ioctl(struct file *filep, int cmd, unsigned long arg);
static int bl602_receive(struct uart_dev_s *dev, unsigned int *status);
static void bl602_rxint(struct uart_dev_s *dev, bool enable);
static bool bl602_rxavailable(struct uart_dev_s *dev);
static void bl602_send(struct uart_dev_s *dev, int ch);
static void bl602_txint(struct uart_dev_s *dev, bool enable);
static bool bl602_txready(struct uart_dev_s *dev);
static bool bl602_txempty(struct uart_dev_s *dev);
/****************************************************************************
* Private Data
@ -154,21 +152,21 @@ static bool up_txempty(struct uart_dev_s *dev);
static const struct uart_ops_s g_uart_ops =
{
.setup = up_setup,
.shutdown = up_shutdown,
.attach = up_attach,
.detach = up_detach,
.ioctl = up_ioctl,
.receive = up_receive,
.rxint = up_rxint,
.rxavailable = up_rxavailable,
.setup = bl602_setup,
.shutdown = bl602_shutdown,
.attach = bl602_attach,
.detach = bl602_detach,
.ioctl = bl602_ioctl,
.receive = bl602_receive,
.rxint = bl602_rxint,
.rxavailable = bl602_rxavailable,
#ifdef CONFIG_SERIAL_IFLOWCONTROL
.rxflowcontrol = NULL,
#endif
.send = up_send,
.txint = up_txint,
.txready = up_txready,
.txempty = up_txempty,
.send = bl602_send,
.txint = bl602_txint,
.txready = bl602_txready,
.txempty = bl602_txempty,
};
/* I/O buffers */
@ -177,11 +175,9 @@ static const struct uart_ops_s g_uart_ops =
static char g_uart0rxbuffer[CONFIG_UART0_RXBUFSIZE];
static char g_uart0txbuffer[CONFIG_UART0_TXBUFSIZE];
static struct up_dev_s g_uart0priv =
static struct bl602_uart_s g_uart0priv =
{
.uartbase = UART0_BASE,
.irq = BL602_IRQ_UART0,
.config =
{
.idx = 0,
@ -189,10 +185,6 @@ static struct up_dev_s g_uart0priv =
.parity = CONFIG_UART0_PARITY,
.data_bits = CONFIG_UART0_BITS,
.stop_bits = CONFIG_UART0_2STOP,
.tx_pin = CONFIG_BL602_UART0_TX_PIN,
.rx_pin = CONFIG_BL602_UART0_RX_PIN,
.rts_pin = CONFIG_BL602_UART0_RTS_PIN,
.cts_pin = CONFIG_BL602_UART0_CTS_PIN,
#ifdef CONFIG_UART0_IFLOWCONTROL
.iflow_ctl = CONFIG_UART0_IFLOWCONTROL,
@ -232,11 +224,9 @@ static uart_dev_t g_uart0port =
static char g_uart1rxbuffer[CONFIG_UART1_RXBUFSIZE];
static char g_uart1txbuffer[CONFIG_UART1_TXBUFSIZE];
static struct up_dev_s g_uart1priv =
static struct bl602_uart_s g_uart1priv =
{
.uartbase = UART1_BASE,
.irq = BL602_IRQ_UART1,
.config =
{
.idx = 1,
@ -244,10 +234,6 @@ static struct up_dev_s g_uart1priv =
.parity = CONFIG_UART1_PARITY,
.data_bits = CONFIG_UART1_BITS,
.stop_bits = CONFIG_UART1_2STOP,
.tx_pin = CONFIG_BL602_UART1_TX_PIN,
.rx_pin = CONFIG_BL602_UART1_RX_PIN,
.rts_pin = CONFIG_BL602_UART1_RTS_PIN,
.cts_pin = CONFIG_BL602_UART1_CTS_PIN,
#ifdef CONFIG_UART1_IFLOWCONTROL
.iflow_ctl = CONFIG_UART1_IFLOWCONTROL,
@ -307,20 +293,22 @@ static struct uart_dev_s *const g_uart_devs[] =
static int __uart_interrupt(int irq, FAR void *context, FAR void *arg)
{
uart_dev_t * dev = (uart_dev_t *)arg;
struct up_dev_s *uart_priv = dev->priv;
uint32_t tmp_val = 0;
uint32_t mask_val = 0;
uart_dev_t *dev = (uart_dev_t *)arg;
struct bl602_uart_s *priv = dev->priv;
uint8_t uart_idx = priv->config.idx;
uint32_t int_status;
uint32_t int_mask;
tmp_val = bl602_up_serialin(uart_priv->uartbase, UART_INT_STS_OFFSET);
mask_val = bl602_up_serialin(uart_priv->uartbase, UART_INT_MASK_OFFSET);
int_status = getreg32(BL602_UART_INT_STS(uart_idx));
int_mask = getreg32(BL602_UART_INT_MASK(uart_idx));
/* Length of uart rx data transfer arrived interrupt */
if ((tmp_val & (1 << UART_URX_END_INT_POS)) &&
!(mask_val & (1 << UART_CR_URX_END_MASK_POS)))
if ((int_status & UART_INT_STS_URX_END_INT) &&
!(int_mask & UART_INT_MASK_CR_URX_END_MASK))
{
bl602_up_serialout(uart_priv->uartbase, UART_INT_CLEAR_OFFSET, 0x2);
putreg32(UART_INT_CLEAR_CR_URX_END_CLR,
BL602_UART_INT_CLEAR(uart_idx));
/* Receive Data ready */
@ -329,8 +317,8 @@ static int __uart_interrupt(int irq, FAR void *context, FAR void *arg)
/* Tx fifo ready interrupt,auto-cleared when data is pushed */
if ((tmp_val & (1 << UART_UTX_FIFO_INT_POS)) &&
!(mask_val & (1 << UART_CR_UTX_FIFO_MASK_POS)))
if ((int_status & UART_INT_STS_UTX_FIFO_INT) &&
!(int_mask & UART_INT_MASK_CR_UTX_FIFO_MASK))
{
/* Transmit data request interrupt */
@ -339,8 +327,8 @@ static int __uart_interrupt(int irq, FAR void *context, FAR void *arg)
/* Rx fifo ready interrupt,auto-cleared when data is popped */
if ((tmp_val & (1 << UART_URX_FIFO_INT_POS)) &&
!(mask_val & (1 << UART_CR_URX_FIFO_MASK_POS)))
if ((int_status & UART_INT_STS_URX_FIFO_INT) &&
!(int_mask & UART_INT_MASK_CR_URX_FIFO_MASK))
{
/* Receive Data ready */
@ -351,7 +339,7 @@ static int __uart_interrupt(int irq, FAR void *context, FAR void *arg)
}
/****************************************************************************
* Name: up_setup
* Name: bl602_setup
*
* Description:
* Configure the UART baud, bits, parity, etc. This method is called the
@ -359,16 +347,16 @@ static int __uart_interrupt(int irq, FAR void *context, FAR void *arg)
*
****************************************************************************/
static int up_setup(struct uart_dev_s *dev)
static int bl602_setup(struct uart_dev_s *dev)
{
struct up_dev_s *uart_priv = (struct up_dev_s *)dev->priv;
struct bl602_uart_s *priv = (struct bl602_uart_s *)dev->priv;
bl602_uart_configure(uart_priv->uartbase, &uart_priv->config);
bl602_uart_configure(&priv->config);
return OK;
}
/****************************************************************************
* Name: up_shutdown
* Name: bl602_shutdown
*
* Description:
* Disable the UART. This method is called when the serial
@ -376,18 +364,19 @@ static int up_setup(struct uart_dev_s *dev)
*
****************************************************************************/
static void up_shutdown(struct uart_dev_s *dev)
static void bl602_shutdown(struct uart_dev_s *dev)
{
struct up_dev_s *uart_priv = (struct up_dev_s *)dev->priv;
struct bl602_uart_s *priv = (struct bl602_uart_s *)dev->priv;
uint8_t uart_idx = priv->config.idx;
/* Disable uart before config */
bl602_up_serialmodify(uart_priv->uartbase, UART_UTX_CONFIG_OFFSET, 1, 0);
bl602_up_serialmodify(uart_priv->uartbase, UART_URX_CONFIG_OFFSET, 1, 0);
modifyreg32(BL602_UART_UTX_CONFIG(uart_idx), UART_UTX_CONFIG_CR_EN, 0);
modifyreg32(BL602_UART_URX_CONFIG(uart_idx), UART_URX_CONFIG_CR_EN, 0);
}
/****************************************************************************
* Name: up_attach
* Name: bl602_attach
*
* Description:
* Configure the UART to operation in interrupt driven mode. This method
@ -401,10 +390,10 @@ static void up_shutdown(struct uart_dev_s *dev)
*
****************************************************************************/
static int up_attach(struct uart_dev_s *dev)
static int bl602_attach(struct uart_dev_s *dev)
{
int ret;
struct up_dev_s *priv = (struct up_dev_s *)dev->priv;
struct bl602_uart_s *priv = (struct bl602_uart_s *)dev->priv;
ret = irq_attach(priv->irq, __uart_interrupt, (void *)dev);
if (ret == OK)
@ -416,7 +405,7 @@ static int up_attach(struct uart_dev_s *dev)
}
/****************************************************************************
* Name: up_detach
* Name: bl602_detach
*
* Description:
* Detach UART interrupts. This method is called when the serial port is
@ -425,9 +414,9 @@ static int up_attach(struct uart_dev_s *dev)
*
****************************************************************************/
static void up_detach(struct uart_dev_s *dev)
static void bl602_detach(struct uart_dev_s *dev)
{
struct up_dev_s *priv = (struct up_dev_s *)dev->priv;
struct bl602_uart_s *priv = (struct bl602_uart_s *)dev->priv;
/* Disable interrupts */
@ -439,24 +428,14 @@ static void up_detach(struct uart_dev_s *dev)
}
/****************************************************************************
* Name: bl602_data_getbits
****************************************************************************/
static uint32_t
bl602_data_getbits(uint32_t data, uint32_t start, uint32_t len)
{
return (((data) >> (start)) & (~((~0) << (len))));
}
/****************************************************************************
* Name: up_ioctl
* Name: bl602_ioctl
*
* Description:
* All ioctl calls will be routed through this method
*
****************************************************************************/
static int up_ioctl(struct file *filep, int cmd, unsigned long arg)
static int bl602_ioctl(struct file *filep, int cmd, unsigned long arg)
{
#if defined(CONFIG_SERIAL_TERMIOS) || defined(CONFIG_SERIAL_TIOCSERGSTRUCT)
struct inode * inode = filep->f_inode;
@ -471,7 +450,7 @@ static int up_ioctl(struct file *filep, int cmd, unsigned long arg)
do
{
struct termios * termiosp = (struct termios *)arg;
struct up_dev_s *priv = (struct up_dev_s *)dev->priv;
struct bl602_uart_s *priv = (struct bl602_uart_s *)dev->priv;
if (!termiosp)
{
@ -527,7 +506,7 @@ static int up_ioctl(struct file *filep, int cmd, unsigned long arg)
do
{
struct termios * termiosp = (struct termios *)arg;
struct up_dev_s * priv = (struct up_dev_s *)dev->priv;
struct bl602_uart_s * priv = (struct bl602_uart_s *)dev->priv;
struct uart_config_s config;
uint32_t tmp_val;
@ -615,11 +594,9 @@ static int up_ioctl(struct file *filep, int cmd, unsigned long arg)
* implement TCSADRAIN / TCSAFLUSH
*/
tmp_val =
bl602_up_serialin(priv->uartbase, UART_INT_MASK_OFFSET);
bl602_uart_configure(priv->uartbase, &config);
bl602_up_serialout(
priv->uartbase, UART_INT_MASK_OFFSET, tmp_val);
tmp_val = getreg32(BL602_UART_INT_MASK(config->idx));
bl602_uart_configure(&config);
putreg32(tmp_val, BL602_UART_INT_MASK(config->idx));
}
}
while (0);
@ -635,7 +612,7 @@ static int up_ioctl(struct file *filep, int cmd, unsigned long arg)
}
/****************************************************************************
* Name: up_receive
* Name: bl602_receive
*
* Description:
* Called (usually) from the interrupt level to receive one
@ -644,10 +621,11 @@ static int up_ioctl(struct file *filep, int cmd, unsigned long arg)
*
****************************************************************************/
static int up_receive(struct uart_dev_s *dev, unsigned int *status)
static int bl602_receive(struct uart_dev_s *dev, unsigned int *status)
{
struct up_dev_s *priv = (struct up_dev_s *)dev->priv;
int rxdata;
struct bl602_uart_s *priv = (struct bl602_uart_s *)dev->priv;
uint8_t uart_idx = priv->config.idx;
int rxdata;
/* Return status information */
@ -658,12 +636,11 @@ static int up_receive(struct uart_dev_s *dev, unsigned int *status)
/* if uart fifo cnts > 0 */
if (bl602_data_getbits(
bl602_up_serialin(priv->uartbase, UART_FIFO_CONFIG_1_OFFSET),
UART_RX_FIFO_CNT_POS,
6) > 0)
if (getreg32(BL602_UART_FIFO_CONFIG_1(uart_idx)) & \
UART_FIFO_CONFIG_1_RX_CNT_MASK)
{
rxdata = bl602_up_serialin(priv->uartbase, UART_FIFO_RDATA_OFFSET);
rxdata = getreg32(BL602_UART_FIFO_RDATA(uart_idx)) & \
UART_FIFO_RDATA_MASK;
}
else
{
@ -673,97 +650,94 @@ static int up_receive(struct uart_dev_s *dev, unsigned int *status)
}
/****************************************************************************
* Name: up_rxint
* Name: bl602_rxint
*
* Description:
* Call to enable or disable RX interrupts
*
****************************************************************************/
static void up_rxint(struct uart_dev_s *dev, bool enable)
static void bl602_rxint(struct uart_dev_s *dev, bool enable)
{
uint32_t tmp_val;
struct up_dev_s *priv = (struct up_dev_s *)dev->priv;
uint32_t int_mask;
struct bl602_uart_s *priv = (struct bl602_uart_s *)dev->priv;
uint8_t uart_idx = priv->config.idx;
irqstate_t flags = enter_critical_section();
if (enable)
{
#ifndef CONFIG_SUPPRESS_SERIAL_INTS
tmp_val = bl602_up_serialin(priv->uartbase, UART_INT_MASK_OFFSET);
tmp_val &= ~(1 << UART_INT_RX_FIFO_REQ);
tmp_val &= ~(1 << UART_INT_RX_END);
bl602_up_serialout(priv->uartbase, UART_INT_MASK_OFFSET, tmp_val);
int_mask = getreg32(BL602_UART_INT_MASK(uart_idx));
int_mask &= ~(UART_INT_MASK_CR_URX_FIFO_MASK);
int_mask &= ~(UART_INT_MASK_CR_URX_END_MASK);
putreg32(int_mask, BL602_UART_INT_MASK(uart_idx));
#endif
}
else
{
tmp_val = bl602_up_serialin(priv->uartbase, UART_INT_MASK_OFFSET);
tmp_val |= (1 << UART_INT_RX_FIFO_REQ);
tmp_val |= (1 << UART_INT_RX_END);
bl602_up_serialout(priv->uartbase, UART_INT_MASK_OFFSET, tmp_val);
int_mask = getreg32(BL602_UART_INT_MASK(uart_idx));
int_mask |= UART_INT_MASK_CR_URX_FIFO_MASK;
int_mask |= UART_INT_MASK_CR_URX_END_MASK;
putreg32(int_mask, BL602_UART_INT_MASK(uart_idx));
}
leave_critical_section(flags);
}
/****************************************************************************
* Name: up_rxavailable
* Name: bl602_rxavailable
*
* Description:
* Return true if the receive register is not empty
*
****************************************************************************/
static bool up_rxavailable(struct uart_dev_s *dev)
static bool bl602_rxavailable(struct uart_dev_s *dev)
{
struct up_dev_s *priv = (struct up_dev_s *)dev->priv;
struct bl602_uart_s *priv = (struct bl602_uart_s *)dev->priv;
uint8_t uart_idx = priv->config.idx;
/* Return true is data is available in the receive data buffer */
uint32_t rxcnt = bl602_data_getbits(
bl602_up_serialin(priv->uartbase, UART_FIFO_CONFIG_1_OFFSET),
UART_RX_FIFO_CNT_POS,
6);
return rxcnt != 0;
return (getreg32(BL602_UART_FIFO_CONFIG_1(uart_idx)) & \
UART_FIFO_CONFIG_1_RX_CNT_MASK) != 0;
}
/****************************************************************************
* Name: up_send
* Name: bl602_send
*
* Description:
* This method will send one byte on the UART.
*
****************************************************************************/
static void up_send(struct uart_dev_s *dev, int ch)
static void bl602_send(struct uart_dev_s *dev, int ch)
{
struct up_dev_s *priv = (struct up_dev_s *)dev->priv;
struct bl602_uart_s *priv = (struct bl602_uart_s *)dev->priv;
uint8_t uart_idx = priv->config.idx;
/* Wait for FIFO */
/* Wait for FIFO to be empty */
while (bl602_data_getbits(
bl602_up_serialin(priv->uartbase, UART_FIFO_CONFIG_1_OFFSET),
UART_TX_FIFO_CNT_POS,
6) == 0)
;
while ((getreg32(BL602_UART_FIFO_CONFIG_1(uart_idx)) & \
UART_FIFO_CONFIG_1_TX_CNT_MASK) == 0);
bl602_up_serialout(priv->uartbase, UART_FIFO_WDATA_OFFSET, ch);
putreg32(ch, BL602_UART_FIFO_WDATA(uart_idx));
}
/****************************************************************************
* Name: up_txint
* Name: bl602_txint
*
* Description:
* Call to enable or disable TX interrupts
*
****************************************************************************/
static void up_txint(struct uart_dev_s *dev, bool enable)
static void bl602_txint(struct uart_dev_s *dev, bool enable)
{
struct up_dev_s *priv = (struct up_dev_s *)dev->priv;
struct bl602_uart_s *priv = (struct bl602_uart_s *)dev->priv;
uint8_t uart_idx = priv->config.idx;
irqstate_t flags;
uint32_t tmp_val;
uint32_t int_mask;
flags = enter_critical_section();
@ -772,9 +746,9 @@ static void up_txint(struct uart_dev_s *dev, bool enable)
#ifndef CONFIG_SUPPRESS_SERIAL_INTS
/* Enable the TX interrupt */
tmp_val = bl602_up_serialin(priv->uartbase, UART_INT_MASK_OFFSET);
tmp_val &= ~(1 << UART_INT_TX_FIFO_REQ);
bl602_up_serialout(priv->uartbase, UART_INT_MASK_OFFSET, tmp_val);
int_mask = getreg32(BL602_UART_INT_MASK(uart_idx));
int_mask &= ~(UART_INT_MASK_CR_UTX_FIFO_MASK);
putreg32(int_mask, BL602_UART_INT_MASK(uart_idx));
/* Fake a TX interrupt here by just calling uart_xmitchars() with
* interrupts disabled (note this may recurse).
@ -787,55 +761,48 @@ static void up_txint(struct uart_dev_s *dev, bool enable)
{
/* Disable the TX interrupt */
tmp_val = bl602_up_serialin(priv->uartbase, UART_INT_MASK_OFFSET);
tmp_val |= (1 << UART_INT_TX_FIFO_REQ);
bl602_up_serialout(priv->uartbase, UART_INT_MASK_OFFSET, tmp_val);
int_mask = getreg32(BL602_UART_INT_MASK(uart_idx));
int_mask |= UART_INT_MASK_CR_UTX_FIFO_MASK;
putreg32(int_mask, BL602_UART_INT_MASK(uart_idx));
}
leave_critical_section(flags);
}
/****************************************************************************
* Name: up_txready
* Name: bl602_txready
*
* Description:
* Return true if the tranmsit data register is not full
* Return true if the transmit data register is not full
*
****************************************************************************/
static bool up_txready(struct uart_dev_s *dev)
static bool bl602_txready(struct uart_dev_s *dev)
{
struct up_dev_s *priv = (struct up_dev_s *)dev->priv;
struct bl602_uart_s *priv = (struct bl602_uart_s *)dev->priv;
uint8_t uart_idx = priv->config.idx;
/* Return TRUE if the TX FIFO is not full */
uint32_t txcnt =
bl602_up_serialin(priv->uartbase, UART_FIFO_CONFIG_1_OFFSET);
txcnt = (txcnt & UART_TX_FIFO_CNT_MSK) >> UART_TX_FIFO_CNT_POS;
return (txcnt != 0);
return (getreg32(BL602_UART_FIFO_CONFIG_1(uart_idx)) & \
UART_FIFO_CONFIG_1_TX_CNT_MASK) != 0;
}
/****************************************************************************
* Name: up_txempty
* Name: bl602_txempty
*
* Description:
* Return true if the tranmsit data register is empty
* Return true if the transmit data register is empty
*
****************************************************************************/
static bool up_txempty(struct uart_dev_s *dev)
static bool bl602_txempty(struct uart_dev_s *dev)
{
struct up_dev_s *priv = (struct up_dev_s *)dev->priv;
struct bl602_uart_s *priv = (struct bl602_uart_s *)dev->priv;
uint8_t uart_idx = priv->config.idx;
/* Return TRUE if the TX is pending */
uint32_t txcnt = bl602_data_getbits(
bl602_up_serialin(priv->uartbase, UART_FIFO_CONFIG_1_OFFSET),
UART_TX_FIFO_CNT_POS,
6);
return (txcnt == 0);
return (getreg32(BL602_UART_FIFO_CONFIG_1(uart_idx)) & \
UART_FIFO_CONFIG_1_TX_CNT_MASK) == 0;
}
/****************************************************************************
@ -851,8 +818,8 @@ static bool up_txempty(struct uart_dev_s *dev)
* Performs the low level UART initialization early in debug so that the
* serial console will be available during bootup. This must be called
* before up_serialinit. NOTE: This function depends on GPIO pin
* configuration performed in up_consoleinit() and main clock iniialization
* performed in up_clkinitialize().
* configuration performed in up_consoleinit() and main clock
* initialization performed in up_clkinitialize().
*
****************************************************************************/
@ -862,7 +829,7 @@ void up_earlyserialinit(void)
/* Configuration whichever one is the console */
CONSOLE_DEV.isconsole = true;
up_setup(&CONSOLE_DEV);
bl602_setup(&CONSOLE_DEV);
#endif
}
#endif
@ -922,7 +889,7 @@ void up_serialinit(void)
int up_putc(int ch)
{
#ifdef HAVE_SERIAL_CONSOLE
struct up_dev_s *priv = (struct up_dev_s *)CONSOLE_DEV.priv;
struct bl602_uart_s *priv = (struct bl602_uart_s *)CONSOLE_DEV.priv;
(void)priv;
irqstate_t flags = enter_critical_section();

View File

@ -64,15 +64,15 @@
static uint8_t g_idle_stack[BL602_IDLESTACK_SIZE];
/* Dont change the name of varaible, since we refer this
/* Dont change the name of variable, since we refer this
* boot2_partition_table in linker script
*/
static struct
{
uint8_t partition_active_idx;
uint8_t pad[3];
struct pt_table_stuff_config_s table;
uint8_t partition_active_idx;
uint8_t pad[3];
struct pt_stuff_config_s table;
} boot2_partition_table;
/****************************************************************************
@ -98,8 +98,8 @@ uint32_t boot2_get_flash_addr(void)
extern uint8_t __boot2_flash_cfg_src;
return (uint32_t)(&__boot2_flash_cfg_src +
(sizeof(boot2_partition_table.table.pt_entries[0]) *
boot2_partition_table.table.pt_table.entry_cnt));
(sizeof(boot2_partition_table.table.entries[0]) *
boot2_partition_table.table.table.entry_cnt));
}
/****************************************************************************
@ -108,8 +108,6 @@ uint32_t boot2_get_flash_addr(void)
void bfl_main(void)
{
uint32_t tmp_val;
/* set interrupt vector */
asm volatile("csrw mtvec, %0" ::"r"((uintptr_t)exception_common + 2));
@ -120,10 +118,7 @@ void bfl_main(void)
/* HBN Config AON pad input and SMT */
tmp_val = getreg32(HBN_BASE + HBN_IRQ_MODE_OFFSET);
tmp_val = (tmp_val & HBN_REG_AON_PAD_IE_SMT_UMSK) |
(1 << HBN_REG_AON_PAD_IE_SMT_POS);
putreg32(tmp_val, HBN_BASE + HBN_IRQ_MODE_OFFSET);
modifyreg32(BL602_HBN_IRQ_MODE, 0, HBN_IRQ_MODE_REG_AON_PAD_IE_SMT);
#ifdef USE_EARLYSERIALINIT
up_earlyserialinit();

View File

@ -22,55 +22,24 @@
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include <stdint.h>
#include <stdbool.h>
#include <hardware/bl602_timer.h>
#include "bl602_tim.h"
#include "riscv_arch.h"
#include "riscv_internal.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
#define TIMER_MAX_MATCH 3
/****************************************************************************
* Static Functions
****************************************************************************/
static inline uint32_t bl602_up_tim_regin(uint32_t reg_addr)
{
return getreg32(reg_addr);
}
static inline void bl602_up_tim_regout(uint32_t reg_addr, uint32_t value)
{
putreg32(value, reg_addr);
}
/****************************************************************************
* Name: bl602_data_setbits
****************************************************************************/
static uint32_t bl602_data_setbits(uint32_t data,
uint32_t start,
uint32_t len,
uint32_t value)
{
return (((data) & ~((~((~0) << (len))) << (start))) |
(((value) & ((~((~0) << (len))))) << (start)));
}
static void bl602_wdt_access(void)
{
uint32_t tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_WFAR_OFFSET);
bl602_up_tim_regout(
TIMER_BASE + TIMER_WFAR_OFFSET,
bl602_data_setbits(tmp_val, TIMER_WFAR_POS, 16, 0xbaba));
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_WSAR_OFFSET);
bl602_up_tim_regout(
TIMER_BASE + TIMER_WSAR_OFFSET,
bl602_data_setbits(tmp_val, TIMER_WSAR_POS, 16, 0xeb10));
modifyreg32(BL602_TIMER_WFAR, TIMER_WFAR_MASK, 0xbaba);
modifyreg32(BL602_TIMER_WFAR, TIMER_WSAR_MASK, 0xeb10);
}
/****************************************************************************
@ -92,13 +61,10 @@ static void bl602_wdt_access(void)
*
****************************************************************************/
uint32_t bl602_timer_getcompvalue(uint32_t timer_ch, uint32_t cmp_no)
uint32_t bl602_timer_getcompvalue(uint8_t timer_ch, uint8_t cmp_no)
{
uint32_t tmp_val;
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_TMR2_0_OFFSET +
4 * (TIMER_MAX_MATCH * timer_ch + cmp_no));
return tmp_val;
return getreg32(BL602_TIMER_TMR2_0 + \
4 * (TIMER_MAX_MATCH * timer_ch + cmp_no));
}
/****************************************************************************
@ -117,13 +83,12 @@ uint32_t bl602_timer_getcompvalue(uint32_t timer_ch, uint32_t cmp_no)
*
****************************************************************************/
void bl602_timer_setcompvalue(uint32_t timer_ch,
uint32_t cmp_no,
void bl602_timer_setcompvalue(uint8_t timer_ch,
uint8_t cmp_no,
uint32_t val)
{
bl602_up_tim_regout(TIMER_BASE + TIMER_TMR2_0_OFFSET +
4 * (TIMER_MAX_MATCH * timer_ch + cmp_no),
val);
putreg32(val,
BL602_TIMER_TMR2_0 + 4 * (TIMER_MAX_MATCH * timer_ch + cmp_no));
}
/****************************************************************************
@ -142,23 +107,23 @@ void bl602_timer_setcompvalue(uint32_t timer_ch,
uint32_t bl602_timer_getcountervalue(uint32_t timer_ch)
{
uint32_t tmp_val;
uint32_t tmp_addr;
uint32_t count;
uint32_t tcvwr_addr;
/* TO avoid risk of reading, don't read TCVWR directly
* request for read
* request for read. Why? This register is read-only.
*/
tmp_addr = TIMER_BASE + TIMER_TCVWR2_OFFSET + 4 * timer_ch;
bl602_up_tim_regout(tmp_addr, 1);
tcvwr_addr = BL602_TIMER_TCVWR2 + 4 * timer_ch;
putreg32(1, tcvwr_addr);
/* Need wait */
tmp_val = bl602_up_tim_regin(tmp_addr);
tmp_val = bl602_up_tim_regin(tmp_addr);
tmp_val = bl602_up_tim_regin(tmp_addr);
count = getreg32(tcvwr_addr);
count = getreg32(tcvwr_addr);
count = getreg32(tcvwr_addr);
return tmp_val;
return count;
}
/****************************************************************************
@ -172,33 +137,27 @@ uint32_t bl602_timer_getcountervalue(uint32_t timer_ch)
* cmp_no - TIMER comparator ID type.
*
* Returned Value:
* 0 or 1
* match status
*
****************************************************************************/
uint32_t bl602_timer_getmatchstatus(uint32_t timer_ch, uint32_t cmp_no)
bool bl602_timer_getmatchstatus(uint32_t timer_ch, uint8_t cmp_no)
{
uint32_t tmp_val;
uint32_t bit_status = 0;
uint32_t status = getreg32(BL602_TIMER_TMSR2 + 4 * timer_ch);
tmp_val =
bl602_up_tim_regin(TIMER_BASE + TIMER_TMSR2_OFFSET + 4 * timer_ch);
switch (cmp_no)
{
case TIMER_COMP_ID_0:
bit_status = (((tmp_val) & (1 << (TIMER_TMSR_0_POS))) ? 1 : 0);
break;
return ((status & TIMER_TMSR2_TMSR_0) != 0);
case TIMER_COMP_ID_1:
bit_status = (((tmp_val) & (1 << (TIMER_TMSR_1_POS))) ? 1 : 0);
break;
return ((status & TIMER_TMSR2_TMSR_1) != 0);
case TIMER_COMP_ID_2:
bit_status = (((tmp_val) & (1 << (TIMER_TMSR_2_POS))) ? 1 : 0);
break;
return ((status & TIMER_TMSR2_TMSR_2) != 0);
default:
break;
}
return bit_status;
return false;
}
/****************************************************************************
@ -217,11 +176,7 @@ uint32_t bl602_timer_getmatchstatus(uint32_t timer_ch, uint32_t cmp_no)
uint32_t bl602_timer_getpreloadvalue(uint32_t timer_ch)
{
uint32_t tmp_val;
tmp_val =
bl602_up_tim_regin(TIMER_BASE + TIMER_TPLVR2_OFFSET + 4 * timer_ch);
return tmp_val;
return getreg32(BL602_TIMER_TPLVR2 + 4 * timer_ch);
}
/****************************************************************************
@ -239,9 +194,9 @@ uint32_t bl602_timer_getpreloadvalue(uint32_t timer_ch)
*
****************************************************************************/
void bl602_timer_setpreloadvalue(uint32_t timer_ch, uint32_t val)
void bl602_timer_setpreloadvalue(uint8_t timer_ch, uint32_t val)
{
bl602_up_tim_regout(TIMER_BASE + TIMER_TPLVR2_OFFSET + 4 * timer_ch, val);
putreg32(val, BL602_TIMER_TPLVR2 + 4 * timer_ch);
}
/****************************************************************************
@ -259,10 +214,9 @@ void bl602_timer_setpreloadvalue(uint32_t timer_ch, uint32_t val)
*
****************************************************************************/
void bl602_timer_setpreloadtrigsrc(uint32_t timer_ch, uint32_t pl_src)
void bl602_timer_setpreloadtrigsrc(uint8_t timer_ch, uint32_t pl_src)
{
bl602_up_tim_regout(TIMER_BASE + TIMER_TPLCR2_OFFSET + 4 * timer_ch,
pl_src);
putreg32(pl_src, BL602_TIMER_TPLCR2 + 4 * timer_ch);
}
/****************************************************************************
@ -272,24 +226,20 @@ void bl602_timer_setpreloadtrigsrc(uint32_t timer_ch, uint32_t pl_src)
* TIMER set count mode:preload or free run
*
* Input Parameters:
* timer_ch - TIMER channel type.
* timer_ch - TIMER channel type.
* count_mode - TIMER count mode: TIMER_COUNT_PRELOAD or
*TIMER_COUNT_FREERUN.
* TIMER_COUNT_FREERUN.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_timer_setcountmode(uint32_t timer_ch, uint32_t count_mode)
void bl602_timer_setcountmode(uint32_t timer_ch, uint8_t count_mode)
{
uint32_t tmpval;
tmpval = bl602_up_tim_regin(TIMER_BASE + TIMER_TCMR_OFFSET);
tmpval &= (~(1 << (timer_ch + 1)));
tmpval |= (count_mode << (timer_ch + 1));
bl602_up_tim_regout(TIMER_BASE + TIMER_TCMR_OFFSET, tmpval);
modifyreg32(BL602_TIMER_TCMR,
TIMER_TCMR_TIMER2_MODE << timer_ch,
count_mode ? TIMER_TCMR_TIMER2_MODE << timer_ch : 0);
}
/****************************************************************************
@ -307,17 +257,9 @@ void bl602_timer_setcountmode(uint32_t timer_ch, uint32_t count_mode)
*
****************************************************************************/
void bl602_timer_clearintstatus(uint32_t timer_ch, uint32_t cmp_no)
void bl602_timer_clearintstatus(uint8_t timer_ch, uint32_t cmp_no)
{
uint32_t tmp_addr;
uint32_t tmp_val;
tmp_addr = TIMER_BASE + TIMER_TICR2_OFFSET + 4 * timer_ch;
tmp_val = bl602_up_tim_regin(tmp_addr);
tmp_val |= (1 << cmp_no);
bl602_up_tim_regout(tmp_addr, tmp_val);
putreg32(BL602_TIMER_TICR2 + 4 * timer_ch, 1 << cmp_no);
}
/****************************************************************************
@ -334,43 +276,36 @@ void bl602_timer_clearintstatus(uint32_t timer_ch, uint32_t cmp_no)
*
****************************************************************************/
void bl602_timer_init(timer_cfg_t *timer_cfg)
void bl602_timer_init(struct timer_cfg_s *timer_cfg)
{
uint32_t timer_ch = timer_cfg->timer_ch;
uint32_t tmp_val;
uint8_t timer_ch = timer_cfg->timer_ch;
/* Configure timer clock source */
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_TCCR_OFFSET);
if (timer_ch == TIMER_CH0)
{
tmp_val =
bl602_data_setbits(tmp_val, TIMER_CS_1_POS, 2, timer_cfg->clk_src);
modifyreg32(BL602_TIMER_TCCR, TIMER_TCCR_CS_1_MASK,
timer_cfg->clk_src << TIMER_TCCR_CS_1_SHIFT);
}
else
{
tmp_val =
bl602_data_setbits(tmp_val, TIMER_CS_2_POS, 2, timer_cfg->clk_src);
modifyreg32(BL602_TIMER_TCCR, TIMER_TCCR_CS_2_MASK,
timer_cfg->clk_src << TIMER_TCCR_CS_2_SHIFT);
}
bl602_up_tim_regout(TIMER_BASE + TIMER_TCCR_OFFSET, tmp_val);
/* Configure timer clock division */
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_TCDR_OFFSET);
if (timer_ch == TIMER_CH0)
{
tmp_val = bl602_data_setbits(
tmp_val, TIMER_TCDR2_POS, 8, timer_cfg->clock_division);
modifyreg32(BL602_TIMER_TCDR, TIMER_TCDR_TCDR2_MASK,
timer_cfg->clock_division << TIMER_TCDR_TCDR2_SHIFT);
}
else
{
tmp_val = bl602_data_setbits(
tmp_val, TIMER_TCDR3_POS, 8, timer_cfg->clock_division);
modifyreg32(BL602_TIMER_TCDR, TIMER_TCDR_TCDR3_MASK,
timer_cfg->clock_division << TIMER_TCDR_TCDR3_SHIFT);
}
bl602_up_tim_regout(TIMER_BASE + TIMER_TCDR_OFFSET, tmp_val);
/* Configure timer count mode: preload or free run */
bl602_timer_setcountmode(timer_ch, timer_cfg->count_mode);
@ -388,9 +323,9 @@ void bl602_timer_init(timer_cfg_t *timer_cfg)
/* Configure match compare values */
bl602_timer_setcompvalue(timer_ch, TIMER_COMP_ID_0, timer_cfg->match_val0);
bl602_timer_setcompvalue(timer_ch, TIMER_COMP_ID_1, timer_cfg->match_val1);
bl602_timer_setcompvalue(timer_ch, TIMER_COMP_ID_2, timer_cfg->match_val2);
bl602_timer_setcompvalue(timer_ch, 0, timer_cfg->match_val0);
bl602_timer_setcompvalue(timer_ch, 1, timer_cfg->match_val1);
bl602_timer_setcompvalue(timer_ch, 2, timer_cfg->match_val2);
}
/****************************************************************************
@ -407,14 +342,9 @@ void bl602_timer_init(timer_cfg_t *timer_cfg)
*
****************************************************************************/
void bl602_timer_enable(uint32_t timer_ch)
void bl602_timer_enable(uint8_t timer_ch)
{
uint32_t tmp_val;
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_TCER_OFFSET);
tmp_val |= (1 << (timer_ch + 1));
bl602_up_tim_regout(TIMER_BASE + TIMER_TCER_OFFSET, tmp_val);
modifyreg32(BL602_TIMER_TCER, 0, (TIMER_TCER_TIMER2_EN << timer_ch));
}
/****************************************************************************
@ -431,14 +361,9 @@ void bl602_timer_enable(uint32_t timer_ch)
*
****************************************************************************/
void bl602_timer_disable(uint32_t timer_ch)
void bl602_timer_disable(uint8_t timer_ch)
{
uint32_t tmp_val;
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_TCER_OFFSET);
tmp_val &= (~(1 << (timer_ch + 1)));
bl602_up_tim_regout(TIMER_BASE + TIMER_TCER_OFFSET, tmp_val);
modifyreg32(BL602_TIMER_TCER, (TIMER_TCER_TIMER2_EN << timer_ch), 0);
}
/****************************************************************************
@ -451,22 +376,17 @@ void bl602_timer_disable(uint32_t timer_ch)
* timer_ch - TIMER channel type.
* int_type - TIMER interrupt type.
* int_mask - TIMER interrupt mask value:1:disbale interrupt.0:enable
*interrupt.
* interrupt.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_timer_intmask(uint32_t timer_ch,
uint32_t int_type,
uint32_t int_mask)
void bl602_timer_intmask(uint8_t timer_ch, uint8_t int_type,
uint8_t int_mask)
{
uint32_t tmp_addr;
uint32_t tmp_val;
tmp_addr = TIMER_BASE + TIMER_TIER2_OFFSET + 4 * timer_ch;
tmp_val = bl602_up_tim_regin(tmp_addr);
uint32_t tier_addr = BL602_TIMER_TIER2 + 4 * timer_ch;
switch (int_type)
{
@ -475,13 +395,13 @@ void bl602_timer_intmask(uint32_t timer_ch,
{
/* Enable this interrupt */
bl602_up_tim_regout(tmp_addr, tmp_val |= 1 << TIMER_TIER_0_POS);
modifyreg32(tier_addr, 0, TIMER_TIER2_TIER_0);
}
else
{
/* Disable this interrupt */
bl602_up_tim_regout(tmp_addr, tmp_val &= ~(1 << TIMER_TIER_0_POS));
modifyreg32(tier_addr, TIMER_TIER2_TIER_0, 0);
}
break;
@ -491,13 +411,13 @@ void bl602_timer_intmask(uint32_t timer_ch,
{
/* Enable this interrupt */
bl602_up_tim_regout(tmp_addr, tmp_val |= 1 << TIMER_TIER_1_POS);
modifyreg32(tier_addr, 0, TIMER_TIER2_TIER_1);
}
else
{
/* Disable this interrupt */
bl602_up_tim_regout(tmp_addr, tmp_val &= ~(1 << TIMER_TIER_1_POS));
modifyreg32(tier_addr, TIMER_TIER2_TIER_1, 0);
}
break;
@ -507,13 +427,13 @@ void bl602_timer_intmask(uint32_t timer_ch,
{
/* Enable this interrupt */
bl602_up_tim_regout(tmp_addr, tmp_val |= 1 << TIMER_TIER_2_POS);
modifyreg32(tier_addr, 0, TIMER_TIER2_TIER_2);
}
else
{
/* Disable this interrupt */
bl602_up_tim_regout(tmp_addr, tmp_val &= ~(1 << TIMER_TIER_2_POS));
modifyreg32(tier_addr, TIMER_TIER2_TIER_2, 0);
}
break;
@ -523,17 +443,15 @@ void bl602_timer_intmask(uint32_t timer_ch,
{
/* Enable this interrupt */
bl602_up_tim_regout(tmp_addr, tmp_val |= 1 << TIMER_TIER_0_POS);
bl602_up_tim_regout(tmp_addr, tmp_val |= 1 << TIMER_TIER_1_POS);
bl602_up_tim_regout(tmp_addr, tmp_val |= 1 << TIMER_TIER_2_POS);
modifyreg32(tier_addr, 0,
TIMER_TIER2_TIER_0 | TIMER_TIER2_TIER_1 | TIMER_TIER2_TIER_2);
}
else
{
/* Disable this interrupt */
bl602_up_tim_regout(tmp_addr, tmp_val &= ~(1 << TIMER_TIER_0_POS));
bl602_up_tim_regout(tmp_addr, tmp_val &= ~(1 << TIMER_TIER_1_POS));
bl602_up_tim_regout(tmp_addr, tmp_val &= ~(1 << TIMER_TIER_2_POS));
modifyreg32(tier_addr,
TIMER_TIER2_TIER_0 | TIMER_TIER2_TIER_1 | TIMER_TIER2_TIER_2, 0);
}
break;
@ -558,21 +476,17 @@ void bl602_timer_intmask(uint32_t timer_ch,
*
****************************************************************************/
void bl602_wdt_set_clock(uint32_t clk_src, uint8_t div)
void bl602_wdt_set_clock(uint8_t clk_src, uint8_t div)
{
uint32_t tmp_val;
/* Configure watchdog timer clock source */
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_TCCR_OFFSET);
tmp_val = bl602_data_setbits(tmp_val, TIMER_CS_WDT_POS, 2, clk_src);
bl602_up_tim_regout(TIMER_BASE + TIMER_TCCR_OFFSET, tmp_val);
modifyreg32(BL602_TIMER_TCCR, TIMER_TCCR_CS_WDT_MASK,
clk_src << TIMER_TCCR_CS_WDT_SHIFT);
/* Configure watchdog timer clock divison */
/* Configure watchdog timer clock division */
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_TCDR_OFFSET);
tmp_val = bl602_data_setbits(tmp_val, TIMER_WCDR_POS, 8, div);
bl602_up_tim_regout(TIMER_BASE + TIMER_TCDR_OFFSET, tmp_val);
modifyreg32(BL602_TIMER_TCDR, TIMER_TCDR_WCDR_MASK,
div << TIMER_TCDR_WCDR_SHIFT);
}
/****************************************************************************
@ -589,17 +503,13 @@ void bl602_wdt_set_clock(uint32_t clk_src, uint8_t div)
*
****************************************************************************/
uint32_t bl602_wdt_getmatchvalue(void)
uint16_t bl602_wdt_getmatchvalue(void)
{
uint32_t tmp_val;
bl602_wdt_access();
/* Get watchdog timer match register value */
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_WMR_OFFSET);
return tmp_val;
return (uint16_t)(getreg32(BL602_TIMER_WMR) & TIMER_WMR_WMR_MASK);
}
/****************************************************************************
@ -622,7 +532,7 @@ void bl602_wdt_setcompvalue(uint16_t val)
/* Set watchdog timer match register value */
bl602_up_tim_regout(TIMER_BASE + TIMER_WMR_OFFSET, val);
putreg32(val, BL602_TIMER_WMR);
}
/****************************************************************************
@ -641,15 +551,11 @@ void bl602_wdt_setcompvalue(uint16_t val)
uint16_t bl602_wdt_getcountervalue(void)
{
uint32_t tmp_val;
bl602_wdt_access();
/* Get watchdog timer count register value */
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_WVR_OFFSET);
return tmp_val;
return (uint16_t)(getreg32(BL602_TIMER_WVR) & TIMER_WVR_WVR_MASK);
}
/****************************************************************************
@ -668,18 +574,13 @@ uint16_t bl602_wdt_getcountervalue(void)
void bl602_wdt_resetcountervalue(void)
{
uint32_t tmp_val;
/* Reset watchdog timer count register value */
bl602_wdt_access();
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_WCR_OFFSET);
/* Set watchdog counter reset register bit0 to 1 */
bl602_up_tim_regout(TIMER_BASE + TIMER_WCR_OFFSET,
tmp_val |= 1 << TIMER_WCR_POS);
modifyreg32(BL602_TIMER_WCR, 0, TIMER_WCR_WCR);
}
/****************************************************************************
@ -696,19 +597,13 @@ void bl602_wdt_resetcountervalue(void)
*
****************************************************************************/
uint32_t bl602_wdt_getresetstatus(void)
bool bl602_wdt_getresetstatus(void)
{
uint32_t tmp_val;
uint32_t ret;
bl602_wdt_access();
/* Get watchdog status register */
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_WSR_OFFSET);
ret = (((tmp_val) & (1 << (TIMER_WTS_POS))) ? 1 : 0);
return ret;
return ((getreg32(BL602_TIMER_WSR) & TIMER_WSR_WTS) != 0);
}
/****************************************************************************
@ -727,16 +622,11 @@ uint32_t bl602_wdt_getresetstatus(void)
void bl602_wdt_clearresetstatus(void)
{
uint32_t tmp_val;
bl602_wdt_access();
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_WSR_OFFSET);
/* Set watchdog status register */
bl602_up_tim_regout(TIMER_BASE + TIMER_WSR_OFFSET,
tmp_val &= ~(1 << TIMER_WTS_POS));
modifyreg32(BL602_TIMER_WSR, TIMER_WSR_WTS, 0);
}
/****************************************************************************
@ -755,14 +645,9 @@ void bl602_wdt_clearresetstatus(void)
void bl602_wdt_enable(void)
{
uint32_t tmp_val;
bl602_wdt_access();
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_WMER_OFFSET);
bl602_up_tim_regout(TIMER_BASE + TIMER_WMER_OFFSET,
tmp_val |= 1 << TIMER_WE_POS);
modifyreg32(BL602_TIMER_WMER, 0, TIMER_WMER_WE);
}
/****************************************************************************
@ -781,14 +666,9 @@ void bl602_wdt_enable(void)
void bl602_wdt_disable(void)
{
uint32_t tmp_val;
bl602_wdt_access();
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_WMER_OFFSET);
bl602_up_tim_regout(TIMER_BASE + TIMER_WMER_OFFSET,
tmp_val &= ~(1 << TIMER_WE_POS));
modifyreg32(BL602_TIMER_WMER, TIMER_WMER_WE, 0);
}
/****************************************************************************
@ -799,26 +679,22 @@ void bl602_wdt_disable(void)
*
* Input Parameters:
* int_type - Watchdog interrupt type.
* int_mask - Watchdog interrupt mask value:BL_STD_MASK:disbale
*interrupt.BL_STD_UNMASK:enable interrupt.
* int_mask - Watchdog interrupt mask value:BL_STD_MASK:disable
* interrupt.BL_STD_UNMASK:enable interrupt.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_wdt_intmask(uint32_t int_type, uint32_t int_mask)
void bl602_wdt_intmask(uint8_t int_type, uint8_t int_mask)
{
uint32_t tmp_val;
bl602_wdt_access();
/* Deal with watchdog match/interrupt enable register,WRIE:watchdog
* reset/interrupt enable
*/
tmp_val = bl602_up_tim_regin(TIMER_BASE + TIMER_WMER_OFFSET);
switch (int_type)
{
case WDT_INT:
@ -830,8 +706,7 @@ void bl602_wdt_intmask(uint32_t int_type, uint32_t int_mask)
* not generated
*/
bl602_up_tim_regout(TIMER_BASE + TIMER_WMER_OFFSET,
tmp_val &= ~(1 << TIMER_WRIE_POS));
modifyreg32(BL602_TIMER_WMER, TIMER_WMER_WRIE, 0);
}
else
{
@ -841,8 +716,7 @@ void bl602_wdt_intmask(uint32_t int_type, uint32_t int_mask)
* not generated
*/
bl602_up_tim_regout(TIMER_BASE + TIMER_WMER_OFFSET,
tmp_val |= 1 << TIMER_WRIE_POS);
modifyreg32(BL602_TIMER_WMER, 0, TIMER_WMER_WRIE);
}
break;

View File

@ -0,0 +1,513 @@
/****************************************************************************
* arch/risc-v/src/bl602/bl602_tim.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_BL602_TIM_H
#define __ARCH_RISCV_SRC_BL602_BL602_TIM_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#ifndef __ASSEMBLY__
# include <stdint.h>
#endif
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* TIMER channel type definition */
#define TIMER_CH0 0 /* TIMER channel 0 port */
#define TIMER_CH1 1 /* TIMER channel 1 port */
#define TIMER_CH_MAX 2
/* TIMER clock source type definition */
#define TIMER_CLKSRC_FCLK 0 /* TIMER clock source :System CLK */
#define TIMER_CLKSRC_32K 1 /* TIMER clock source :32K CLK */
#define TIMER_CLKSRC_1K 2 /* TIMER clock source :1K CLK (not for WDT) */
#define TIMER_CLKSRC_XTAL 3 /* TIMER clock source :XTAL CLK */
/* TIMER match compare ID type definition */
#define TIMER_COMP_ID_0 0 /* TIMER match compare ID 0 */
#define TIMER_COMP_ID_1 1 /* TIMER match compare ID 1 */
#define TIMER_COMP_ID_2 2 /* TIMER match compare ID 2 */
#define TIMER_MAX_MATCH 3
/* TIMER preload source type definition */
#define TIMER_PRELOAD_TRIG_NONE 0 /* TIMER no preload source, free run */
#define TIMER_PRELOAD_TRIG_COMP0 1 /* TIMER count register preload triggered by comparator 0 */
#define TIMER_PRELOAD_TRIG_COMP1 2 /* TIMER count register preload triggered by comparator 1 */
#define TIMER_PRELOAD_TRIG_COMP2 3 /* TIMER count register preload triggered by comparator 2 */
/* TIMER count register run mode type definition */
#define TIMER_COUNT_PRELOAD 0 /* TIMER count register preload from comparator register */
#define TIMER_COUNT_FREERUN 1 /* TIMER count register free run */
/* TIMER interrupt type definition */
#define TIMER_INT_COMP_0 0 /* Comparator 0 match cause interrupt */
#define TIMER_INT_COMP_1 1 /* Comparator 1 match cause interrupt */
#define TIMER_INT_COMP_2 2 /* Comparator 2 match cause interrupt */
#define TIMER_INT_ALL 3
/* Watchdog timer interrupt type definition */
#define WDT_INT 0 /* Comparator 0 match cause interrupt */
#define WDT_INT_ALL 1
/****************************************************************************
* Public Types
****************************************************************************/
struct timer_cfg_s
{
uint8_t timer_ch; /* Timer channel */
uint8_t clk_src; /* Timer clock source */
/* Timer count register preload trigger source select */
uint8_t pl_trig_src;
uint8_t count_mode; /* Timer count mode */
uint8_t clock_division; /* Timer clock division value */
uint32_t match_val0; /* Timer match 0 value 0 */
uint32_t match_val1; /* Timer match 1 value 0 */
uint32_t match_val2; /* Timer match 2 value 0 */
uint32_t pre_load_val; /* Timer preload value */
};
/****************************************************************************
* Public Data
****************************************************************************/
#ifndef __ASSEMBLY__
#undef EXTERN
#if defined(__cplusplus)
#define EXTERN extern "C"
extern "C"
{
#else
#define EXTERN extern
#endif
/****************************************************************************
* Public Function Prototypes
****************************************************************************/
/****************************************************************************
* Name: bl602_timer_getcompvalue
*
* Description:
* Get the specified channel and match comparator value.
*
* Input Parameters:
* timer_ch - TIMER channel type.
* cmp_no - TIMER comparator ID type.
*
* Returned Value:
* Match comapre register value
*
****************************************************************************/
uint32_t bl602_timer_getcompvalue(uint8_t timer_ch, uint8_t cmp_no);
/****************************************************************************
* Name: bl602_timer_setcompvalue
*
* Description:
* TIMER set specified channel and comparator compare value
*
* Input Parameters:
* timer_ch - TIMER channel type.
* cmp_no - TIMER comparator ID type.
* val - TIMER match comapre register value.
*
* Returned Value:
* None
*
****************************************************************************/
void bl602_timer_setcompvalue(uint8_t timer_ch, uint8_t cmp_no,
uint32_t val);
/****************************************************************************
* Name: bl602_timer_getcountervalue
*
* Description:
* TIMER get the specified channel count value.
*
* Input Parameters:
* timer_ch - TIMER channel type
*
* Returned Value:
* TIMER count register value
*
****************************************************************************/
uint32_t bl602_timer_getcountervalue(uint32_t timer_ch);
/****************************************************************************
* Name: bl602_timer_getmatchstatus
*
* Description:
* TIMER get specified channel and comparator match status
*
* Input Parameters:
* timer_ch - TIMER channel type.
* cmp_no - TIMER comparator ID type.
*
* Returned Value:
* match status
*
****************************************************************************/
bool bl602_timer_getmatchstatus(uint32_t timer_ch, uint8_t cmp_no);
/****************************************************************************
* Name: bl602_timer_getpreloadvalue
*
* Description:
* TIMER get specified channel preload value
*
* Input Parameters:
* timer_ch - TIMER channel type.
*
* Returned Value:
* Preload register value.
*
****************************************************************************/
uint32_t bl602_timer_getpreloadvalue(uint32_t timer_ch);
/****************************************************************************
* Name: bl602_timer_setpreloadvalue
*
* Description:
* TIMER set preload register low 32bits value
*
* Input Parameters:
* timer_ch - TIMER channel type.
* val - Preload register low 32bits value.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_timer_setpreloadvalue(uint8_t timer_ch, uint32_t val);
/****************************************************************************
* Name: bl602_timer_setpreloadtrigsrc
*
* Description:
* TIMER set preload trigger source,COMP0,COMP1,COMP2 or None
*
* Input Parameters:
* timer_ch - TIMER channel type.
* pl_src - TIMER preload source type.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_timer_setpreloadtrigsrc(uint8_t timer_ch, uint32_t pl_src);
/****************************************************************************
* Name: bl602_timer_setcountmode
*
* Description:
* TIMER set count mode:preload or free run
*
* Input Parameters:
* timer_ch - TIMER channel type.
* count_mode - TIMER count mode: TIMER_COUNT_PRELOAD or
* TIMER_COUNT_FREERUN.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_timer_setcountmode(uint32_t timer_ch, uint8_t count_mode);
/****************************************************************************
* Name: bl602_timer_clearintstatus
*
* Description:
* TIMER clear interrupt status
*
* Input Parameters:
* timer_ch - TIMER channel type.
* cmp_no - TIMER macth comparator ID type.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_timer_clearintstatus(uint8_t timer_ch, uint32_t cmp_no);
/****************************************************************************
* Name: bl602_timer_init
*
* Description:
* TIMER initialization function.
*
* Input Parameters:
* timer_cfg - TIMER configuration structure pointer.
*
* Returned Value:
* None
*
****************************************************************************/
void bl602_timer_init(struct timer_cfg_s *timer_cfg);
/****************************************************************************
* Name: bl602_timer_enable
*
* Description:
* TIMER enable one channel function.
*
* Input Parameters:
* timer_ch - TIMER channel type.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_timer_enable(uint8_t timer_ch);
/****************************************************************************
* Name: bl602_timer_disable
*
* Description:
* TIMER disable one channel function.
*
* Input Parameters:
* timer_ch - TIMER channel type.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_timer_disable(uint8_t timer_ch);
/****************************************************************************
* Name: bl602_timer_intmask
*
* Description:
* TIMER mask or unmask certain or all interrupt.
*
* Input Parameters:
* timer_ch - TIMER channel type.
* int_type - TIMER interrupt type.
* int_mask - TIMER interrupt mask value:1:disbale interrupt.0:enable
* interrupt.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_timer_intmask(uint8_t timer_ch, uint8_t int_type,
uint8_t int_mask);
/****************************************************************************
* Name: bl602_wdt_set_clock
*
* Description:
* TIMER set watchdog clock source and clock division.
*
* Input Parameters:
* clk_src - Watchdog timer clock source type.
* div - Watchdog timer clock division value.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_wdt_set_clock(uint8_t clk_src, uint8_t div);
/****************************************************************************
* Name: bl602_wdt_getmatchvalue
*
* Description:
* TIMER get watchdog match compare value.
*
* Input Parameters:
* None.
*
* Returned Value:
* Watchdog match comapre register value.
*
****************************************************************************/
uint16_t bl602_wdt_getmatchvalue(void);
/****************************************************************************
* Name: bl602_wdt_setcompvalue
*
* Description:
* TIMER set watchdog match compare value.
*
* Input Parameters:
* val - Watchdog match compare value
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_wdt_setcompvalue(uint16_t val);
/****************************************************************************
* Name: bl602_wdt_getcountervalue
*
* Description:
* TIMER get watchdog count register value.
*
* Input Parameters:
* None.
*
* Returned Value:
* Watchdog count register value.
*
****************************************************************************/
uint16_t bl602_wdt_getcountervalue(void);
/****************************************************************************
* Name: bl602_wdt_resetcountervalue
*
* Description:
* TIMER reset watchdog count register value.
*
* Input Parameters:
* None.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_wdt_resetcountervalue(void);
/****************************************************************************
* Name: bl602_wdt_getresetstatus
*
* Description:
* TIMER get watchdog reset status.
*
* Input Parameters:
* None.
*
* Returned Value:
* 0 or 1.
*
****************************************************************************/
bool bl602_wdt_getresetstatus(void);
/****************************************************************************
* Name: bl602_wdt_clearresetstatus
*
* Description:
* TIMER clear watchdog reset status.
*
* Input Parameters:
* None.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_wdt_clearresetstatus(void);
/****************************************************************************
* Name: bl602_wdt_enable
*
* Description:
* TIMER enable watchdog function.
*
* Input Parameters:
* None.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_wdt_enable(void);
/****************************************************************************
* Name: bl602_wdt_disable
*
* Description:
* Watchdog timer disable function.
*
* Input Parameters:
* None.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_wdt_disable(void);
/****************************************************************************
* Name: bl602_wdt_intmask
*
* Description:
* Watchdog timer mask or unmask certain or all interrupt.
*
* Input Parameters:
* int_type - Watchdog interrupt type.
* int_mask - Watchdog interrupt mask value:BL_STD_MASK:disable
* interrupt.BL_STD_UNMASK:enable interrupt.
*
* Returned Value:
* None.
*
****************************************************************************/
void bl602_wdt_intmask(uint8_t int_type, uint8_t int_mask);
#undef EXTERN
#if defined(__cplusplus)
}
#endif
#endif /* __ASSEMBLY__ */
#endif /* __ARCH_RISCV_SRC_BL602_BL602_TIM_H */

View File

@ -37,8 +37,10 @@
#include <arch/board/board.h>
#include "riscv_arch.h"
#include <hardware/bl602_glb.h>
#include <hardware/bl602_timer.h>
#include "hardware/bl602_glb.h"
#include "hardware/bl602_timer.h"
#include "bl602_tim_lowerhalf.h"
#include "bl602_glb.h"
/****************************************************************************
* Pre-processor Definitions
@ -142,15 +144,15 @@ static int bl602_timer_handler(int irq, void *context, void *arg)
uint32_t tmp_val;
uint32_t tmp_addr;
int_id = getreg32(TIMER_BASE + TIMER_TMSR2_OFFSET + 4 * priv->tim);
tmp_addr = TIMER_BASE + TIMER_TICR2_OFFSET + 4 * priv->tim;
int_id = getreg32(BL602_TIMER_TMSR2 + 4 * priv->tim);
tmp_addr = BL602_TIMER_TICR2 + 4 * priv->tim;
tmp_val = getreg32(tmp_addr);
/* Comparator 0 match interrupt */
if (((int_id) & (1 << (TIMER_TMSR_0_POS))) != 0)
if ((int_id & TIMER_TMSR2_TMSR_0) != 0)
{
putreg32(tmp_val | (1 << TIMER_TCLR_0_POS), tmp_addr);
putreg32(tmp_val | TIMER_TMSR2_TMSR_0, tmp_addr);
if (priv->callback(&next_interval_us, priv->arg))
{
if (next_interval_us > 0)
@ -173,16 +175,16 @@ static int bl602_timer_handler(int irq, void *context, void *arg)
/* Comparator 1 match interrupt */
if (((int_id) & (1 << (TIMER_TMSR_1_POS))) != 0)
if ((int_id & TIMER_TMSR2_TMSR_1) != 0)
{
putreg32(tmp_val | (1 << TIMER_TCLR_1_POS), tmp_addr);
putreg32(tmp_val | TIMER_TICR2_TCLR_1, tmp_addr);
}
/* Comparator 2 match interrupt */
if (((int_id) & (1 << (TIMER_TMSR_2_POS))) != 0)
if ((int_id & TIMER_TMSR2_TMSR_2) != 0)
{
putreg32(tmp_val | (1 << TIMER_TCLR_2_POS), tmp_addr);
putreg32(tmp_val | TIMER_TICR2_TCLR_2, tmp_addr);
}
return OK;
@ -337,10 +339,11 @@ static int bl602_tim_settimeout(FAR struct timer_lowerhalf_s *lower,
*
* Input Parameters:
* lower - A pointer the publicly visible representation of the
*"lower-half" driver state structure. callback - The new timer expiration
*function pointer. If this function pointer is NULL, then the
*reset-on-expiration behavior is restored, arg - Argument that will be
*provided in the callback
* "lower-half" driver state structure.
* callback - The new timer expiration function pointer. If this function
* pointer is NULL, then the reset-on-expiration behavior is
* restored.
* arg - Argument that will be provided in the callback
*
* Returned Value:
* The previous timer expiration function pointer or NULL is there was
@ -389,7 +392,7 @@ static void bl602_tim_setcallback(FAR struct timer_lowerhalf_s *lower,
int bl602_timer_initialize(FAR const char *devpath, int timer)
{
FAR struct bl602_tim_lowerhalf_s *lower;
timer_cfg_t timstr;
struct timer_cfg_s timstr;
switch (timer)
{
@ -420,7 +423,7 @@ int bl602_timer_initialize(FAR const char *devpath, int timer)
timstr.match_val2 = TIMER_MAX_VALUE; /* Timer match 2 value 0 */
timstr.pre_load_val = TIMER_MAX_VALUE; /* Timer preload value */
bl602_glb_ahb_slave1_reset(BL_AHB_SLAVE1_TMR);
bl602_swrst_ahb_slave1(AHB_SLAVE1_TMR);
bl602_timer_intmask(lower->tim, TIMER_INT_ALL, 1);

View File

@ -27,7 +27,8 @@
#include <nuttx/config.h>
#include <bl602_tim_lowerhalf.h>
#include "bl602_tim_lowerhalf.h"
#include "bl602_tim.h"
/****************************************************************************
* Public Function Prototypes
@ -37,6 +38,6 @@
* Name: bl602_timer_initialize
****************************************************************************/
int bl602_timer_initialize(FAR const char *devpath, uint8_t timer);
int bl602_timer_initialize(FAR const char *devpath, int timer);
#endif /* __ARCH_RISCV_SRC_BL602_TIM_LOWERHALF_H */

View File

@ -31,7 +31,7 @@
#include <nuttx/arch.h>
#include <nuttx/clock.h>
#include <arch/board/board.h>
#include "hardware/bl602_clint.h"
#include "hardware/bl602_clic.h"
#include "riscv_arch.h"
#include "chip.h"
@ -61,21 +61,21 @@ static bool g_b_tick_started = false;
static inline uint64_t bl602_clint_time_read(void)
{
uint64_t r = getreg32(BL602_MTIMER_HIGH);
uint64_t r = getreg32(BL602_CLIC_MTIME + 4);
r <<= 32;
r |= getreg32(BL602_MTIMER_LOW);
r |= getreg32(BL602_CLIC_MTIME);
return r;
}
static inline uint64_t bl602_clint_time_cmp_read(void)
{
return getreg64(BL602_MTIMER_CMP);
return getreg64(BL602_CLIC_MTIMECMP);
}
static inline void bl602_clint_time_cmp_write(uint64_t v)
{
putreg64(v, BL602_MTIMER_CMP);
putreg64(v, BL602_CLIC_MTIMECMP);
}
/****************************************************************************

View File

@ -0,0 +1,387 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_aon.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_AON_SEC_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_AON_SEC_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_AON_OFFSET 0x000800 /* aon */
#define BL602_AON_COMMON_OFFSET 0x000804 /* aon_common */
#define BL602_AON_MISC_OFFSET 0x000808 /* aon_misc */
#define BL602_BG_SYS_TOP_OFFSET 0x000810 /* bg_sys_top */
#define BL602_DCDC18_TOP_0_OFFSET 0x000814 /* dcdc18_top_0 */
#define BL602_DCDC18_TOP_1_OFFSET 0x000818 /* dcdc18_top_1 */
#define BL602_LDO11SOC_AND_DCTEST_OFFSET 0x00081c /* ldo11soc_and_dctest */
#define BL602_PSW_IRRCV_OFFSET 0x000820 /* psw_irrcv */
#define BL602_RF_TOP_AON_OFFSET 0x000880 /* rf_top_aon */
#define BL602_XTAL_CFG_OFFSET 0x000884 /* xtal_cfg */
#define BL602_TSEN_OFFSET 0x000888 /* tsen */
#define BL602_ACOMP0_CTRL_OFFSET 0x000900 /* acomp0_ctrl */
#define BL602_ACOMP1_CTRL_OFFSET 0x000904 /* acomp1_ctrl */
#define BL602_ACOMP_CTRL_OFFSET 0x000908 /* acomp_ctrl */
#define BL602_GPADC_REG_CMD_OFFSET 0x00090c /* gpadc_reg_cmd */
#define BL602_GPADC_REG_CONFIG1_OFFSET 0x000910 /* gpadc_reg_config1 */
#define BL602_GPADC_REG_CONFIG2_OFFSET 0x000914 /* gpadc_reg_config2 */
#define BL602_GPADC_REG_SCN_POS1_OFFSET 0x000918 /* adc conversion sequence 1 */
#define BL602_GPADC_REG_SCN_POS2_OFFSET 0x00091c /* adc conversion sequence 2 */
#define BL602_GPADC_REG_SCN_NEG1_OFFSET 0x000920 /* adc conversion sequence 3 */
#define BL602_GPADC_REG_SCN_NEG2_OFFSET 0x000924 /* adc conversion sequence 4 */
#define BL602_GPADC_REG_STATUS_OFFSET 0x000928 /* gpadc_reg_status */
#define BL602_GPADC_REG_ISR_OFFSET 0x00092c /* gpadc_reg_isr */
#define BL602_GPADC_REG_RESULT_OFFSET 0x000930 /* gpadc_reg_result */
#define BL602_GPADC_REG_RAW_RESULT_OFFSET 0x000934 /* gpadc_reg_raw_result */
#define BL602_GPADC_REG_DEFINE_OFFSET 0x000938 /* gpadc_reg_define */
#define BL602_HBNCORE_RESV0_OFFSET 0x00093c /* hbncore_resv0 */
#define BL602_HBNCORE_RESV1_OFFSET 0x000940 /* hbncore_resv1 */
/* Register definitions *****************************************************/
#define BL602_AON (BL602_AON_BASE + BL602_AON_OFFSET)
#define BL602_AON_COMMON (BL602_AON_BASE + BL602_AON_COMMON_OFFSET)
#define BL602_AON_MISC (BL602_AON_BASE + BL602_AON_MISC_OFFSET)
#define BL602_BG_SYS_TOP (BL602_AON_BASE + BL602_BG_SYS_TOP_OFFSET)
#define BL602_DCDC18_TOP_0 (BL602_AON_BASE + BL602_DCDC18_TOP_0_OFFSET)
#define BL602_DCDC18_TOP_1 (BL602_AON_BASE + BL602_DCDC18_TOP_1_OFFSET)
#define BL602_LDO11SOC_AND_DCTEST (BL602_AON_BASE + BL602_LDO11SOC_AND_DCTEST_OFFSET)
#define BL602_PSW_IRRCV (BL602_AON_BASE + BL602_PSW_IRRCV_OFFSET)
#define BL602_RF_TOP_AON (BL602_AON_BASE + BL602_RF_TOP_AON_OFFSET)
#define BL602_XTAL_CFG (BL602_AON_BASE + BL602_XTAL_CFG_OFFSET)
#define BL602_TSEN (BL602_AON_BASE + BL602_TSEN_OFFSET)
#define BL602_ACOMP0_CTRL (BL602_AON_BASE + BL602_ACOMP0_CTRL_OFFSET)
#define BL602_ACOMP1_CTRL (BL602_AON_BASE + BL602_ACOMP1_CTRL_OFFSET)
#define BL602_ACOMP_CTRL (BL602_AON_BASE + BL602_ACOMP_CTRL_OFFSET)
#define BL602_GPADC_REG_CMD (BL602_AON_BASE + BL602_GPADC_REG_CMD_OFFSET)
#define BL602_GPADC_REG_CONFIG1 (BL602_AON_BASE + BL602_GPADC_REG_CONFIG1_OFFSET)
#define BL602_GPADC_REG_CONFIG2 (BL602_AON_BASE + BL602_GPADC_REG_CONFIG2_OFFSET)
#define BL602_GPADC_REG_SCN_POS1 (BL602_AON_BASE + BL602_GPADC_REG_SCN_POS1_OFFSET)
#define BL602_GPADC_REG_SCN_POS2 (BL602_AON_BASE + BL602_GPADC_REG_SCN_POS2_OFFSET)
#define BL602_GPADC_REG_SCN_NEG1 (BL602_AON_BASE + BL602_GPADC_REG_SCN_NEG1_OFFSET)
#define BL602_GPADC_REG_SCN_NEG2 (BL602_AON_BASE + BL602_GPADC_REG_SCN_NEG2_OFFSET)
#define BL602_GPADC_REG_STATUS (BL602_AON_BASE + BL602_GPADC_REG_STATUS_OFFSET)
#define BL602_GPADC_REG_ISR (BL602_AON_BASE + BL602_GPADC_REG_ISR_OFFSET)
#define BL602_GPADC_REG_RESULT (BL602_AON_BASE + BL602_GPADC_REG_RESULT_OFFSET)
#define BL602_GPADC_REG_RAW_RESULT (BL602_AON_BASE + BL602_GPADC_REG_RAW_RESULT_OFFSET)
#define BL602_GPADC_REG_DEFINE (BL602_AON_BASE + BL602_GPADC_REG_DEFINE_OFFSET)
#define BL602_HBNCORE_RESV0 (BL602_AON_BASE + BL602_HBNCORE_RESV0_OFFSET)
#define BL602_HBNCORE_RESV1 (BL602_AON_BASE + BL602_HBNCORE_RESV1_OFFSET)
/* Register bit definitions *************************************************/
#define SW_PU_LDO11_RT (1 << 22)
#define LDO11_RT_PULLDOWN_SEL (1 << 21)
#define LDO11_RT_PULLDOWN (1 << 20)
#define PU_AON_DC_TBUF (1 << 12)
#define RESV_MASK (0xff)
#define COMMON_TEN_CIP_MISC_AON (1 << 20)
#define COMMON_TEN_MBG_AON (1 << 19)
#define COMMON_DTEN_XTAL_AON (1 << 18)
#define COMMON_TEN_XTAL_AON (1 << 17)
#define COMMON_TEN_LDO15RF_AON (1 << 16)
#define COMMON_TEN_BG_SYS_AON (1 << 12)
#define COMMON_TEN_DCDC18_1_AON (1 << 11)
#define COMMON_TEN_DCDC18_0_AON (1 << 10)
#define COMMON_TEN_LDO11SOC_AON (1 << 9)
#define COMMON_TEN_VDDCORE_AON (1 << 8)
#define COMMON_TEN_XTAL32K (1 << 6)
#define COMMON_DTEN_XTAL32K (1 << 5)
#define COMMON_TEN_AON (1 << 4)
#define COMMON_TMUX_AON_MASK (0x07)
#define MISC_SW_WB_EN_AON (1 << 1)
#define MISC_SW_SOC_EN_AON (1 << 0)
#define BG_SYS_TOP_BG_SYS_START_CTRL_AON (1 << 12)
#define BG_SYS_TOP_PU_BG_SYS_AON (1 << 8)
#define BG_SYS_TOP_PMIP_RESV_MASK (0xff)
#define DCDC18_TOP_0_DCDC18_RDY_AON (1 << 31)
#define DCDC18_TOP_0_DCDC18_SSTART_TIME_AON_SHIFT (28)
#define DCDC18_TOP_0_DCDC18_SSTART_TIME_AON_MASK (0x03 << DCDC18_TOP_0_DCDC18_SSTART_TIME_AON_SHIFT)
#define DCDC18_TOP_0_DCDC18_OSC_INHIBIT_T2_AON (1 << 27)
#define DCDC18_TOP_0_DCDC18_SLOW_OSC_AON (1 << 26)
#define DCDC18_TOP_0_DCDC18_STOP_OSC_AON (1 << 25)
#define DCDC18_TOP_0_DCDC18_SLOPE_CURR_SEL_AON_SHIFT (20)
#define DCDC18_TOP_0_DCDC18_SLOPE_CURR_SEL_AON_MASK (0x1f << DCDC18_TOP_0_DCDC18_SLOPE_CURR_SEL_AON_SHIFT)
#define DCDC18_TOP_0_DCDC18_OSC_FREQ_TRIM_AON_SHIFT (16)
#define DCDC18_TOP_0_DCDC18_OSC_FREQ_TRIM_AON_MASK (0x0f << DCDC18_TOP_0_DCDC18_OSC_FREQ_TRIM_AON_SHIFT)
#define DCDC18_TOP_0_DCDC18_OSC_2M_MODE_AON (1 << 12)
#define DCDC18_TOP_0_DCDC18_VPFM_AON_SHIFT (8)
#define DCDC18_TOP_0_DCDC18_VPFM_AON_MASK (0x0f << DCDC18_TOP_0_DCDC18_VPFM_AON_SHIFT)
#define DCDC18_TOP_0_DCDC18_VOUT_SEL_AON_SHIFT (1)
#define DCDC18_TOP_0_DCDC18_VOUT_SEL_AON_MASK (0x1f << DCDC18_TOP_0_DCDC18_VOUT_SEL_AON_SHIFT)
#define DCDC18_TOP_1_DCDC18_PULLDOWN_AON (1 << 29)
#define DCDC18_TOP_1_DCDC18_EN_ANTIRING_AON (1 << 28)
#define DCDC18_TOP_1_DCDC18_CFB_SEL_AON_SHIFT (24)
#define DCDC18_TOP_1_DCDC18_CFB_SEL_AON_MASK (0x0f << DCDC18_TOP_1_DCDC18_CFB_SEL_AON_SHIFT)
#define DCDC18_TOP_1_DCDC18_CHF_SEL_AON_SHIFT (20)
#define DCDC18_TOP_1_DCDC18_CHF_SEL_AON_MASK (0x0f << DCDC18_TOP_1_DCDC18_CHF_SEL_AON_SHIFT)
#define DCDC18_TOP_1_DCDC18_RC_SEL_AON_SHIFT (16)
#define DCDC18_TOP_1_DCDC18_RC_SEL_AON_MASK (0x0f << DCDC18_TOP_1_DCDC18_RC_SEL_AON_SHIFT)
#define DCDC18_TOP_1_DCDC18_NONOVERLAP_TD_AON_SHIFT (8)
#define DCDC18_TOP_1_DCDC18_NONOVERLAP_TD_AON_MASK (0x1f << DCDC18_TOP_1_DCDC18_NONOVERLAP_TD_AON_SHIFT)
#define DCDC18_TOP_1_DCDC18_ZVS_TD_OPT_AON_SHIFT (4)
#define DCDC18_TOP_1_DCDC18_ZVS_TD_OPT_AON_MASK (0x07 << DCDC18_TOP_1_DCDC18_ZVS_TD_OPT_AON_SHIFT)
#define DCDC18_TOP_1_DCDC18_CS_DELAY_AON_SHIFT (1)
#define DCDC18_TOP_1_DCDC18_CS_DELAY_AON_MASK (0x07 << DCDC18_TOP_1_DCDC18_CS_DELAY_AON_SHIFT)
#define DCDC18_TOP_1_DCDC18_FORCE_CS_ZVS_AON (1 << 0)
#define LDO11SOC_AND_DCTEST_PMIP_DC_TP_OUT_EN_AON (1 << 31)
#define LDO11SOC_AND_DCTEST_PU_VDDCORE_MISC_AON (1 << 30)
#define LDO11SOC_AND_DCTEST_LDO11SOC_POWER_GOOD_AON (1 << 29)
#define LDO11SOC_AND_DCTEST_LDO11SOC_RDY_AON (1 << 28)
#define LDO11SOC_AND_DCTEST_LDO11SOC_CC_AON_SHIFT (24)
#define LDO11SOC_AND_DCTEST_LDO11SOC_CC_AON_MASK (0x03 << LDO11SOC_AND_DCTEST_LDO11SOC_CC_AON_SHIFT)
#define LDO11SOC_AND_DCTEST_LDO11SOC_VTH_SEL_AON_SHIFT (12)
#define LDO11SOC_AND_DCTEST_LDO11SOC_VTH_SEL_AON_MASK (0x03 << LDO11SOC_AND_DCTEST_LDO11SOC_VTH_SEL_AON_SHIFT)
#define LDO11SOC_AND_DCTEST_LDO11SOC_PULLDOWN_SEL_AON (1 << 11)
#define LDO11SOC_AND_DCTEST_LDO11SOC_PULLDOWN_AON (1 << 10)
#define LDO11SOC_AND_DCTEST_LDO11SOC_SSTART_DELAY_AON_SHIFT (8)
#define LDO11SOC_AND_DCTEST_LDO11SOC_SSTART_DELAY_AON_MASK (0x03 << LDO11SOC_AND_DCTEST_LDO11SOC_SSTART_DELAY_AON_SHIFT)
#define LDO11SOC_AND_DCTEST_LDO11SOC_SSTART_SEL_AON (1 << 4)
#define LDO11SOC_AND_DCTEST_PU_LDO11SOC_AON (1 << 0)
#define PSW_IRRCV_PU_IR_PSW_AON (1 << 0)
#define RF_TOP_AON_LDO15RF_BYPASS_AON (1 << 28)
#define RF_TOP_AON_LDO15RF_CC_AON_SHIFT (24)
#define RF_TOP_AON_LDO15RF_CC_AON_MASK (0x03 << RF_TOP_AON_LDO15RF_CC_AON_SHIFT)
#define RF_TOP_AON_LDO15RF_VOUT_SEL_AON_SHIFT (16)
#define RF_TOP_AON_LDO15RF_VOUT_SEL_AON_MASK (0x07 << RF_TOP_AON_LDO15RF_VOUT_SEL_AON_SHIFT)
#define RF_TOP_AON_LDO15RF_PULLDOWN_SEL_AON (1 << 13)
#define RF_TOP_AON_LDO15RF_PULLDOWN_AON (1 << 12)
#define RF_TOP_AON_LDO15RF_SSTART_DELAY_AON_SHIFT (9)
#define RF_TOP_AON_LDO15RF_SSTART_DELAY_AON_MASK (0x03 << RF_TOP_AON_LDO15RF_SSTART_DELAY_AON_SHIFT)
#define RF_TOP_AON_LDO15RF_SSTART_SEL_AON (1 << 8)
#define RF_TOP_AON_PU_XTAL_AON (1 << 5)
#define RF_TOP_AON_PU_XTAL_BUF_AON (1 << 4)
#define RF_TOP_AON_PU_SFREG_AON (1 << 2)
#define RF_TOP_AON_PU_LDO15RF_AON (1 << 1)
#define RF_TOP_AON_PU_MBG_AON (1 << 0)
#define XTAL_CFG_XTAL_RDY_SEL_AON_SHIFT (30)
#define XTAL_CFG_XTAL_RDY_SEL_AON_MASK (0x03 << XTAL_CFG_XTAL_RDY_SEL_AON_SHIFT)
#define XTAL_CFG_XTAL_GM_BOOST_AON_SHIFT (28)
#define XTAL_CFG_XTAL_GM_BOOST_AON_MASK (0x03 << XTAL_CFG_XTAL_GM_BOOST_AON_SHIFT)
#define XTAL_CFG_XTAL_CAPCODE_IN_AON_SHIFT (22)
#define XTAL_CFG_XTAL_CAPCODE_IN_AON_MASK (0x3f << XTAL_CFG_XTAL_CAPCODE_IN_AON_SHIFT)
#define XTAL_CFG_XTAL_CAPCODE_OUT_AON_SHIFT (16)
#define XTAL_CFG_XTAL_CAPCODE_OUT_AON_MASK (0x3f << XTAL_CFG_XTAL_CAPCODE_OUT_AON_SHIFT)
#define XTAL_CFG_XTAL_AMP_CTRL_AON_SHIFT (14)
#define XTAL_CFG_XTAL_AMP_CTRL_AON_MASK (0x03 << XTAL_CFG_XTAL_AMP_CTRL_AON_SHIFT)
#define XTAL_CFG_XTAL_SLEEP_AON (1 << 13)
#define XTAL_CFG_XTAL_FAST_STARTUP_AON (1 << 12)
#define XTAL_CFG_XTAL_BUF_HP_AON_SHIFT (8)
#define XTAL_CFG_XTAL_BUF_HP_AON_MASK (0x0f << XTAL_CFG_XTAL_BUF_HP_AON_SHIFT)
#define XTAL_CFG_XTAL_BUF_EN_AON_SHIFT (4)
#define XTAL_CFG_XTAL_BUF_EN_AON_MASK (0x0f << XTAL_CFG_XTAL_BUF_EN_AON_SHIFT)
#define XTAL_CFG_XTAL_EXT_SEL_AON (1 << 3)
#define XTAL_CFG_XTAL_CAPCODE_EXTRA_AON (1 << 2)
#define XTAL_CFG_XTAL_BK_AON_MASK (0x03)
#define TSEN_XTAL_RDY_INT_SEL_AON_SHIFT (30)
#define TSEN_XTAL_RDY_INT_SEL_AON_MASK (0x03 << TSEN_XTAL_RDY_INT_SEL_AON_SHIFT)
#define TSEN_XTAL_INN_CFG_EN_AON (1 << 29)
#define TSEN_XTAL_RDY (1 << 28)
#define TSEN_TSEN_REFCODE_RFCAL_SHIFT (16)
#define TSEN_TSEN_REFCODE_RFCAL_MASK (0xfff << TSEN_TSEN_REFCODE_RFCAL_SHIFT)
#define TSEN_TSEN_REFCODE_CORNER_MASK (0xfff)
#define ACOMP0_CTRL_ACOMP0_MUXEN (1 << 26)
#define ACOMP0_CTRL_ACOMP0_POS_SEL_SHIFT (22)
#define ACOMP0_CTRL_ACOMP0_POS_SEL_MASK (0x0f << ACOMP0_CTRL_ACOMP0_POS_SEL_SHIFT)
#define ACOMP0_CTRL_ACOMP0_NEG_SEL_SHIFT (18)
#define ACOMP0_CTRL_ACOMP0_NEG_SEL_MASK (0x0f << ACOMP0_CTRL_ACOMP0_NEG_SEL_SHIFT)
#define ACOMP0_CTRL_ACOMP0_LEVEL_SEL_SHIFT (12)
#define ACOMP0_CTRL_ACOMP0_LEVEL_SEL_MASK (0x3f << ACOMP0_CTRL_ACOMP0_LEVEL_SEL_SHIFT)
#define ACOMP0_CTRL_ACOMP0_BIAS_PROG_SHIFT (10)
#define ACOMP0_CTRL_ACOMP0_BIAS_PROG_MASK (0x03 << ACOMP0_CTRL_ACOMP0_BIAS_PROG_SHIFT)
#define ACOMP0_CTRL_ACOMP0_HYST_SELP_SHIFT (7)
#define ACOMP0_CTRL_ACOMP0_HYST_SELP_MASK (0x07 << ACOMP0_CTRL_ACOMP0_HYST_SELP_SHIFT)
#define ACOMP0_CTRL_ACOMP0_HYST_SELN_SHIFT (4)
#define ACOMP0_CTRL_ACOMP0_HYST_SELN_MASK (0x07 << ACOMP0_CTRL_ACOMP0_HYST_SELN_SHIFT)
#define ACOMP0_CTRL_ACOMP0_EN (1 << 0)
#define ACOMP1_CTRL_ACOMP1_MUXEN (1 << 26)
#define ACOMP1_CTRL_ACOMP1_POS_SEL_SHIFT (22)
#define ACOMP1_CTRL_ACOMP1_POS_SEL_MASK (0x0f << ACOMP1_CTRL_ACOMP1_POS_SEL_SHIFT)
#define ACOMP1_CTRL_ACOMP1_NEG_SEL_SHIFT (18)
#define ACOMP1_CTRL_ACOMP1_NEG_SEL_MASK (0x0f << ACOMP1_CTRL_ACOMP1_NEG_SEL_SHIFT)
#define ACOMP1_CTRL_ACOMP1_LEVEL_SEL_SHIFT (12)
#define ACOMP1_CTRL_ACOMP1_LEVEL_SEL_MASK (0x3f << ACOMP1_CTRL_ACOMP1_LEVEL_SEL_SHIFT)
#define ACOMP1_CTRL_ACOMP1_BIAS_PROG_SHIFT (10)
#define ACOMP1_CTRL_ACOMP1_BIAS_PROG_MASK (0x03 << ACOMP1_CTRL_ACOMP1_BIAS_PROG_SHIFT)
#define ACOMP1_CTRL_ACOMP1_HYST_SELP_SHIFT (7)
#define ACOMP1_CTRL_ACOMP1_HYST_SELP_MASK (0x07 << ACOMP1_CTRL_ACOMP1_HYST_SELP_SHIFT)
#define ACOMP1_CTRL_ACOMP1_HYST_SELN_SHIFT (4)
#define ACOMP1_CTRL_ACOMP1_HYST_SELN_MASK (0x07 << ACOMP1_CTRL_ACOMP1_HYST_SELN_SHIFT)
#define ACOMP1_CTRL_ACOMP1_EN (1 << 0)
#define ACOMP_CTRL_ACOMP0_OUT_RAW (1 << 19)
#define ACOMP_CTRL_ACOMP1_OUT_RAW (1 << 17)
#define ACOMP_CTRL_ACOMP0_TEST_SEL_SHIFT (12)
#define ACOMP_CTRL_ACOMP0_TEST_SEL_MASK (0x03 << ACOMP_CTRL_ACOMP0_TEST_SEL_SHIFT)
#define ACOMP_CTRL_ACOMP1_TEST_SEL_SHIFT (10)
#define ACOMP_CTRL_ACOMP1_TEST_SEL_MASK (0x03 << ACOMP_CTRL_ACOMP1_TEST_SEL_SHIFT)
#define ACOMP_CTRL_ACOMP0_TEST_EN (1 << 9)
#define ACOMP_CTRL_ACOMP1_TEST_EN (1 << 8)
#define ACOMP_CTRL_ACOMP0_RSTN_ANA (1 << 1)
#define ACOMP_CTRL_ACOMP1_RSTN_ANA (1 << 0)
#define GPADC_REG_CMD_GPADC_SEN_TEST_EN (1 << 30)
#define GPADC_REG_CMD_GPADC_SEN_SEL_SHIFT (28)
#define GPADC_REG_CMD_GPADC_SEN_SEL_MASK (0x03 << GPADC_REG_CMD_GPADC_SEN_SEL_SHIFT)
#define GPADC_REG_CMD_GPADC_CHIP_SEN_PU (1 << 27)
#define GPADC_REG_CMD_GPADC_MICBOOST_32DB_EN (1 << 23)
#define GPADC_REG_CMD_GPADC_MIC_PGA2_GAIN_SHIFT (21)
#define GPADC_REG_CMD_GPADC_MIC_PGA2_GAIN_MASK (0x03 << GPADC_REG_CMD_GPADC_MIC_PGA2_GAIN_SHIFT)
#define GPADC_REG_CMD_GPADC_MIC1_DIFF (1 << 20)
#define GPADC_REG_CMD_GPADC_MIC2_DIFF (1 << 19)
#define GPADC_REG_CMD_GPADC_DWA_EN (1 << 18)
#define GPADC_REG_CMD_GPADC_BYP_MICBOOST (1 << 16)
#define GPADC_REG_CMD_GPADC_MICPGA_EN (1 << 15)
#define GPADC_REG_CMD_GPADC_MICBIAS_EN (1 << 14)
#define GPADC_REG_CMD_GPADC_NEG_GND (1 << 13)
#define GPADC_REG_CMD_GPADC_POS_SEL_SHIFT (8)
#define GPADC_REG_CMD_GPADC_POS_SEL_MASK (0x1f << GPADC_REG_CMD_GPADC_POS_SEL_SHIFT)
#define GPADC_REG_CMD_GPADC_NEG_SEL_SHIFT (3)
#define GPADC_REG_CMD_GPADC_NEG_SEL_MASK (0x1f << GPADC_REG_CMD_GPADC_NEG_SEL_SHIFT)
#define GPADC_REG_CMD_GPADC_SOFT_RST (1 << 2)
#define GPADC_REG_CMD_GPADC_CONV_START (1 << 1)
#define GPADC_REG_CMD_GPADC_GLOBAL_EN (1 << 0)
#define GPADC_REG_CONFIG1_GPADC_V18_SEL_SHIFT (29)
#define GPADC_REG_CONFIG1_GPADC_V18_SEL_MASK (0x03 << GPADC_REG_CONFIG1_GPADC_V18_SEL_SHIFT)
#define GPADC_REG_CONFIG1_GPADC_V11_SEL_SHIFT (27)
#define GPADC_REG_CONFIG1_GPADC_V11_SEL_MASK (0x03 << GPADC_REG_CONFIG1_GPADC_V11_SEL_SHIFT)
#define GPADC_REG_CONFIG1_GPADC_DITHER_EN (1 << 26)
#define GPADC_REG_CONFIG1_GPADC_SCAN_EN (1 << 25)
#define GPADC_REG_CONFIG1_GPADC_SCAN_LENGTH_SHIFT (21)
#define GPADC_REG_CONFIG1_GPADC_SCAN_LENGTH_MASK (0x0f << GPADC_REG_CONFIG1_GPADC_SCAN_LENGTH_SHIFT)
#define GPADC_REG_CONFIG1_GPADC_CLK_DIV_RATIO_SHIFT (18)
#define GPADC_REG_CONFIG1_GPADC_CLK_DIV_RATIO_MASK (0x07 << GPADC_REG_CONFIG1_GPADC_CLK_DIV_RATIO_SHIFT)
#define GPADC_REG_CONFIG1_GPADC_CLK_ANA_INV (1 << 17)
#define GPADC_REG_CONFIG1_GPADC_RES_SEL_SHIFT (2)
#define GPADC_REG_CONFIG1_GPADC_RES_SEL_MASK (0x07 << GPADC_REG_CONFIG1_GPADC_RES_SEL_SHIFT)
#define GPADC_REG_CONFIG1_GPADC_CONT_CONV_EN (1 << 1)
#define GPADC_REG_CONFIG1_GPADC_CAL_OS_EN (1 << 0)
#define GPADC_REG_CONFIG2_GPADC_TSVBE_LOW (1 << 31)
#define GPADC_REG_CONFIG2_GPADC_DLY_SEL_SHIFT (28)
#define GPADC_REG_CONFIG2_GPADC_DLY_SEL_MASK (0x07 << GPADC_REG_CONFIG2_GPADC_DLY_SEL_SHIFT)
#define GPADC_REG_CONFIG2_GPADC_PGA1_GAIN_SHIFT (25)
#define GPADC_REG_CONFIG2_GPADC_PGA1_GAIN_MASK (0x07 << GPADC_REG_CONFIG2_GPADC_PGA1_GAIN_SHIFT)
#define GPADC_REG_CONFIG2_GPADC_PGA2_GAIN_SHIFT (22)
#define GPADC_REG_CONFIG2_GPADC_PGA2_GAIN_MASK (0x07 << GPADC_REG_CONFIG2_GPADC_PGA2_GAIN_SHIFT)
#define GPADC_REG_CONFIG2_GPADC_TEST_SEL_SHIFT (19)
#define GPADC_REG_CONFIG2_GPADC_TEST_SEL_MASK (0x07 << GPADC_REG_CONFIG2_GPADC_TEST_SEL_SHIFT)
#define GPADC_REG_CONFIG2_GPADC_TEST_EN (1 << 18)
#define GPADC_REG_CONFIG2_GPADC_BIAS_SEL (1 << 17)
#define GPADC_REG_CONFIG2_GPADC_CHOP_MODE_SHIFT (15)
#define GPADC_REG_CONFIG2_GPADC_CHOP_MODE_MASK (0x03 << GPADC_REG_CONFIG2_GPADC_CHOP_MODE_SHIFT)
#define GPADC_REG_CONFIG2_GPADC_PGA_VCMI_EN (1 << 14)
#define GPADC_REG_CONFIG2_GPADC_PGA_EN (1 << 13)
#define GPADC_REG_CONFIG2_GPADC_PGA_OS_CAL_SHIFT (9)
#define GPADC_REG_CONFIG2_GPADC_PGA_OS_CAL_MASK (0x0f << GPADC_REG_CONFIG2_GPADC_PGA_OS_CAL_SHIFT)
#define GPADC_REG_CONFIG2_GPADC_PGA_VCM_SHIFT (7)
#define GPADC_REG_CONFIG2_GPADC_PGA_VCM_MASK (0x03 << GPADC_REG_CONFIG2_GPADC_PGA_VCM_SHIFT)
#define GPADC_REG_CONFIG2_GPADC_TS_EN (1 << 6)
#define GPADC_REG_CONFIG2_GPADC_TSEXT_SEL (1 << 5)
#define GPADC_REG_CONFIG2_GPADC_VBAT_EN (1 << 4)
#define GPADC_REG_CONFIG2_GPADC_VREF_SEL (1 << 3)
#define GPADC_REG_CONFIG2_GPADC_DIFF_MODE (1 << 2)
#define GPADC_REG_SCN_POS1_GPADC_SCAN_POS_5_SHIFT (25)
#define GPADC_REG_SCN_POS1_GPADC_SCAN_POS_5_MASK (0x1f << GPADC_REG_SCN_POS1_GPADC_SCAN_POS_5_SHIFT)
#define GPADC_REG_SCN_POS1_GPADC_SCAN_POS_4_SHIFT (20)
#define GPADC_REG_SCN_POS1_GPADC_SCAN_POS_4_MASK (0x1f << GPADC_REG_SCN_POS1_GPADC_SCAN_POS_4_SHIFT)
#define GPADC_REG_SCN_POS1_GPADC_SCAN_POS_3_SHIFT (15)
#define GPADC_REG_SCN_POS1_GPADC_SCAN_POS_3_MASK (0x1f << GPADC_REG_SCN_POS1_GPADC_SCAN_POS_3_SHIFT)
#define GPADC_REG_SCN_POS1_GPADC_SCAN_POS_2_SHIFT (10)
#define GPADC_REG_SCN_POS1_GPADC_SCAN_POS_2_MASK (0x1f << GPADC_REG_SCN_POS1_GPADC_SCAN_POS_2_SHIFT)
#define GPADC_REG_SCN_POS1_GPADC_SCAN_POS_1_SHIFT (5)
#define GPADC_REG_SCN_POS1_GPADC_SCAN_POS_1_MASK (0x1f << GPADC_REG_SCN_POS1_GPADC_SCAN_POS_1_SHIFT)
#define GPADC_REG_SCN_POS1_GPADC_SCAN_POS_0_MASK (0x1f)
#define GPADC_REG_SCN_POS2_GPADC_SCAN_POS_11_SHIFT (25)
#define GPADC_REG_SCN_POS2_GPADC_SCAN_POS_11_MASK (0x1f << GPADC_REG_SCN_POS2_GPADC_SCAN_POS_11_SHIFT)
#define GPADC_REG_SCN_POS2_GPADC_SCAN_POS_10_SHIFT (20)
#define GPADC_REG_SCN_POS2_GPADC_SCAN_POS_10_MASK (0x1f << GPADC_REG_SCN_POS2_GPADC_SCAN_POS_10_SHIFT)
#define GPADC_REG_SCN_POS2_GPADC_SCAN_POS_9_SHIFT (15)
#define GPADC_REG_SCN_POS2_GPADC_SCAN_POS_9_MASK (0x1f << GPADC_REG_SCN_POS2_GPADC_SCAN_POS_9_SHIFT)
#define GPADC_REG_SCN_POS2_GPADC_SCAN_POS_8_SHIFT (10)
#define GPADC_REG_SCN_POS2_GPADC_SCAN_POS_8_MASK (0x1f << GPADC_REG_SCN_POS2_GPADC_SCAN_POS_8_SHIFT)
#define GPADC_REG_SCN_POS2_GPADC_SCAN_POS_7_SHIFT (5)
#define GPADC_REG_SCN_POS2_GPADC_SCAN_POS_7_MASK (0x1f << GPADC_REG_SCN_POS2_GPADC_SCAN_POS_7_SHIFT)
#define GPADC_REG_SCN_POS2_GPADC_SCAN_POS_6_MASK (0x1f)
#define GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_5_SHIFT (25)
#define GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_5_MASK (0x1f << GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_5_SHIFT)
#define GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_4_SHIFT (20)
#define GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_4_MASK (0x1f << GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_4_SHIFT)
#define GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_3_SHIFT (15)
#define GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_3_MASK (0x1f << GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_3_SHIFT)
#define GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_2_SHIFT (10)
#define GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_2_MASK (0x1f << GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_2_SHIFT)
#define GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_1_SHIFT (5)
#define GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_1_MASK (0x1f << GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_1_SHIFT)
#define GPADC_REG_SCN_NEG1_GPADC_SCAN_NEG_0_MASK (0x1f)
#define GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_11_SHIFT (25)
#define GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_11_MASK (0x1f << GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_11_SHIFT)
#define GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_10_SHIFT (20)
#define GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_10_MASK (0x1f << GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_10_SHIFT)
#define GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_9_SHIFT (15)
#define GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_9_MASK (0x1f << GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_9_SHIFT)
#define GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_8_SHIFT (10)
#define GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_8_MASK (0x1f << GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_8_SHIFT)
#define GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_7_SHIFT (5)
#define GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_7_MASK (0x1f << GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_7_SHIFT)
#define GPADC_REG_SCN_NEG2_GPADC_SCAN_NEG_6_MASK (0x1f)
#define GPADC_REG_STATUS_GPADC_DATA_RDY (1 << 0)
#define GPADC_REG_ISR_GPADC_POS_SATUR_MASK (1 << 9)
#define GPADC_REG_ISR_GPADC_NEG_SATUR_MASK (1 << 8)
#define GPADC_REG_ISR_GPADC_POS_SATUR_CLR (1 << 5)
#define GPADC_REG_ISR_GPADC_NEG_SATUR_CLR (1 << 4)
#define GPADC_REG_ISR_GPADC_POS_SATUR (1 << 1)
#define GPADC_REG_ISR_GPADC_NEG_SATUR (1 << 0)
#define GPADC_REG_RESULT_GPADC_DATA_OUT_MASK (0x3ffffff)
#define GPADC_REG_RAW_RESULT_GPADC_RAW_DATA_MASK (0xfff)
#define GPADC_REG_DEFINE_GPADC_OS_CAL_DATA_MASK (0xffff)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_AON_SEC_H */

View File

@ -0,0 +1,69 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_cci.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_CCI_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_CCI_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_CCI_CFG_OFFSET 0x000000 /* cci_cfg */
#define BL602_CCI_ADDR_OFFSET 0x000004 /* cci_addr */
#define BL602_CCI_WDATA_OFFSET 0x000008 /* cci_wdata */
#define BL602_CCI_RDATA_OFFSET 0x00000c /* cci_rdata */
#define BL602_CCI_CTL_OFFSET 0x000010 /* cci_ctl */
/* Register definitions *****************************************************/
#define BL602_CCI_CFG (BL602_CCI_BASE + BL602_CCI_CFG_OFFSET)
#define BL602_CCI_ADDR (BL602_CCI_BASE + BL602_CCI_ADDR_OFFSET)
#define BL602_CCI_WDATA (BL602_CCI_BASE + BL602_CCI_WDATA_OFFSET)
#define BL602_CCI_RDATA (BL602_CCI_BASE + BL602_CCI_RDATA_OFFSET)
#define BL602_CCI_CTL (BL602_CCI_BASE + BL602_CCI_CTL_OFFSET)
/* Register bit definitions *************************************************/
#define CCI_CFG_REG_MCCI_CLK_INV (1 << 9)
#define CCI_CFG_REG_SCCI_CLK_INV (1 << 8)
#define CCI_CFG_CFG_CCI1_PRE_READ (1 << 7)
#define CCI_CFG_REG_DIV_M_CCI_SCLK_SHIFT (5)
#define CCI_CFG_REG_DIV_M_CCI_SCLK_MASK (0x03 << CCI_CFG_REG_DIV_M_CCI_SCLK_SHIFT)
#define CCI_CFG_REG_M_CCI_SCLK_EN (1 << 4)
#define CCI_CFG_CCI_MAS_HW_MODE (1 << 3)
#define CCI_CFG_CCI_MAS_SEL_CCI2 (1 << 2)
#define CCI_CFG_CCI_SLV_SEL_CCI2 (1 << 1)
#define CCI_CFG_CCI_EN (1 << 0)
#define CCI_CTL_AHB_STATE_SHIFT (2)
#define CCI_CTL_AHB_STATE_MASK (0x03 << CCI_CTL_AHB_STATE_SHIFT)
#define CCI_CTL_CCI_READ_FLAG (1 << 1)
#define CCI_CTL_CCI_WRITE_FLAG (1 << 0)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_CCI_H */

View File

@ -0,0 +1,56 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_cks.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_CKS_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_CKS_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_CKS_CONFIG_OFFSET 0x000000 /* cks_config */
#define BL602_CKS_DATA_IN_OFFSET 0x000004 /* data_in */
#define BL602_CKS_OUT_OFFSET 0x000008 /* cks_out */
/* Register definitions *****************************************************/
#define BL602_CKS_CONFIG (BL602_CKS_BASE + BL602_CKS_CONFIG_OFFSET)
#define BL602_CKS_DATA_IN (BL602_CKS_BASE + BL602_CKS_DATA_IN_OFFSET)
#define BL602_CKS_OUT (BL602_CKS_BASE + BL602_CKS_OUT_OFFSET)
/* Register bit definitions *************************************************/
#define CKS_CONFIG_CR_CKS_BYTE_SWAP (1 << 1)
#define CKS_CKS_CONFIG_CR_CKS_CLR (1 << 0)
#define CKS_DATA_IN_MASK (0xff)
#define CKS_OUT_MASK (0xffff)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_CKS_H */

View File

@ -0,0 +1,57 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_clic.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_CLIC_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_CLIC_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_CLIC_MSIP_OFFSET 0x0000
#define BL602_CLIC_MTIMECMP_OFFSET 0x4000
#define BL602_CLIC_MTIME_OFFSET 0xbff8
#define BL602_CLIC_INTIP_OFFSET 0x000
#define BL602_CLIC_INTIE_OFFSET 0x400
#define BL602_CLIC_INTCFG_OFFSET 0x800
#define BL602_CLIC_CFG_OFFSET 0xc00
/* Register definitions *****************************************************/
#define BL602_CLIC_MSIP (BL602_CLIC_CTRL_BASE + BL602_CLIC_MSIP_OFFSET)
#define BL602_CLIC_MTIMECMP (BL602_CLIC_CTRL_BASE + BL602_CLIC_MTIMECMP_OFFSET)
#define BL602_CLIC_MTIME (BL602_CLIC_CTRL_BASE + BL602_CLIC_MTIME_OFFSET)
#define BL602_CLIC_INTIP (BL602_CLIC_HART0_BASE + BL602_CLIC_INTIP_OFFSET)
#define BL602_CLIC_INTIE (BL602_CLIC_HART0_BASE + BL602_CLIC_INTIE_OFFSET)
#define BL602_CLIC_INTCFG (BL602_CLIC_HART0_BASE + BL602_CLIC_INTCFG_OFFSET)
#define BL602_CLIC_CFG (BL602_CLIC_HART0_BASE + BL602_CLIC_CFG_OFFSET)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_CLIC_H */

View File

@ -1,183 +0,0 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_common.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_COMMON_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_COMMON_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <stdint.h>
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
#define BL602_FLASH_XIP_BASE (0x23000000)
#define BL602_FLASH_XIP_END (0x23000000 + 16 * 1024 * 1024)
#define BL602_FLASH_XIP_REMAP0_BASE (0x33000000)
#define BL602_FLASH_XIP_REMAP0_END (0x33000000 + 16 * 1024 * 1024)
#define BL602_FLASH_XIP_REMAP1_BASE (0x43000000)
#define BL602_FLASH_XIP_REMAP1_END (0x43000000 + 16 * 1024 * 1024)
#define BL602_FLASH_XIP_REMAP2_BASE (0x53000000)
#define BL602_FLASH_XIP_REMAP2_END (0x53000000 + 16 * 1024 * 1024)
#define BL602_WRAM_BASE (0x42020000)
#define BL602_WRAM_END (0x42020000 + 176 * 1024)
#define BL602_WRAM_REMAP0_BASE (0x22020000)
#define BL602_WRAM_REMAP0_END (0x22020000 + 176 * 1024)
#define BL602_WRAM_REMAP1_BASE (0x32020000)
#define BL602_WRAM_REMAP1_END (0x32020000 + 176 * 1024)
#define BL602_WRAM_REMAP2_BASE (0x52020000)
#define BL602_WRAM_REMAP2_END (0x52020000 + 176 * 1024)
#define BL602_TCM_BASE (0x22008000)
#define BL602_TCM_END (0x22008000 + (96 + 176) * 1024)
#define BL602_TCM_REMAP0_BASE (0x32008000)
#define BL602_TCM_REMAP0_END (0x32008000 + (96 + 176) * 1024)
#define BL602_TCM_REMAP1_BASE (0x42008000)
#define BL602_TCM_REMAP1_END (0x42008000 + (96 + 176) * 1024)
#define BL602_TCM_REMAP2_BASE (0x52008000)
#define BL602_TCM_REMAP2_END (0x52008000 + (96 + 176) * 1024)
/* BL602 peripherals base address */
#define GLB_BASE (0x40000000)
#define RF_BASE (0x40001000)
/* AUX module base address */
#define GPIP_BASE (0x40002000)
/* Security Debug module base address */
#define SEC_DBG_BASE (0x40003000)
/* Security Engine module base address */
#define SEC_ENG_BASE (0x40004000)
/* Trustzone control security base address */
#define TZC_SEC_BASE (0x40005000)
/* Trustzone control none-security base address */
#define TZC_NSEC_BASE (0x40006000)
#define EF_DATA_BASE (0x40007000)
#define EF_CTRL_BASE (0x40007000)
#define CCI_BASE (0x40008000)
/* L1 cache config base address */
#define L1C_BASE (0x40009000)
#define UART0_BASE (0x4000A000)
#define UART1_BASE (0x4000A100)
#define SPI_BASE (0x4000A200)
#define I2C_BASE (0x4000A300)
#define PWM_BASE (0x4000A400)
#define TIMER_BASE (0x4000A500)
#define IR_BASE (0x4000A600)
#define SF_CTRL_BASE (0x4000B000)
#define SF_CTRL_BUF_BASE (0x4000B700)
#define DMA_BASE (0x4000C000)
#define SDU_BASE (0x4000D000)
/* Power down sleep module base address */
#define PDS_BASE (0x4000E000)
/* Hibernate module base address */
#define HBN_BASE (0x4000F000)
/* Always on module base address */
#define AON_BASE (0x4000F000)
#define HBN_RAM_BASE (0x40010000)
/* Delay for a while */
#define BL_DRV_DUMMY() \
{ \
__asm volatile("nop"); \
__asm volatile("nop"); \
__asm volatile("nop"); \
__asm volatile("nop"); \
}
#define BL_AHB_SLAVE1_GLB 0x00
#define BL_AHB_SLAVE1_RF 0x01
#define BL_AHB_SLAVE1_GPIP_PHY_AGC 0x02
#define BL_AHB_SLAVE1_SEC_DBG 0x03
#define BL_AHB_SLAVE1_SEC 0x04
#define BL_AHB_SLAVE1_TZ1 0x05
#define BL_AHB_SLAVE1_TZ2 0x06
#define BL_AHB_SLAVE1_EFUSE 0x07
#define BL_AHB_SLAVE1_CCI 0x08
#define BL_AHB_SLAVE1_L1C 0x09
#define BL_AHB_SLAVE1_RSVD0A 0x0a
#define BL_AHB_SLAVE1_SFC 0x0b
#define BL_AHB_SLAVE1_DMA 0x0c
#define BL_AHB_SLAVE1_SDU 0x0d
#define BL_AHB_SLAVE1_PDS_HBN_AON_HBNRAM 0x0e
#define BL_AHB_SLAVE1_RSVD0F 0x0f
#define BL_AHB_SLAVE1_UART0 0x10
#define BL_AHB_SLAVE1_UART1 0x11
#define BL_AHB_SLAVE1_SPI 0x12
#define BL_AHB_SLAVE1_I2C 0x13
#define BL_AHB_SLAVE1_PWM 0x14
#define BL_AHB_SLAVE1_TMR 0x15
#define BL_AHB_SLAVE1_IRR 0x16
#define BL_AHB_SLAVE1_CKS 0x17
#define BL_AHB_SLAVE1_MAX 0x18
/* Std driver attribute macro */
#define ATTR_CLOCK_SECTION __attribute__((section(".sclock_rlt_code")))
#define ATTR_CLOCK_CONST_SECTION __attribute__((section(".sclock_rlt_const")))
#define ATTR_TCM_SECTION __attribute__((section(".tcm_code")))
#define ATTR_TCM_CONST_SECTION __attribute__((section(".tcm_const")))
#define ATTR_DTCM_SECTION __attribute__((section(".tcm_data")))
#define ATTR_HSRAM_SECTION __attribute__((section(".hsram_code")))
/****************************************************************************
* Public Types
****************************************************************************/
#ifndef __ASSEMBLY__
#ifdef __cplusplus
#define EXTERN extern "C"
extern "C"
{
#else
#define EXTERN extern
#endif
#undef EXTERN
#ifdef __cplusplus
}
#endif
#endif /* __ASSEMBLY__ */
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_COMMON_H */

View File

@ -0,0 +1,254 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_dma.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_DMA_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_DMA_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_DMA_INTSTATUS_OFFSET 0x000000 /* IntStatus */
#define BL602_DMA_INTTCSTATUS_OFFSET 0x000004 /* IntTCStatus */
#define BL602_DMA_INTTCCLEAR_OFFSET 0x000008 /* IntTCClear */
#define BL602_DMA_INTERRORSTATUS_OFFSET 0x00000c /* IntErrorStatus */
#define BL602_DMA_INTERRCLR_OFFSET 0x000010 /* IntErrClr */
#define BL602_DMA_RAWINTTCSTATUS_OFFSET 0x000014 /* RawIntTCStatus */
#define BL602_DMA_RAWINTERRORSTATUS_OFFSET 0x000018 /* RawIntErrorStatus */
#define BL602_DMA_ENBLDCHNS_OFFSET 0x00001c /* EnbldChns */
#define BL602_DMA_SOFTBREQ_OFFSET 0x000020 /* SoftBReq */
#define BL602_DMA_SOFTSREQ_OFFSET 0x000024 /* SoftSReq */
#define BL602_DMA_SOFTLBREQ_OFFSET 0x000028 /* SoftLBReq */
#define BL602_DMA_SOFTLSREQ_OFFSET 0x00002c /* SoftLSReq */
#define BL602_DMA_TOP_CONFIG_OFFSET 0x000030 /* Top_Config */
#define BL602_DMA_SYNC_OFFSET 0x000034 /* Sync */
#define BL602_DMA_C0SRCADDR_OFFSET 0x000100 /* C0SrcAddr */
#define BL602_DMA_C0DSTADDR_OFFSET 0x000104 /* C0DstAddr */
#define BL602_DMA_C0LLI_OFFSET 0x000108 /* C0LLI */
#define BL602_DMA_C0CONTROL_OFFSET 0x00010c /* C0Control */
#define BL602_DMA_C0CONFIG_OFFSET 0x000110 /* C0Config */
#define BL602_DMA_C1SRCADDR_OFFSET 0x000200 /* C1SrcAddr */
#define BL602_DMA_C1DSTADDR_OFFSET 0x000204 /* C1DstAddr */
#define BL602_DMA_C1LLI_OFFSET 0x000208 /* C1LLI */
#define BL602_DMA_C1CONTROL_OFFSET 0x00020c /* C1Control */
#define BL602_DMA_C1CONFIG_OFFSET 0x000210 /* C1Config */
#define BL602_DMA_C2SRCADDR_OFFSET 0x000300 /* C2SrcAddr */
#define BL602_DMA_C2DSTADDR_OFFSET 0x000304 /* C2DstAddr */
#define BL602_DMA_C2LLI_OFFSET 0x000308 /* C2LLI */
#define BL602_DMA_C2CONTROL_OFFSET 0x00030c /* C2Control */
#define BL602_DMA_C2CONFIG_OFFSET 0x000310 /* C2Config */
#define BL602_DMA_C3SRCADDR_OFFSET 0x000400 /* C3SrcAddr */
#define BL602_DMA_C3DSTADDR_OFFSET 0x000404 /* C3DstAddr */
#define BL602_DMA_C3LLI_OFFSET 0x000408 /* C3LLI */
#define BL602_DMA_C3CONTROL_OFFSET 0x00040c /* C3Control */
#define BL602_DMA_C3CONFIG_OFFSET 0x000410 /* C3Config */
/* Register definitions *****************************************************/
#define BL602_DMA_INTSTATUS (BL602_DMA_BASE + BL602_DMA_INTSTATUS_OFFSET)
#define BL602_DMA_INTTCSTATUS (BL602_DMA_BASE + BL602_DMA_INTTCSTATUS_OFFSET)
#define BL602_DMA_INTTCCLEAR (BL602_DMA_BASE + BL602_DMA_INTTCCLEAR_OFFSET)
#define BL602_DMA_INTERRORSTATUS (BL602_DMA_BASE + BL602_DMA_INTERRORSTATUS_OFFSET)
#define BL602_DMA_INTERRCLR (BL602_DMA_BASE + BL602_DMA_INTERRCLR_OFFSET)
#define BL602_DMA_RAWINTTCSTATUS (BL602_DMA_BASE + BL602_DMA_RAWINTTCSTATUS_OFFSET)
#define BL602_DMA_RAWINTERRORSTATUS (BL602_DMA_BASE + BL602_DMA_RAWINTERRORSTATUS_OFFSET)
#define BL602_DMA_ENBLDCHNS (BL602_DMA_BASE + BL602_DMA_ENBLDCHNS_OFFSET)
#define BL602_DMA_SOFTBREQ (BL602_DMA_BASE + BL602_DMA_SOFTBREQ_OFFSET)
#define BL602_DMA_SOFTSREQ (BL602_DMA_BASE + BL602_DMA_SOFTSREQ_OFFSET)
#define BL602_DMA_SOFTLBREQ (BL602_DMA_BASE + BL602_DMA_SOFTLBREQ_OFFSET)
#define BL602_DMA_SOFTLSREQ (BL602_DMA_BASE + BL602_DMA_SOFTLSREQ_OFFSET)
#define BL602_DMA_TOP_CONFIG (BL602_DMA_BASE + BL602_DMA_TOP_CONFIG_OFFSET)
#define BL602_DMA_SYNC (BL602_DMA_BASE + BL602_DMA_SYNC_OFFSET)
#define BL602_DMA_C0SRCADDR (BL602_DMA_BASE + BL602_DMA_C0SRCADDR_OFFSET)
#define BL602_DMA_C0DSTADDR (BL602_DMA_BASE + BL602_DMA_C0DSTADDR_OFFSET)
#define BL602_DMA_C0LLI (BL602_DMA_BASE + BL602_DMA_C0LLI_OFFSET)
#define BL602_DMA_C0CONTROL (BL602_DMA_BASE + BL602_DMA_C0CONTROL_OFFSET)
#define BL602_DMA_C0CONFIG (BL602_DMA_BASE + BL602_DMA_C0CONFIG_OFFSET)
#define BL602_DMA_C1SRCADDR (BL602_DMA_BASE + BL602_DMA_C1SRCADDR_OFFSET)
#define BL602_DMA_C1DSTADDR (BL602_DMA_BASE + BL602_DMA_C1DSTADDR_OFFSET)
#define BL602_DMA_C1LLI (BL602_DMA_BASE + BL602_DMA_C1LLI_OFFSET)
#define BL602_DMA_C1CONTROL (BL602_DMA_BASE + BL602_DMA_C1CONTROL_OFFSET)
#define BL602_DMA_C1CONFIG (BL602_DMA_BASE + BL602_DMA_C1CONFIG_OFFSET)
#define BL602_DMA_C2SRCADDR (BL602_DMA_BASE + BL602_DMA_C2SRCADDR_OFFSET)
#define BL602_DMA_C2DSTADDR (BL602_DMA_BASE + BL602_DMA_C2DSTADDR_OFFSET)
#define BL602_DMA_C2LLI (BL602_DMA_BASE + BL602_DMA_C2LLI_OFFSET)
#define BL602_DMA_C2CONTROL (BL602_DMA_BASE + BL602_DMA_C2CONTROL_OFFSET)
#define BL602_DMA_C2CONFIG (BL602_DMA_BASE + BL602_DMA_C2CONFIG_OFFSET)
#define BL602_DMA_C3SRCADDR (BL602_DMA_BASE + BL602_DMA_C3SRCADDR_OFFSET)
#define BL602_DMA_C3DSTADDR (BL602_DMA_BASE + BL602_DMA_C3DSTADDR_OFFSET)
#define BL602_DMA_C3LLI (BL602_DMA_BASE + BL602_DMA_C3LLI_OFFSET)
#define BL602_DMA_C3CONTROL (BL602_DMA_BASE + BL602_DMA_C3CONTROL_OFFSET)
#define BL602_DMA_C3CONFIG (BL602_DMA_BASE + BL602_DMA_C3CONFIG_OFFSET)
/* Register bit definitions *************************************************/
#define DMA_INTSTATUS_MASK (0xff)
#define DMA_INTTCSTATUS_MASK (0xff)
#define DMA_INTTCCLEAR_MASK (0xff)
#define DMA_INTERRORSTATUS_MASK (0xff)
#define DMA_INTERRCLR_MASK (0xff)
#define DMA_RAWINTTCSTATUS_MASK (0xff)
#define DMA_RAWINTERRORSTATUS_MASK (0xff)
#define DMA_ENBLDCHNS_MASK (0xff)
#define DMA_TOP_CONFIG_M (1 << 1)
#define DMA_TOP_CONFIG_E (1 << 0)
#define DMA_C0CONTROL_I (1 << 31)
#define DMA_C0CONTROL_PROT_SHIFT (28)
#define DMA_C0CONTROL_PROT_MASK (0x07 << DMA_C0CONTROL_PROT_SHIFT)
#define DMA_C0CONTROL_DI (1 << 27)
#define DMA_C0CONTROL_SI (1 << 26)
#define DMA_C0CONTROL_SLARGERD (1 << 24)
#define DMA_C0CONTROL_DWIDTH_SHIFT (21)
#define DMA_C0CONTROL_DWIDTH_MASK (0x07 << DMA_C0CONTROL_DWIDTH_SHIFT)
#define DMA_C0CONTROL_SWIDTH_SHIFT (18)
#define DMA_C0CONTROL_SWIDTH_MASK (0x07 << DMA_C0CONTROL_SWIDTH_SHIFT)
#define DMA_C0CONTROL_DBSIZE_SHIFT (15)
#define DMA_C0CONTROL_DBSIZE_MASK (0x07 << DMA_C0CONTROL_DBSIZE_SHIFT)
#define DMA_C0CONTROL_SBSIZE_SHIFT (12)
#define DMA_C0CONTROL_SBSIZE_MASK (0x07 << DMA_C0CONTROL_SBSIZE_SHIFT)
#define DMA_C0CONTROL_TRANSFERSIZE_MASK (0xfff)
#define DMA_C0CONFIG_LLICOUNTER_SHIFT (20)
#define DMA_C0CONFIG_LLICOUNTER_MASK (0x3ff << DMA_C0CONFIG_LLICOUNTER_SHIFT)
#define DMA_C0CONFIG_H (1 << 18)
#define DMA_C0CONFIG_A (1 << 17)
#define DMA_C0CONFIG_L (1 << 16)
#define DMA_C0CONFIG_ITC (1 << 15)
#define DMA_C0CONFIG_IE (1 << 14)
#define DMA_C0CONFIG_FLOWCNTRL_SHIFT (11)
#define DMA_C0CONFIG_FLOWCNTRL_MASK (0x07 << DMA_C0CONFIG_FLOWCNTRL_SHIFT)
#define DMA_C0CONFIG_DSTPERIPHERAL_SHIFT (6)
#define DMA_C0CONFIG_DSTPERIPHERAL_MASK (0x1f << DMA_C0CONFIG_DSTPERIPHERAL_SHIFT)
#define DMA_C0CONFIG_SRCPERIPHERAL_SHIFT (1)
#define DMA_C0CONFIG_SRCPERIPHERAL_MASK (0x1f << DMA_C0CONFIG_SRCPERIPHERAL_SHIFT)
#define DMA_C0CONFIG_E (1 << 0)
#define DMA_C1LLI_LLI_SHIFT (2)
#define DMA_C1LLI_LLI_MASK (0x3fffffff << DMA_C1LLI_LLI_SHIFT)
#define DMA_C1CONTROL_I (1 << 31)
#define DMA_C1CONTROL_PROT_SHIFT (28)
#define DMA_C1CONTROL_PROT_MASK (0x07 << DMA_C1CONTROL_PROT_SHIFT)
#define DMA_C1CONTROL_DI (1 << 27)
#define DMA_C1CONTROL_SI (1 << 26)
#define DMA_C1CONTROL_DWIDTH_SHIFT (21)
#define DMA_C1CONTROL_DWIDTH_MASK (0x07 << DMA_C1CONTROL_DWIDTH_SHIFT)
#define DMA_C1CONTROL_SWIDTH_SHIFT (18)
#define DMA_C1CONTROL_SWIDTH_MASK (0x07 << DMA_C1CONTROL_SWIDTH_SHIFT)
#define DMA_C1CONTROL_DBSIZE_SHIFT (15)
#define DMA_C1CONTROL_DBSIZE_MASK (0x07 << DMA_C1CONTROL_DBSIZE_SHIFT)
#define DMA_C1CONTROL_SBSIZE_SHIFT (12)
#define DMA_C1CONTROL_SBSIZE_MASK (0x07 << DMA_C1CONTROL_SBSIZE_SHIFT)
#define DMA_C1CONTROL_TRANSFERSIZE_MASK (0xfff)
#define DMA_C1CONFIG_H (1 << 18)
#define DMA_C1CONFIG_A (1 << 17)
#define DMA_C1CONFIG_L (1 << 16)
#define DMA_C1CONFIG_ITC (1 << 15)
#define DMA_C1CONFIG_IE (1 << 14)
#define DMA_C1CONFIG_FLOWCNTRL_SHIFT (11)
#define DMA_C1CONFIG_FLOWCNTRL_MASK (0x07 << DMA_C1CONFIG_FLOWCNTRL_SHIFT)
#define DMA_C1CONFIG_DSTPERIPHERAL_SHIFT (6)
#define DMA_C1CONFIG_DSTPERIPHERAL_MASK (0x1f << DMA_C1CONFIG_DSTPERIPHERAL_SHIFT)
#define DMA_C1CONFIG_SRCPERIPHERAL_SHIFT (1)
#define DMA_C1CONFIG_SRCPERIPHERAL_MASK (0x1f << DMA_C1CONFIG_SRCPERIPHERAL_SHIFT)
#define DMA_C1CONFIG_E (1 << 0)
#define DMA_C2LLI_LLI_SHIFT (2)
#define DMA_C2LLI_LLI_MASK (0x3fffffff << DMA_C2LLI_LLI_SHIFT)
#define DMA_C2CONTROL_I (1 << 31)
#define DMA_C2CONTROL_PROT_SHIFT (28)
#define DMA_C2CONTROL_PROT_MASK (0x07 << DMA_C2CONTROL_PROT_SHIFT)
#define DMA_C2CONTROL_DI (1 << 27)
#define DMA_C2CONTROL_SI (1 << 26)
#define DMA_C2CONTROL_DWIDTH_SHIFT (21)
#define DMA_C2CONTROL_DWIDTH_MASK (0x07 << DMA_C2CONTROL_DWIDTH_SHIFT)
#define DMA_C2CONTROL_SWIDTH_SHIFT (18)
#define DMA_C2CONTROL_SWIDTH_MASK (0x07 << DMA_C2CONTROL_SWIDTH_SHIFT)
#define DMA_C2CONTROL_DBSIZE_SHIFT (15)
#define DMA_C2CONTROL_DBSIZE_MASK (0x07 << DMA_C2CONTROL_DBSIZE_SHIFT)
#define DMA_C2CONTROL_SBSIZE_SHIFT (12)
#define DMA_C2CONTROL_SBSIZE_MASK (0x07 << DMA_C2CONTROL_SBSIZE_SHIFT)
#define DMA_C2CONTROL_TRANSFERSIZE_MASK (0xfff)
#define DMA_C2CONFIG_H (1 << 18)
#define DMA_C2CONFIG_A (1 << 17)
#define DMA_C2CONFIG_L (1 << 16)
#define DMA_C2CONFIG_ITC (1 << 15)
#define DMA_C2CONFIG_IE (1 << 14)
#define DMA_C2CONFIG_FLOWCNTRL_SHIFT (11)
#define DMA_C2CONFIG_FLOWCNTRL_MASK (0x07 << DMA_C2CONFIG_FLOWCNTRL_SHIFT)
#define DMA_C2CONFIG_DSTPERIPHERAL_SHIFT (6)
#define DMA_C2CONFIG_DSTPERIPHERAL_MASK (0x1f << DMA_C2CONFIG_DSTPERIPHERAL_SHIFT)
#define DMA_C2CONFIG_SRCPERIPHERAL_SHIFT (1)
#define DMA_C2CONFIG_SRCPERIPHERAL_MASK (0x1f << DMA_C2CONFIG_SRCPERIPHERAL_SHIFT)
#define DMA_C2CONFIG_E (1 << 0)
#define DMA_C3LLI_LLI_SHIFT (2)
#define DMA_C3LLI_LLI_MASK (0x3fffffff << DMA_C3LLI_LLI_SHIFT)
#define DMA_C3CONTROL_I (1 << 31)
#define DMA_C3CONTROL_PROT_SHIFT (28)
#define DMA_C3CONTROL_PROT_MASK (0x07 << DMA_C3CONTROL_PROT_SHIFT)
#define DMA_C3CONTROL_DI (1 << 27)
#define DMA_C3CONTROL_SI (1 << 26)
#define DMA_C3CONTROL_DWIDTH_SHIFT (21)
#define DMA_C3CONTROL_DWIDTH_MASK (0x07 << DMA_C3CONTROL_DWIDTH_SHIFT)
#define DMA_C3CONTROL_SWIDTH_SHIFT (18)
#define DMA_C3CONTROL_SWIDTH_MASK (0x07 << DMA_C3CONTROL_SWIDTH_SHIFT)
#define DMA_C3CONTROL_DBSIZE_SHIFT (15)
#define DMA_C3CONTROL_DBSIZE_MASK (0x07 << DMA_C3CONTROL_DBSIZE_SHIFT)
#define DMA_C3CONTROL_SBSIZE_SHIFT (12)
#define DMA_C3CONTROL_SBSIZE_MASK (0x07 << DMA_C3CONTROL_SBSIZE_SHIFT)
#define DMA_C3CONTROL_TRANSFERSIZE_MASK (0xfff)
#define DMA_C3CONFIG_H (1 << 18)
#define DMA_C3CONFIG_A (1 << 17)
#define DMA_C3CONFIG_L (1 << 16)
#define DMA_C3CONFIG_ITC (1 << 15)
#define DMA_C3CONFIG_IE (1 << 14)
#define DMA_C3CONFIG_FLOWCNTRL_SHIFT (11)
#define DMA_C3CONFIG_FLOWCNTRL_MASK (0x07 << DMA_C3CONFIG_FLOWCNTRL_SHIFT)
#define DMA_C3CONFIG_DSTPERIPHERAL_SHIFT (6)
#define DMA_C3CONFIG_DSTPERIPHERAL_MASK (0x1f << DMA_C3CONFIG_DSTPERIPHERAL_SHIFT)
#define DMA_C3CONFIG_SRCPERIPHERAL_SHIFT (1)
#define DMA_C3CONFIG_SRCPERIPHERAL_MASK (0x1f << DMA_C3CONFIG_SRCPERIPHERAL_SHIFT)
#define DMA_C3CONFIG_E (1 << 0)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_DMA_H */

View File

@ -0,0 +1,372 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_ef.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_EF_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_EF_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_EF_CFG_0_OFFSET 0x000000 /* ef_cfg_0 */
#define BL602_EF_DBG_PWD_LOW_OFFSET 0x000004 /* ef_dbg_pwd_low */
#define BL602_EF_DBG_PWD_HIGH_OFFSET 0x000008 /* ef_dbg_pwd_high */
#define BL602_EF_ANA_TRIM_0_OFFSET 0x00000c /* ef_ana_trim_0 */
#define BL602_EF_SW_USAGE_0_OFFSET 0x000010 /* ef_sw_usage_0 */
#define BL602_EF_WIFI_MAC_LOW_OFFSET 0x000014 /* ef_wifi_mac_low */
#define BL602_EF_WIFI_MAC_HIGH_OFFSET 0x000018 /* ef_wifi_mac_high */
#define BL602_EF_KEY_SLOT_0_W0_OFFSET 0x00001c /* ef_key_slot_0_w0 */
#define BL602_EF_KEY_SLOT_0_W1_OFFSET 0x000020 /* ef_key_slot_0_w1 */
#define BL602_EF_KEY_SLOT_0_W2_OFFSET 0x000024 /* ef_key_slot_0_w2 */
#define BL602_EF_KEY_SLOT_0_W3_OFFSET 0x000028 /* ef_key_slot_0_w3 */
#define BL602_EF_KEY_SLOT_1_W0_OFFSET 0x00002c /* ef_key_slot_1_w0 */
#define BL602_EF_KEY_SLOT_1_W1_OFFSET 0x000030 /* ef_key_slot_1_w1 */
#define BL602_EF_KEY_SLOT_1_W2_OFFSET 0x000034 /* ef_key_slot_1_w2 */
#define BL602_EF_KEY_SLOT_1_W3_OFFSET 0x000038 /* ef_key_slot_1_w3 */
#define BL602_EF_KEY_SLOT_2_W0_OFFSET 0x00003c /* ef_key_slot_2_w0 */
#define BL602_EF_KEY_SLOT_2_W1_OFFSET 0x000040 /* ef_key_slot_2_w1 */
#define BL602_EF_KEY_SLOT_2_W2_OFFSET 0x000044 /* ef_key_slot_2_w2 */
#define BL602_EF_KEY_SLOT_2_W3_OFFSET 0x000048 /* ef_key_slot_2_w3 */
#define BL602_EF_KEY_SLOT_3_W0_OFFSET 0x00004c /* ef_key_slot_3_w0 */
#define BL602_EF_KEY_SLOT_3_W1_OFFSET 0x000050 /* ef_key_slot_3_w1 */
#define BL602_EF_KEY_SLOT_3_W2_OFFSET 0x000054 /* ef_key_slot_3_w2 */
#define BL602_EF_KEY_SLOT_3_W3_OFFSET 0x000058 /* ef_key_slot_3_w3 */
#define BL602_EF_KEY_SLOT_4_W0_OFFSET 0x00005c /* ef_key_slot_4_w0 */
#define BL602_EF_KEY_SLOT_4_W1_OFFSET 0x000060 /* ef_key_slot_4_w1 */
#define BL602_EF_KEY_SLOT_4_W2_OFFSET 0x000064 /* ef_key_slot_4_w2 */
#define BL602_EF_KEY_SLOT_4_W3_OFFSET 0x000068 /* ef_key_slot_4_w3 */
#define BL602_EF_KEY_SLOT_5_W0_OFFSET 0x00006c /* ef_key_slot_5_w0 */
#define BL602_EF_KEY_SLOT_5_W1_OFFSET 0x000070 /* ef_key_slot_5_w1 */
#define BL602_EF_KEY_SLOT_5_W2_OFFSET 0x000074 /* ef_key_slot_5_w2 */
#define BL602_EF_KEY_SLOT_5_W3_OFFSET 0x000078 /* ef_key_slot_5_w3 */
#define BL602_EF_DATA_0_LOCK_OFFSET 0x00007c /* ef_data_0_lock */
#define BL602_EF_REG_KEY_SLOT_6_W0_OFFSET 0x000080 /* reg_key_slot_6_w0 */
#define BL602_EF_REG_KEY_SLOT_6_W1_OFFSET 0x000084 /* reg_key_slot_6_w1 */
#define BL602_EF_REG_KEY_SLOT_6_W2_OFFSET 0x000088 /* reg_key_slot_6_w2 */
#define BL602_EF_REG_KEY_SLOT_6_W3_OFFSET 0x00008c /* reg_key_slot_6_w3 */
#define BL602_EF_REG_KEY_SLOT_7_W0_OFFSET 0x000090 /* reg_key_slot_7_w0 */
#define BL602_EF_REG_KEY_SLOT_7_W1_OFFSET 0x000094 /* reg_key_slot_7_w1 */
#define BL602_EF_REG_KEY_SLOT_7_W2_OFFSET 0x000098 /* reg_key_slot_7_w2 */
#define BL602_EF_REG_KEY_SLOT_7_W3_OFFSET 0x00009c /* reg_key_slot_7_w3 */
#define BL602_EF_REG_KEY_SLOT_8_W0_OFFSET 0x0000a0 /* reg_key_slot_8_w0 */
#define BL602_EF_REG_KEY_SLOT_8_W1_OFFSET 0x0000a4 /* reg_key_slot_8_w1 */
#define BL602_EF_REG_KEY_SLOT_8_W2_OFFSET 0x0000a8 /* reg_key_slot_8_w2 */
#define BL602_EF_REG_KEY_SLOT_8_W3_OFFSET 0x0000ac /* reg_key_slot_8_w3 */
#define BL602_EF_REG_KEY_SLOT_9_W0_OFFSET 0x0000b0 /* reg_key_slot_9_w0 */
#define BL602_EF_REG_KEY_SLOT_9_W1_OFFSET 0x0000b4 /* reg_key_slot_9_w1 */
#define BL602_EF_REG_KEY_SLOT_9_W2_OFFSET 0x0000b8 /* reg_key_slot_9_w2 */
#define BL602_EF_REG_KEY_SLOT_9_W3_OFFSET 0x0000bc /* reg_key_slot_9_w3 */
#define BL602_EF_REG_KEY_SLOT_10_W0_OFFSET 0x0000c0 /* reg_key_slot_10_w0 */
#define BL602_EF_REG_KEY_SLOT_10_W1_OFFSET 0x0000c4 /* reg_key_slot_10_w1 */
#define BL602_EF_REG_KEY_SLOT_10_W2_OFFSET 0x0000c8 /* reg_key_slot_10_w2 */
#define BL602_EF_REG_KEY_SLOT_10_W3_OFFSET 0x0000cc /* reg_key_slot_10_w3 */
#define BL602_EF_REG_KEY_SLOT_11_W0_OFFSET 0x0000d0 /* reg_key_slot_11_w0 */
#define BL602_EF_REG_KEY_SLOT_11_W1_OFFSET 0x0000d4 /* reg_key_slot_11_w1 */
#define BL602_EF_REG_KEY_SLOT_11_W2_OFFSET 0x0000d8 /* reg_key_slot_11_w2 */
#define BL602_EF_REG_KEY_SLOT_11_W3_OFFSET 0x0000dc /* reg_key_slot_11_w3 */
#define BL602_EF_REG_DATA_1_LOCK_OFFSET 0x0000e0 /* reg_data_1_lock */
#define BL602_EF_IF_CTRL_0_OFFSET 0x000800 /* ef_if_ctrl_0 */
#define BL602_EF_IF_CYC_0_OFFSET 0x000804 /* ef_if_cyc_0 */
#define BL602_EF_IF_CYC_1_OFFSET 0x000808 /* ef_if_cyc_1 */
#define BL602_EF_IF_0_MANUAL_OFFSET 0x00080c /* ef_if_0_manual */
#define BL602_EF_IF_0_STATUS_OFFSET 0x000810 /* ef_if_0_status */
#define BL602_EF_IF_CFG_0_OFFSET 0x000814 /* ef_if_cfg_0 */
#define BL602_EF_SW_CFG_0_OFFSET 0x000818 /* ef_sw_cfg_0 */
#define BL602_EF_RESERVED_OFFSET 0x00081c /* ef_reserved */
#define BL602_EF_IF_ANA_TRIM_0_OFFSET 0x000820 /* ef_if_ana_trim_0 */
#define BL602_EF_IF_SW_USAGE_0_OFFSET 0x000824 /* ef_if_sw_usage_0 */
#define BL602_EF_CRC_CTRL_0_OFFSET 0x000a00 /* ef_crc_ctrl_0 */
#define BL602_EF_CRC_CTRL_1_OFFSET 0x000a04 /* ef_crc_ctrl_1 */
#define BL602_EF_CRC_CTRL_2_OFFSET 0x000a08 /* ef_crc_ctrl_2 */
#define BL602_EF_CRC_CTRL_3_OFFSET 0x000a0c /* ef_crc_ctrl_3 */
#define BL602_EF_CRC_CTRL_4_OFFSET 0x000a10 /* ef_crc_ctrl_4 */
#define BL602_EF_CRC_CTRL_5_OFFSET 0x000a14 /* ef_crc_ctrl_5 */
/* Register definitions *****************************************************/
#define BL602_EF_CFG_0 ( BL602_EF_BASE + BL602_EF_CFG_0_OFFSET)
#define BL602_EF_DBG_PWD_LOW ( BL602_EF_BASE + BL602_EF_DBG_PWD_LOW_OFFSET)
#define BL602_EF_DBG_PWD_HIGH ( BL602_EF_BASE + BL602_EF_DBG_PWD_HIGH_OFFSET)
#define BL602_EF_ANA_TRIM_0 ( BL602_EF_BASE + BL602_EF_ANA_TRIM_0_OFFSET)
#define BL602_EF_SW_USAGE_0 ( BL602_EF_BASE + BL602_EF_SW_USAGE_0_OFFSET)
#define BL602_EF_WIFI_MAC_LOW ( BL602_EF_BASE + BL602_EF_WIFI_MAC_LOW_OFFSET)
#define BL602_EF_WIFI_MAC_HIGH ( BL602_EF_BASE + BL602_EF_WIFI_MAC_HIGH_OFFSET)
#define BL602_EF_KEY_SLOT_0_W0 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_0_W0_OFFSET)
#define BL602_EF_KEY_SLOT_0_W1 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_0_W1_OFFSET)
#define BL602_EF_KEY_SLOT_0_W2 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_0_W2_OFFSET)
#define BL602_EF_KEY_SLOT_0_W3 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_0_W3_OFFSET)
#define BL602_EF_KEY_SLOT_1_W0 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_1_W0_OFFSET)
#define BL602_EF_KEY_SLOT_1_W1 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_1_W1_OFFSET)
#define BL602_EF_KEY_SLOT_1_W2 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_1_W2_OFFSET)
#define BL602_EF_KEY_SLOT_1_W3 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_1_W3_OFFSET)
#define BL602_EF_KEY_SLOT_2_W0 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_2_W0_OFFSET)
#define BL602_EF_KEY_SLOT_2_W1 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_2_W1_OFFSET)
#define BL602_EF_KEY_SLOT_2_W2 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_2_W2_OFFSET)
#define BL602_EF_KEY_SLOT_2_W3 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_2_W3_OFFSET)
#define BL602_EF_KEY_SLOT_3_W0 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_3_W0_OFFSET)
#define BL602_EF_KEY_SLOT_3_W1 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_3_W1_OFFSET)
#define BL602_EF_KEY_SLOT_3_W2 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_3_W2_OFFSET)
#define BL602_EF_KEY_SLOT_3_W3 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_3_W3_OFFSET)
#define BL602_EF_KEY_SLOT_4_W0 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_4_W0_OFFSET)
#define BL602_EF_KEY_SLOT_4_W1 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_4_W1_OFFSET)
#define BL602_EF_KEY_SLOT_4_W2 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_4_W2_OFFSET)
#define BL602_EF_KEY_SLOT_4_W3 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_4_W3_OFFSET)
#define BL602_EF_KEY_SLOT_5_W0 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_5_W0_OFFSET)
#define BL602_EF_KEY_SLOT_5_W1 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_5_W1_OFFSET)
#define BL602_EF_KEY_SLOT_5_W2 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_5_W2_OFFSET)
#define BL602_EF_KEY_SLOT_5_W3 ( BL602_EF_BASE + BL602_EF_KEY_SLOT_5_W3_OFFSET)
#define BL602_EF_DATA_0_LOCK ( BL602_EF_BASE + BL602_EF_DATA_0_LOCK_OFFSET)
#define BL602_EF_REG_KEY_SLOT_6_W0 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_6_W0_OFFSET)
#define BL602_EF_REG_KEY_SLOT_6_W1 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_6_W1_OFFSET)
#define BL602_EF_REG_KEY_SLOT_6_W2 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_6_W2_OFFSET)
#define BL602_EF_REG_KEY_SLOT_6_W3 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_6_W3_OFFSET)
#define BL602_EF_REG_KEY_SLOT_7_W0 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_7_W0_OFFSET)
#define BL602_EF_REG_KEY_SLOT_7_W1 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_7_W1_OFFSET)
#define BL602_EF_REG_KEY_SLOT_7_W2 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_7_W2_OFFSET)
#define BL602_EF_REG_KEY_SLOT_7_W3 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_7_W3_OFFSET)
#define BL602_EF_REG_KEY_SLOT_8_W0 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_8_W0_OFFSET)
#define BL602_EF_REG_KEY_SLOT_8_W1 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_8_W1_OFFSET)
#define BL602_EF_REG_KEY_SLOT_8_W2 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_8_W2_OFFSET)
#define BL602_EF_REG_KEY_SLOT_8_W3 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_8_W3_OFFSET)
#define BL602_EF_REG_KEY_SLOT_9_W0 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_9_W0_OFFSET)
#define BL602_EF_REG_KEY_SLOT_9_W1 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_9_W1_OFFSET)
#define BL602_EF_REG_KEY_SLOT_9_W2 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_9_W2_OFFSET)
#define BL602_EF_REG_KEY_SLOT_9_W3 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_9_W3_OFFSET)
#define BL602_EF_REG_KEY_SLOT_10_W0 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_10_W0_OFFSET)
#define BL602_EF_REG_KEY_SLOT_10_W1 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_10_W1_OFFSET)
#define BL602_EF_REG_KEY_SLOT_10_W2 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_10_W2_OFFSET)
#define BL602_EF_REG_KEY_SLOT_10_W3 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_10_W3_OFFSET)
#define BL602_EF_REG_KEY_SLOT_11_W0 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_11_W0_OFFSET)
#define BL602_EF_REG_KEY_SLOT_11_W1 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_11_W1_OFFSET)
#define BL602_EF_REG_KEY_SLOT_11_W2 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_11_W2_OFFSET)
#define BL602_EF_REG_KEY_SLOT_11_W3 ( BL602_EF_BASE + BL602_EF_REG_KEY_SLOT_11_W3_OFFSET)
#define BL602_EF_REG_DATA_1_LOCK ( BL602_EF_BASE + BL602_EF_REG_DATA_1_LOCK_OFFSET)
#define BL602_EF_IF_CTRL_0 ( BL602_EF_BASE + BL602_EF_IF_CTRL_0_OFFSET)
#define BL602_EF_IF_CYC_0 ( BL602_EF_BASE + BL602_EF_IF_CYC_0_OFFSET)
#define BL602_EF_IF_CYC_1 ( BL602_EF_BASE + BL602_EF_IF_CYC_1_OFFSET)
#define BL602_EF_IF_0_MANUAL ( BL602_EF_BASE + BL602_EF_IF_0_MANUAL_OFFSET)
#define BL602_EF_IF_0_STATUS ( BL602_EF_BASE + BL602_EF_IF_0_STATUS_OFFSET)
#define BL602_EF_IF_CFG_0 ( BL602_EF_BASE + BL602_EF_IF_CFG_0_OFFSET)
#define BL602_EF_SW_CFG_0 ( BL602_EF_BASE + BL602_EF_SW_CFG_0_OFFSET)
#define BL602_EF_RESERVED ( BL602_EF_BASE + BL602_EF_RESERVED_OFFSET)
#define BL602_EF_IF_ANA_TRIM_0 ( BL602_EF_BASE + BL602_EF_IF_ANA_TRIM_0_OFFSET)
#define BL602_EF_IF_SW_USAGE_0 ( BL602_EF_BASE + BL602_EF_IF_SW_USAGE_0_OFFSET)
#define BL602_EF_CRC_CTRL_0 ( BL602_EF_BASE + BL602_EF_CRC_CTRL_0_OFFSET)
#define BL602_EF_CRC_CTRL_1 ( BL602_EF_BASE + BL602_EF_CRC_CTRL_1_OFFSET)
#define BL602_EF_CRC_CTRL_2 ( BL602_EF_BASE + BL602_EF_CRC_CTRL_2_OFFSET)
#define BL602_EF_CRC_CTRL_3 ( BL602_EF_BASE + BL602_EF_CRC_CTRL_3_OFFSET)
#define BL602_EF_CRC_CTRL_4 ( BL602_EF_BASE + BL602_EF_CRC_CTRL_4_OFFSET)
#define BL602_EF_CRC_CTRL_5 ( BL602_EF_BASE + BL602_EF_CRC_CTRL_5_OFFSET)
/* Register bit definitions *************************************************/
#define EF_CFG_0_EF_DBG_MODE_SHIFT (28)
#define EF_CFG_0_EF_DBG_MODE_MASK (0x0f << EF_CFG_0_EF_DBG_MODE_SHIFT)
#define EF_CFG_0_EF_DBG_JTAG_0_DIS_SHIFT (26)
#define EF_CFG_0_EF_DBG_JTAG_0_DIS_MASK (0x03 << EF_CFG_0_EF_DBG_JTAG_0_DIS_SHIFT)
#define EF_CFG_0_EF_DBG_JTAG_1_DIS_SHIFT (24)
#define EF_CFG_0_EF_DBG_JTAG_1_DIS_MASK (0x03 << EF_CFG_0_EF_DBG_JTAG_1_DIS_SHIFT)
#define EF_CFG_0_EF_EFUSE_DBG_DIS (1 << 23)
#define EF_CFG_0_EF_SE_DBG_DIS (1 << 22)
#define EF_CFG_0_EF_CPU_RST_DBG_DIS (1 << 21)
#define EF_CFG_0_EF_CPU1_DIS (1 << 20)
#define EF_CFG_0_EF_SF_DIS (1 << 19)
#define EF_CFG_0_EF_CAM_DIS (1 << 18)
#define EF_CFG_0_EF_0_KEY_ENC_EN (1 << 17)
#define EF_CFG_0_EF_WIFI_DIS (1 << 16)
#define EF_CFG_0_EF_BLE_DIS (1 << 15)
#define EF_CFG_0_EF_SDU_DIS (1 << 14)
#define EF_CFG_0_EF_SW_USAGE_1_SHIFT (12)
#define EF_CFG_0_EF_SW_USAGE_1_MASK (0x03 << EF_CFG_0_EF_SW_USAGE_1_SHIFT)
#define EF_CFG_0_EF_BOOT_SEL_SHIFT (8)
#define EF_CFG_0_EF_BOOT_SEL_MASK (0x0f << EF_CFG_0_EF_BOOT_SEL_SHIFT)
#define EF_CFG_0_EF_CPU0_ENC_EN (1 << 7)
#define EF_CFG_0_EF_CPU1_ENC_EN (1 << 6)
#define EF_CFG_0_EF_SBOOT_EN_SHIFT (4)
#define EF_CFG_0_EF_SBOOT_EN_MASK (0x03 << EF_CFG_0_EF_SBOOT_EN_SHIFT)
#define EF_CFG_0_EF_SBOOT_SIGN_MODE_SHIFT (2)
#define EF_CFG_0_EF_SBOOT_SIGN_MODE_MASK (0x03 << EF_CFG_0_EF_SBOOT_SIGN_MODE_SHIFT)
#define EF_CFG_0_EF_SF_AES_MODE_MASK (0x03)
#define EF_LOCK_RD_LOCK_KEY_SLOT_5 (1 << 31)
#define EF_LOCK_RD_LOCK_KEY_SLOT_4 (1 << 30)
#define EF_LOCK_RD_LOCK_KEY_SLOT_3 (1 << 29)
#define EF_LOCK_RD_LOCK_KEY_SLOT_2 (1 << 28)
#define EF_LOCK_RD_LOCK_KEY_SLOT_1 (1 << 27)
#define EF_LOCK_RD_LOCK_KEY_SLOT_0 (1 << 26)
#define EF_LOCK_RD_LOCK_DBG_PWD (1 << 25)
#define EF_LOCK_WR_LOCK_KEY_SLOT_5_H (1 << 24)
#define EF_LOCK_WR_LOCK_KEY_SLOT_4_H (1 << 23)
#define EF_LOCK_WR_LOCK_KEY_SLOT_3 (1 << 22)
#define EF_LOCK_WR_LOCK_KEY_SLOT_2 (1 << 21)
#define EF_LOCK_WR_LOCK_KEY_SLOT_1 (1 << 20)
#define EF_LOCK_WR_LOCK_KEY_SLOT_0 (1 << 19)
#define EF_LOCK_WR_LOCK_WIFI_MAC (1 << 18)
#define EF_LOCK_WR_LOCK_SW_USAGE_0 (1 << 17)
#define EF_LOCK_WR_LOCK_DBG_PWD (1 << 16)
#define EF_LOCK_WR_LOCK_BOOT_MODE (1 << 15)
#define EF_LOCK_WR_LOCK_KEY_SLOT_5_L (1 << 14)
#define EF_LOCK_WR_LOCK_KEY_SLOT_4_L (1 << 13)
#define EF_LOCK_EF_ANA_TRIM_1_MASK (0x1fff)
#define EF_DATA_1_REG_DATA_1_LOCK_RD_LOCK_KEY_SLOT_9 (1 << 29)
#define EF_DATA_1_REG_DATA_1_LOCK_RD_LOCK_KEY_SLOT_8 (1 << 28)
#define EF_DATA_1_REG_DATA_1_LOCK_RD_LOCK_KEY_SLOT_7 (1 << 27)
#define EF_DATA_1_REG_DATA_1_LOCK_RD_LOCK_KEY_SLOT_6 (1 << 26)
#define EF_DATA_1_REG_DATA_1_LOCK_WR_LOCK_KEY_SLOT_9 (1 << 13)
#define EF_DATA_1_REG_DATA_1_LOCK_WR_LOCK_KEY_SLOT_8 (1 << 12)
#define EF_DATA_1_REG_DATA_1_LOCK_WR_LOCK_KEY_SLOT_7 (1 << 11)
#define EF_DATA_1_REG_DATA_1_LOCK_WR_LOCK_KEY_SLOT_6 (1 << 10)
#define EF_IF_CTRL_0_EF_IF_PROT_CODE_CYC_SHIFT (24)
#define EF_IF_CTRL_0_EF_IF_PROT_CODE_CYC_MASK (0xff << EF_IF_CTRL_0_EF_IF_PROT_CODE_CYC_SHIFT)
#define EF_IF_CTRL_0_EF_IF_0_INT_SET (1 << 22)
#define EF_IF_CTRL_0_EF_IF_0_INT_CLR (1 << 21)
#define EF_IF_CTRL_0_EF_IF_0_INT (1 << 20)
#define EF_IF_CTRL_0_EF_IF_CYC_MODIFY_LOCK (1 << 19)
#define EF_IF_CTRL_0_EF_IF_AUTO_RD_EN (1 << 18)
#define EF_IF_CTRL_0_EF_CLK_SAHB_DATA_GATE (1 << 17)
#define EF_IF_CTRL_0_EF_IF_POR_DIG (1 << 16)
#define EF_IF_CTRL_0_EF_IF_PROT_CODE_CTRL_SHIFT (8)
#define EF_IF_CTRL_0_EF_IF_PROT_CODE_CTRL_MASK (0xff << EF_IF_CTRL_0_EF_IF_PROT_CODE_CTRL_SHIFT)
#define EF_IF_CTRL_0_EF_CLK_SAHB_DATA_SEL (1 << 7)
#define EF_IF_CTRL_0_EF_IF_0_CYC_MODIFY (1 << 6)
#define EF_IF_CTRL_0_EF_IF_0_MANUAL_EN (1 << 5)
#define EF_IF_CTRL_0_EF_IF_0_TRIG (1 << 4)
#define EF_IF_CTRL_0_EF_IF_0_RW (1 << 3)
#define EF_IF_CTRL_0_EF_IF_0_BUSY (1 << 2)
#define EF_IF_CTRL_0_EF_IF_0_AUTOLOAD_DONE (1 << 1)
#define EF_IF_CTRL_0_EF_IF_0_AUTOLOAD_P1_DONE (1 << 0)
#define EF_IF_CYC_0_EF_IF_CYC_PD_CS_S_SHIFT (24)
#define EF_IF_CYC_0_EF_IF_CYC_PD_CS_S_MASK (0xff << EF_IF_CYC_0_EF_IF_CYC_PD_CS_S_SHIFT)
#define EF_IF_CYC_0_EF_IF_CYC_CS_SHIFT (18)
#define EF_IF_CYC_0_EF_IF_CYC_CS_MASK (0x3f << EF_IF_CYC_0_EF_IF_CYC_CS_SHIFT)
#define EF_IF_CYC_0_EF_IF_CYC_RD_ADR_SHIFT (12)
#define EF_IF_CYC_0_EF_IF_CYC_RD_ADR_MASK (0x3f << EF_IF_CYC_0_EF_IF_CYC_RD_ADR_SHIFT)
#define EF_IF_CYC_0_EF_IF_CYC_RD_DAT_SHIFT (6)
#define EF_IF_CYC_0_EF_IF_CYC_RD_DAT_MASK (0x3f << EF_IF_CYC_0_EF_IF_CYC_RD_DAT_SHIFT)
#define EF_IF_CYC_0_EF_IF_CYC_RD_DMY_MASK (0x3f)
#define EF_IF_CYC_1_EF_IF_CYC_PD_CS_H_SHIFT (26)
#define EF_IF_CYC_1_EF_IF_CYC_PD_CS_H_MASK (0x3f << EF_IF_CYC_1_EF_IF_CYC_PD_CS_H_SHIFT)
#define EF_IF_CYC_1_EF_IF_CYC_PS_CS_SHIFT (20)
#define EF_IF_CYC_1_EF_IF_CYC_PS_CS_MASK (0x3f << EF_IF_CYC_1_EF_IF_CYC_PS_CS_SHIFT)
#define EF_IF_CYC_1_EF_IF_CYC_WR_ADR_SHIFT (14)
#define EF_IF_CYC_1_EF_IF_CYC_WR_ADR_MASK (0x3f << EF_IF_CYC_1_EF_IF_CYC_WR_ADR_SHIFT)
#define EF_IF_CYC_1_EF_IF_CYC_PP_SHIFT (6)
#define EF_IF_CYC_1_EF_IF_CYC_PP_MASK (0xff << EF_IF_CYC_1_EF_IF_CYC_PP_SHIFT)
#define EF_IF_CYC_1_EF_IF_CYC_PI_MASK (0x3f)
#define EF_IF_0_MANUAL_EF_IF_PROT_CODE_MANUAL_SHIFT (24)
#define EF_IF_0_MANUAL_EF_IF_PROT_CODE_MANUAL_MASK (0xff << EF_IF_0_MANUAL_EF_IF_PROT_CODE_MANUAL_SHIFT)
#define EF_IF_0_MANUAL_EF_IF_0_Q_SHIFT (16)
#define EF_IF_0_MANUAL_EF_IF_0_Q_MASK (0xff << EF_IF_0_MANUAL_EF_IF_0_Q_SHIFT)
#define EF_IF_0_MANUAL_EF_IF_CSB (1 << 15)
#define EF_IF_0_MANUAL_EF_IF_LOAD (1 << 14)
#define EF_IF_0_MANUAL_EF_IF_PGENB (1 << 13)
#define EF_IF_0_MANUAL_EF_IF_STROBE (1 << 12)
#define EF_IF_0_MANUAL_EF_IF_PS (1 << 11)
#define EF_IF_0_MANUAL_EF_IF_PD (1 << 10)
#define EF_IF_0_MANUAL_EF_IF_A_MASK (0x3ff)
#define EF_IF_CFG_0_EF_IF_DBG_MODE_SHIFT (28)
#define EF_IF_CFG_0_EF_IF_DBG_MODE_MASK (0x0f << EF_IF_CFG_0_EF_IF_DBG_MODE_SHIFT)
#define EF_IF_CFG_0_EF_IF_DBG_JTAG_0_DIS_SHIFT (26)
#define EF_IF_CFG_0_EF_IF_DBG_JTAG_0_DIS_MASK (0x03 << EF_IF_CFG_0_EF_IF_DBG_JTAG_0_DIS_SHIFT)
#define EF_IF_CFG_0_EF_IF_DBG_JTAG_1_DIS_SHIFT (24)
#define EF_IF_CFG_0_EF_IF_DBG_JTAG_1_DIS_MASK (0x03 << EF_IF_CFG_0_EF_IF_DBG_JTAG_1_DIS_SHIFT)
#define EF_IF_CFG_0_EF_IF_EFUSE_DBG_DIS (1 << 23)
#define EF_IF_CFG_0_EF_IF_SE_DBG_DIS (1 << 22)
#define EF_IF_CFG_0_EF_IF_CPU_RST_DBG_DIS (1 << 21)
#define EF_IF_CFG_0_EF_IF_CPU1_DIS (1 << 20)
#define EF_IF_CFG_0_EF_IF_SF_DIS (1 << 19)
#define EF_IF_CFG_0_EF_IF_CAM_DIS (1 << 18)
#define EF_IF_CFG_0_EF_IF_0_KEY_ENC_EN (1 << 17)
#define EF_IF_CFG_0_EF_IF_WIFI_DIS (1 << 16)
#define EF_IF_CFG_0_EF_IF_BLE_DIS (1 << 15)
#define EF_IF_CFG_0_EF_IF_SDU_DIS (1 << 14)
#define EF_IF_CFG_0_EF_IF_SW_USAGE_1_SHIFT (12)
#define EF_IF_CFG_0_EF_IF_SW_USAGE_1_MASK (0x03 << EF_IF_CFG_0_EF_IF_SW_USAGE_1_SHIFT)
#define EF_IF_CFG_0_EF_IF_BOOT_SEL_SHIFT (8)
#define EF_IF_CFG_0_EF_IF_BOOT_SEL_MASK (0x0f << EF_IF_CFG_0_EF_IF_BOOT_SEL_SHIFT)
#define EF_IF_CFG_0_EF_IF_CPU0_ENC_EN (1 << 7)
#define EF_IF_CFG_0_EF_IF_CPU1_ENC_EN (1 << 6)
#define EF_IF_CFG_0_EF_IF_SBOOT_EN_SHIFT (4)
#define EF_IF_CFG_0_EF_IF_SBOOT_EN_MASK (0x03 << EF_IF_CFG_0_EF_IF_SBOOT_EN_SHIFT)
#define EF_IF_CFG_0_EF_IF_SBOOT_SIGN_MODE_SHIFT (2)
#define EF_IF_CFG_0_EF_IF_SBOOT_SIGN_MODE_MASK (0x03 << EF_IF_CFG_0_EF_IF_SBOOT_SIGN_MODE_SHIFT)
#define EF_IF_CFG_0_EF_IF_SF_AES_MODE_MASK (0x03)
#define EF_SW_CFG_0_EF_SW_DBG_MODE_SHIFT (28)
#define EF_SW_CFG_0_EF_SW_DBG_MODE_MASK (0x0f << EF_SW_CFG_0_EF_SW_DBG_MODE_SHIFT)
#define EF_SW_CFG_0_EF_SW_DBG_JTAG_0_DIS_SHIFT (26)
#define EF_SW_CFG_0_EF_SW_DBG_JTAG_0_DIS_MASK (0x03 << EF_SW_CFG_0_EF_SW_DBG_JTAG_0_DIS_SHIFT)
#define EF_SW_CFG_0_EF_SW_DBG_JTAG_1_DIS_SHIFT (24)
#define EF_SW_CFG_0_EF_SW_DBG_JTAG_1_DIS_MASK (0x03 << EF_SW_CFG_0_EF_SW_DBG_JTAG_1_DIS_SHIFT)
#define EF_SW_CFG_0_EF_SW_EFUSE_DBG_DIS (1 << 23)
#define EF_SW_CFG_0_EF_SW_SE_DBG_DIS (1 << 22)
#define EF_SW_CFG_0_EF_SW_CPU_RST_DBG_DIS (1 << 21)
#define EF_SW_CFG_0_EF_SW_CPU1_DIS (1 << 20)
#define EF_SW_CFG_0_EF_SW_SF_DIS (1 << 19)
#define EF_SW_CFG_0_EF_SW_CAM_DIS (1 << 18)
#define EF_SW_CFG_0_EF_SW_0_KEY_ENC_EN (1 << 17)
#define EF_SW_CFG_0_EF_SW_WIFI_DIS (1 << 16)
#define EF_SW_CFG_0_EF_SW_BLE_DIS (1 << 15)
#define EF_SW_CFG_0_EF_SW_SDU_DIS (1 << 14)
#define EF_SW_CFG_0_EF_SW_SW_USAGE_1_SHIFT (12)
#define EF_SW_CFG_0_EF_SW_SW_USAGE_1_MASK (0x03 << EF_SW_CFG_0_EF_SW_SW_USAGE_1_SHIFT)
#define EF_SW_CFG_0_EF_SW_CPU0_ENC_EN (1 << 7)
#define EF_SW_CFG_0_EF_SW_CPU1_ENC_EN (1 << 6)
#define EF_SW_CFG_0_EF_SW_SBOOT_EN_SHIFT (4)
#define EF_SW_CFG_0_EF_SW_SBOOT_EN_MASK (0x03 << EF_SW_CFG_0_EF_SW_SBOOT_EN_SHIFT)
#define EF_SW_CFG_0_EF_SW_SBOOT_SIGN_MODE_SHIFT (2)
#define EF_SW_CFG_0_EF_SW_SBOOT_SIGN_MODE_MASK (0x03 << EF_SW_CFG_0_EF_SW_SBOOT_SIGN_MODE_SHIFT)
#define EF_SW_CFG_0_EF_SW_SF_AES_MODE_MASK (0x03)
#define EF_CRC_CTRL_0_EF_CRC_SLP_N_SHIFT (16)
#define EF_CRC_CTRL_0_EF_CRC_SLP_N_MASK (0xffff << EF_CRC_CTRL_0_EF_CRC_SLP_N_SHIFT)
#define EF_CRC_CTRL_0_EF_CRC_LOCK (1 << 11)
#define EF_CRC_CTRL_0_EF_CRC_INT_SET (1 << 10)
#define EF_CRC_CTRL_0_EF_CRC_INT_CLR (1 << 9)
#define EF_CRC_CTRL_0_EF_CRC_INT (1 << 8)
#define EF_CRC_CTRL_0_EF_CRC_DIN_ENDIAN (1 << 7)
#define EF_CRC_CTRL_0_EF_CRC_DOUT_ENDIAN (1 << 6)
#define EF_CRC_CTRL_0_EF_CRC_DOUT_INV_EN (1 << 5)
#define EF_CRC_CTRL_0_EF_CRC_ERROR (1 << 4)
#define EF_CRC_CTRL_0_EF_CRC_MODE (1 << 3)
#define EF_CRC_CTRL_0_EF_CRC_EN (1 << 2)
#define EF_CRC_CTRL_0_EF_CRC_TRIG (1 << 1)
#define EF_CRC_CTRL_0_EF_CRC_BUSY (1 << 0)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_EF_H */

File diff suppressed because it is too large Load Diff

View File

@ -1,501 +0,0 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_gpio.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_GPIO_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_GPIO_H
/****************************************************************************
* Included Files
****************************************************************************/
#include "hardware/bl602_common.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Input Floating Mode */
#define GPIO_MODE_INPUT (0x00000000)
/* Output Push Pull Mode */
#define GPIO_MODE_OUTPUT (0x00000001)
/* Alternate function */
#define GPIO_MODE_AF (0x00000002)
/* GPIO pull up */
#define GPIO_PULL_UP (0x00000000)
/* GPIO pull down */
#define GPIO_PULL_DOWN (0x00000001)
/* GPIO no pull up or down */
#define GPIO_PULL_NONE (0x00000002)
/* GPIO0 function definition */
#define GPIO0_FUN_SDIO_CLK 1
#define GPIO0_FUN_SF_D1 2
#define GPIO0_FUN_UNUSED3 3
#define GPIO0_FUN_SPI_MISO_SPI_MOSI 4
#define GPIO0_FUN_UNUSED5 5
#define GPIO0_FUN_I2C_SCL 6
#define GPIO0_FUN_UART_SIG0 7
#define GPIO0_FUN_PWM_CH0 8
#define GPIO0_FUN_FEM_GPIO_0 9
#define GPIO0_FUN_ATEST_IN 10
#define GPIO0_FUN_SWGPIO_0 11
#define GPIO0_FUN_E21_TMS 14
/* GPIO1 function definition */
#define GPIO1_FUN_SDIO_CMD 1
#define GPIO1_FUN_SF_D2 2
#define GPIO1_FUN_UNUSED3 3
#define GPIO1_FUN_SPI_MOSI_SPI_MISO 4
#define GPIO1_FUN_UNUSED5 5
#define GPIO1_FUN_I2C_SDA 6
#define GPIO1_FUN_UART_SIG1 7
#define GPIO1_FUN_PWM_CH1 8
#define GPIO1_FUN_FEM_GPIO_1 9
#define GPIO1_FUN_ATEST_IP 10
#define GPIO1_FUN_SWGPIO_1 11
#define GPIO1_FUN_E21_TDI 14
/* GPIO2 function definition */
#define GPIO2_FUN_SDIO_DAT0 1
#define GPIO2_FUN_SF_D3 2
#define GPIO2_FUN_UNUSED3 3
#define GPIO2_FUN_SPI_SS 4
#define GPIO2_FUN_UNUSED5 5
#define GPIO2_FUN_I2C_SCL 6
#define GPIO2_FUN_UART_SIG2 7
#define GPIO2_FUN_PWM_CH2 8
#define GPIO2_FUN_FEM_GPIO_2 9
#define GPIO2_FUN_ATEST_QN 10
#define GPIO2_FUN_SWGPIO_2 11
#define GPIO2_FUN_E21_TCK 14
/* GPIO3 function definition */
#define GPIO3_FUN_SDIO_DAT1 1
#define GPIO3_FUN_UNUSED2 2
#define GPIO3_FUN_UNUSED3 3
#define GPIO3_FUN_SPI_SCLK 4
#define GPIO3_FUN_UNUSED5 5
#define GPIO3_FUN_I2C_SDA 6
#define GPIO3_FUN_UART_SIG3 7
#define GPIO3_FUN_PWM_CH3 8
#define GPIO3_FUN_FEM_GPIO_3 9
#define GPIO3_FUN_ATEST_QP 10
#define GPIO3_FUN_SWGPIO_3 11
#define GPIO3_FUN_E21_TDO 14
/* GPIO4 function definition */
#define GPIO4_FUN_SDIO_DAT2 1
#define GPIO4_FUN_UNUSED2 2
#define GPIO4_FUN_UNUSED3 3
#define GPIO4_FUN_SPI_MISO_SPI_MOSI 4
#define GPIO4_FUN_UNUSED5 5
#define GPIO4_FUN_I2C_SCL 6
#define GPIO4_FUN_UART_SIG4 7
#define GPIO4_FUN_PWM_CH4 8
#define GPIO4_FUN_FEM_GPIO_0 9
#define GPIO4_FUN_GPIP_CH1 10
#define GPIO4_FUN_SWGPIO_4 11
#define GPIO4_FUN_E21_TMS 14
/* GPIO5 function definition */
#define GPIO5_FUN_SDIO_DAT3 1
#define GPIO5_FUN_UNUSED2 2
#define GPIO5_FUN_UNUSED3 3
#define GPIO5_FUN_SPI_MOSI_SPI_MISO 4
#define GPIO5_FUN_UNUSED5 5
#define GPIO5_FUN_I2C_SDA 6
#define GPIO5_FUN_UART_SIG5 7
#define GPIO5_FUN_PWM_CH0 8
#define GPIO5_FUN_FEM_GPIO_1 9
#define GPIO5_FUN_GPIP_CH4 10
#define GPIO5_FUN_SWGPIO_5 11
#define GPIO5_FUN_E21_TDI 14
/* GPIO6 function definition */
#define GPIO6_FUN_UNUSED1 1
#define GPIO6_FUN_UNUSED2 2
#define GPIO6_FUN_UNUSED3 3
#define GPIO6_FUN_SPI_SS 4
#define GPIO6_FUN_UNUSED5 5
#define GPIO6_FUN_I2C_SCL 6
#define GPIO6_FUN_UART_SIG6 7
#define GPIO6_FUN_PWM_CH1 8
#define GPIO6_FUN_FEM_GPIO_2 9
#define GPIO6_FUN_GPIP_CH5 10
#define GPIO6_FUN_SWGPIO_6 11
#define GPIO6_FUN_E21_TCK 14
/* GPIO7 function definition */
#define GPIO7_FUN_UNUSED1 1
#define GPIO7_FUN_UNUSED2 2
#define GPIO7_FUN_UNUSED3 3
#define GPIO7_FUN_SPI_SCLK 4
#define GPIO7_FUN_UNUSED5 5
#define GPIO7_FUN_I2C_SDA 6
#define GPIO7_FUN_UART_SIG7 7
#define GPIO7_FUN_PWM_CH2 8
#define GPIO7_FUN_FEM_GPIO_3 9
#define GPIO7_FUN_UNUSED10 10
#define GPIO7_FUN_SWGPIO_7 11
#define GPIO7_FUN_E21_TDO 14
/* GPIO8 function definition */
#define GPIO8_FUN_UNUSED1 1
#define GPIO8_FUN_UNUSED2 2
#define GPIO8_FUN_UNUSED3 3
#define GPIO8_FUN_SPI_MISO_SPI_MOSI 4
#define GPIO8_FUN_UNUSED5 5
#define GPIO8_FUN_I2C_SCL 6
#define GPIO8_FUN_UART_SIG0 7
#define GPIO8_FUN_PWM_CH3 8
#define GPIO8_FUN_FEM_GPIO_0 9
#define GPIO8_FUN_UNUSED10 10
#define GPIO8_FUN_SWGPIO_8 11
#define GPIO8_FUN_E21_TMS 14
/* GPIO9 function definition */
#define GPIO9_FUN_UNUSED1 1
#define GPIO9_FUN_UNUSED2 2
#define GPIO9_FUN_UNUSED3 3
#define GPIO9_FUN_SPI_MOSI_SPI_MISO 4
#define GPIO9_FUN_UNUSED5 5
#define GPIO9_FUN_I2C_SDA 6
#define GPIO9_FUN_UART_SIG1 7
#define GPIO9_FUN_PWM_CH4 8
#define GPIO9_FUN_FEM_GPIO_1 9
#define GPIO9_FUN_GPIP_CH6_GPIP_CH7 10
#define GPIO9_FUN_SWGPIO_9 11
#define GPIO9_FUN_E21_TDI 14
/* GPIO10 function definition */
#define GPIO10_FUN_UNUSED1 1
#define GPIO10_FUN_UNUSED2 2
#define GPIO10_FUN_UNUSED3 3
#define GPIO10_FUN_SPI_SS 4
#define GPIO10_FUN_UNUSED5 5
#define GPIO10_FUN_I2C_SCL 6
#define GPIO10_FUN_UART_SIG2 7
#define GPIO10_FUN_PWM_CH0 8
#define GPIO10_FUN_FEM_GPIO_2 9
#define GPIO10_FUN_MICBIAS_GPIP_CH8_GPIP_CH9 10
#define GPIO10_FUN_SWGPIO_10 11
#define GPIO10_FUN_E21_TCK 14
/* GPIO11 function definition */
#define GPIO11_FUN_UNUSED1 1
#define GPIO11_FUN_UNUSED2 2
#define GPIO11_FUN_UNUSED3 3
#define GPIO11_FUN_SPI_SCLK 4
#define GPIO11_FUN_UNUSED5 5
#define GPIO11_FUN_I2C_SDA 6
#define GPIO11_FUN_UART_SIG3 7
#define GPIO11_FUN_PWM_CH1 8
#define GPIO11_FUN_FEM_GPIO_3 9
#define GPIO11_FUN_IRLED_OUT_GPIP_CH10 10
#define GPIO11_FUN_SWGPIO_11 11
#define GPIO11_FUN_E21_TDO 14
/* GPIO12 function definition */
#define GPIO12_FUN_UNUSED1 1
#define GPIO12_FUN_UNUSED2 2
#define GPIO12_FUN_UNUSED3 3
#define GPIO12_FUN_SPI_MISO_SPI_MOSI 4
#define GPIO12_FUN_UNUSED5 5
#define GPIO12_FUN_I2C_SCL 6
#define GPIO12_FUN_UART_SIG4 7
#define GPIO12_FUN_PWM_CH2 8
#define GPIO12_FUN_FEM_GPIO_0 9
#define GPIO12_FUN_GPIP_CH0_GPADC_VREF_EXT 10
#define GPIO12_FUN_SWGPIO_12 11
#define GPIO12_FUN_E21_TMS 14
/* GPIO13 function definition */
#define GPIO13_FUN_UNUSED1 1
#define GPIO13_FUN_UNUSED2 2
#define GPIO13_FUN_UNUSED3 3
#define GPIO13_FUN_SPI_MOSI_SPI_MISO 4
#define GPIO13_FUN_UNUSED5 5
#define GPIO13_FUN_I2C_SDA 6
#define GPIO13_FUN_UART_SIG5 7
#define GPIO13_FUN_PWM_CH3 8
#define GPIO13_FUN_FEM_GPIO_1 9
#define GPIO13_FUN_GPIP_CH3 10
#define GPIO13_FUN_SWGPIO_13 11
#define GPIO13_FUN_E21_TDI 14
/* GPIO14 function definition */
#define GPIO14_FUN_UNUSED1 1
#define GPIO14_FUN_UNUSED2 2
#define GPIO14_FUN_UNUSED3 3
#define GPIO14_FUN_SPI_SS 4
#define GPIO14_FUN_UNUSED5 5
#define GPIO14_FUN_I2C_SCL 6
#define GPIO14_FUN_UART_SIG6 7
#define GPIO14_FUN_PWM_CH4 8
#define GPIO14_FUN_FEM_GPIO_2 9
#define GPIO14_FUN_GPIP_CH2 10
#define GPIO14_FUN_SWGPIO_14 11
#define GPIO14_FUN_E21_TCK 14
/* GPIO15 function definition */
#define GPIO15_FUN_UNUSED1 1
#define GPIO15_FUN_UNUSED2 2
#define GPIO15_FUN_UNUSED3 3
#define GPIO15_FUN_SPI_SCLK 4
#define GPIO15_FUN_UNUSED5 5
#define GPIO15_FUN_I2C_SDA 6
#define GPIO15_FUN_UART_SIG7 7
#define GPIO15_FUN_PWM_CH0 8
#define GPIO15_FUN_FEM_GPIO_3 9
#define GPIO15_FUN_PSW_IRRCV_OUT_GPIP_CH11 10
#define GPIO15_FUN_SWGPIO_15 11
#define GPIO15_FUN_E21_TDO 14
/* GPIO16 function definition */
#define GPIO16_FUN_UNUSED1 1
#define GPIO16_FUN_UNUSED2 2
#define GPIO16_FUN_UNUSED3 3
#define GPIO16_FUN_SPI_MISO_SPI_MOSI 4
#define GPIO16_FUN_UNUSED5 5
#define GPIO16_FUN_I2C_SCL 6
#define GPIO16_FUN_UART_SIG0 7
#define GPIO16_FUN_PWM_CH1 8
#define GPIO16_FUN_FEM_GPIO_0 9
#define GPIO16_FUN_UNUSED10 10
#define GPIO16_FUN_SWGPIO_16 11
#define GPIO16_FUN_E21_TMS 14
/* GPIO17 function definition */
#define GPIO17_FUN_UNUSED1 1
#define GPIO17_FUN_SF_D3 2
#define GPIO17_FUN_UNUSED3 3
#define GPIO17_FUN_SPI_MOSI_SPI_MISO 4
#define GPIO17_FUN_UNUSED5 5
#define GPIO17_FUN_I2C_SDA 6
#define GPIO17_FUN_UART_SIG1 7
#define GPIO17_FUN_PWM_CH2 8
#define GPIO17_FUN_FEM_GPIO_1 9
#define GPIO17_FUN_PMIP_DC_TP_OUT 10
#define GPIO17_FUN_SWGPIO_17 11
#define GPIO17_FUN_E21_TDI 14
/* GPIO18 function definition */
#define GPIO18_FUN_UNUSED1 1
#define GPIO18_FUN_SF_D2 2
#define GPIO18_FUN_UNUSED3 3
#define GPIO18_FUN_SPI_SS 4
#define GPIO18_FUN_UNUSED5 5
#define GPIO18_FUN_I2C_SCL 6
#define GPIO18_FUN_UART_SIG2 7
#define GPIO18_FUN_PWM_CH3 8
#define GPIO18_FUN_FEM_GPIO_2 9
#define GPIO18_FUN_UNUSED10 10
#define GPIO18_FUN_SWGPIO_18 11
#define GPIO18_FUN_E21_TCK 14
/* GPIO19 function definition */
#define GPIO19_FUN_UNUSED1 1
#define GPIO19_FUN_SF_D1 2
#define GPIO19_FUN_UNUSED3 3
#define GPIO19_FUN_SPI_SCLK 4
#define GPIO19_FUN_UNUSED5 5
#define GPIO19_FUN_I2C_SDA 6
#define GPIO19_FUN_UART_SIG3 7
#define GPIO19_FUN_PWM_CH4 8
#define GPIO19_FUN_FEM_GPIO_3 9
#define GPIO19_FUN_UNUSED10 10
#define GPIO19_FUN_SWGPIO_19 11
#define GPIO19_FUN_E21_TDO 14
/* GPIO20 function definition */
#define GPIO20_FUN_UNUSED1 1
#define GPIO20_FUN_SF_D0 2
#define GPIO20_FUN_UNUSED3 3
#define GPIO20_FUN_SPI_MISO_SPI_MOSI 4
#define GPIO20_FUN_UNUSED5 5
#define GPIO20_FUN_I2C_SCL 6
#define GPIO20_FUN_UART_SIG4 7
#define GPIO20_FUN_PWM_CH0 8
#define GPIO20_FUN_FEM_GPIO_0 9
#define GPIO20_FUN_UNUSED10 10
#define GPIO20_FUN_SWGPIO_20 11
#define GPIO20_FUN_E21_TMS 14
/* GPIO21 function definition */
#define GPIO21_FUN_UNUSED1 1
#define GPIO21_FUN_SF_CS 2
#define GPIO21_FUN_UNUSED3 3
#define GPIO21_FUN_SPI_MOSI_SPI_MISO 4
#define GPIO21_FUN_UNUSED5 5
#define GPIO21_FUN_I2C_SDA 6
#define GPIO21_FUN_UART_SIG5 7
#define GPIO21_FUN_PWM_CH1 8
#define GPIO21_FUN_FEM_GPIO_1 9
#define GPIO21_FUN_UNUSED10 10
#define GPIO21_FUN_SWGPIO_21 11
#define GPIO21_FUN_E21_TDI 14
/* GPIO22 function definition */
#define GPIO22_FUN_UNUSED1 1
#define GPIO22_FUN_SF_CLK_OUT 2
#define GPIO22_FUN_UNUSED3 3
#define GPIO22_FUN_SPI_SS 4
#define GPIO22_FUN_UNUSED5 5
#define GPIO22_FUN_I2C_SCL 6
#define GPIO22_FUN_UART_SIG6 7
#define GPIO22_FUN_PWM_CH2 8
#define GPIO22_FUN_FEM_GPIO_2 9
#define GPIO22_FUN_UNUSED10 10
#define GPIO22_FUN_SWGPIO_22 11
#define GPIO22_FUN_E21_TCK 14
/****************************************************************************
* Public Types
****************************************************************************/
#ifndef __ASSEMBLY__
#define GLB_GPIO_PIN_0 0
#define GLB_GPIO_PIN_1 1
#define GLB_GPIO_PIN_2 2
#define GLB_GPIO_PIN_3 3
#define GLB_GPIO_PIN_4 4
#define GLB_GPIO_PIN_5 5
#define GLB_GPIO_PIN_6 6
#define GLB_GPIO_PIN_7 7
#define GLB_GPIO_PIN_8 8
#define GLB_GPIO_PIN_9 9
#define GLB_GPIO_PIN_10 10
#define GLB_GPIO_PIN_11 11
#define GLB_GPIO_PIN_12 12
#define GLB_GPIO_PIN_13 13
#define GLB_GPIO_PIN_14 14
#define GLB_GPIO_PIN_15 15
#define GLB_GPIO_PIN_16 16
#define GLB_GPIO_PIN_17 17
#define GLB_GPIO_PIN_18 18
#define GLB_GPIO_PIN_19 19
#define GLB_GPIO_PIN_20 20
#define GLB_GPIO_PIN_21 21
#define GLB_GPIO_PIN_22 22
#define GLB_GPIO_PIN_MA 23
#define GPIO_FUN_SDIO 1
#define GPIO_FUN_FLASH 2
#define GPIO_FUN_SPI 4
#define GPIO_FUN_I2C 6
#define GPIO_FUN_UART 7
#define GPIO_FUN_PWM 8
#define GPIO_FUN_EXT_PA 8
#define GPIO_FUN_ANALOG 10
#define GPIO_FUN_SWGPIO 11
#define GPIO_FUN_JTAG 14
struct gpio_cfg_s
{
int gpio_pin;
int gpio_fun;
int gpio_mode;
int pull_type;
int drive;
int smt_ctrl;
};
/****************************************************************************
* Public Data
****************************************************************************/
#ifdef __cplusplus
#define EXTERN extern "C"
extern "C"
{
#else
#define EXTERN extern
#endif
/****************************************************************************
* Inline Functions
****************************************************************************/
/****************************************************************************
* Public Function Prototypes
****************************************************************************/
/****************************************************************************
* Name: bl602_gpio_init
*
* Description:
* Init a gpio pin.
*
* Input Parameters:
* cfg: gpio configuration
*
* Returned Value:
* Description of the value returned by this function (if any),
* including an enumeration of all possible error values.
*
* Assumptions/Limitations:
* Anything else that one might need to know to use this function.
*
****************************************************************************/
EXTERN void bl602_gpio_init(struct gpio_cfg_s *cfg);
#undef EXTERN
#ifdef __cplusplus
}
#endif
#endif /* __ASSEMBLY__ */
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_GPIO_H */

View File

@ -0,0 +1,105 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_gpip.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_GPIP_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_GPIP_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_GPADC_CONFIG_OFFSET 0x000000 /* gpadc_config */
#define BL602_GPADC_DMA_RDATA_OFFSET 0x000004 /* gpadc_dma_rdata */
#define BL602_GPDAC_CONFIG_OFFSET 0x000040 /* gpdac_config */
#define BL602_GPDAC_DMA_CONFIG_OFFSET 0x000044 /* gpdac_dma_config */
#define BL602_GPDAC_DMA_WDATA_OFFSET 0x000048 /* gpdac_dma_wdata */
#define BL602_GPDAC_TX_FIFO_STATUS_OFFSET 0x00004c /* gpdac_tx_fifo_status */
/* Register definitions *****************************************************/
#define BL602_GPADC_CONFIG (BL602_GPIP_BASE + BL602_GPADC_CONFIG_OFFSET)
#define BL602_GPADC_DMA_RDATA (BL602_GPIP_BASE + BL602_GPADC_DMA_RDATA_OFFSET)
#define BL602_GPDAC_CONFIG (BL602_GPIP_BASE + BL602_GPDAC_CONFIG_OFFSET)
#define BL602_GPDAC_DMA_CONFIG (BL602_GPIP_BASE + BL602_GPDAC_DMA_CONFIG_OFFSET)
#define BL602_GPDAC_DMA_WDATA (BL602_GPIP_BASE + BL602_GPDAC_DMA_WDATA_OFFSET)
#define BL602_GPDAC_TX_FIFO_STATUS (BL602_GPIP_BASE + BL602_GPDAC_TX_FIFO_STATUS_OFFSET)
/* Register bit definitions *************************************************/
#define GPADC_CONFIG_RSVD_31_24_SHIFT (24)
#define GPADC_CONFIG_RSVD_31_24_MASK (0xff << GPADC_CONFIG_RSVD_31_24_SHIFT)
#define GPADC_CONFIG_GPADC_FIFO_THL_SHIFT (22)
#define GPADC_CONFIG_GPADC_FIFO_THL_MASK (0x03 << GPADC_CONFIG_GPADC_FIFO_THL_SHIFT)
#define GPADC_CONFIG_GPADC_FIFO_DATA_COUNT_SHIFT (16)
#define GPADC_CONFIG_GPADC_FIFO_DATA_COUNT_MASK (0x3f << GPADC_CONFIG_GPADC_FIFO_DATA_COUNT_SHIFT)
#define GPADC_CONFIG_GPADC_FIFO_UNDERRUN_MASK (1 << 14)
#define GPADC_CONFIG_GPADC_FIFO_OVERRUN_MASK (1 << 13)
#define GPADC_CONFIG_GPADC_RDY_MASK (1 << 12)
#define GPADC_CONFIG_GPADC_FIFO_UNDERRUN_CLR (1 << 10)
#define GPADC_CONFIG_GPADC_FIFO_OVERRUN_CLR (1 << 9)
#define GPADC_CONFIG_GPADC_RDY_CLR (1 << 8)
#define GPADC_CONFIG_GPADC_FIFO_UNDERRUN (1 << 6)
#define GPADC_CONFIG_GPADC_FIFO_OVERRUN (1 << 5)
#define GPADC_CONFIG_GPADC_RDY (1 << 4)
#define GPADC_CONFIG_GPADC_FIFO_FULL (1 << 3)
#define GPADC_CONFIG_GPADC_FIFO_NE (1 << 2)
#define GPADC_CONFIG_GPADC_FIFO_CLR (1 << 1)
#define GPADC_CONFIG_GPADC_DMA_EN (1 << 0)
#define GPADC_DMA_RDATA_RSVD_31_26_SHIFT (26)
#define GPADC_DMA_RDATA_RSVD_31_26_MASK (0x3f << GPADC_DMA_RDATA_RSVD_31_26_SHIFT)
#define GPADC_DMA_RDATA_MASK (0x3ffffff)
#define GPDAC_CONFIG_RSVD_31_24_SHIFT (24)
#define GPDAC_CONFIG_RSVD_31_24_MASK (0xff << GPDAC_CONFIG_RSVD_31_24_SHIFT)
#define GPDAC_CONFIG_GPDAC_CH_B_SEL_SHIFT (20)
#define GPDAC_CONFIG_GPDAC_CH_B_SEL_MASK (0x0f << GPDAC_CONFIG_GPDAC_CH_B_SEL_SHIFT)
#define GPDAC_CONFIG_GPDAC_CH_A_SEL_SHIFT (16)
#define GPDAC_CONFIG_GPDAC_CH_A_SEL_MASK (0x0f << GPDAC_CONFIG_GPDAC_CH_A_SEL_SHIFT)
#define GPDAC_CONFIG_GPDAC_MODE_SHIFT (8)
#define GPDAC_CONFIG_GPDAC_MODE_MASK (0x07 << GPDAC_CONFIG_GPDAC_MODE_SHIFT)
#define GPDAC_CONFIG_DSM_MODE_SHIFT (4)
#define GPDAC_CONFIG_DSM_MODE_MASK (0x03 << GPDAC_CONFIG_DSM_MODE_SHIFT)
#define GPDAC_CONFIG_GPDAC_EN2 (1 << 1)
#define GPDAC_CONFIG_GPDAC_EN (1 << 0)
#define GPDAC_DMA_CONFIG_GPDAC_DMA_FORMAT_SHIFT (4)
#define GPDAC_DMA_CONFIG_GPDAC_DMA_FORMAT_MASK (0x03 << GPDAC_DMA_CONFIG_GPDAC_DMA_FORMAT_SHIFT)
#define GPDAC_DMA_CONFIG_GPDAC_DMA_TX_EN (1 << 0)
#define GPDAC_TX_FIFO_STATUS_TXFIFOWRPTR_SHIFT (8)
#define GPDAC_TX_FIFO_STATUS_TXFIFOWRPTR_MASK (0x03 << GPDAC_TX_FIFO_STATUS_TXFIFOWRPTR_SHIFT)
#define GPDAC_TX_FIFO_STATUS_TXFIFORDPTR_SHIFT (4)
#define GPDAC_TX_FIFO_STATUS_TXFIFORDPTR_MASK (0x07 << GPDAC_TX_FIFO_STATUS_TXFIFORDPTR_SHIFT)
#define GPDAC_TX_FIFO_STATUS_TX_CS_SHIFT (2)
#define GPDAC_TX_FIFO_STATUS_TX_CS_MASK (0x03 << GPDAC_TX_FIFO_STATUS_TX_CS_SHIFT)
#define GPDAC_TX_FIFO_STATUS_TX_FIFO_FULL (1 << 1)
#define GPDAC_TX_FIFO_STATUS_TX_FIFO_EMPTY (1 << 0)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_GPIP_H */

View File

@ -25,660 +25,161 @@
* Included Files
****************************************************************************/
#include "hardware/bl602_common.h"
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* 0x0 : HBN_CTL */
/* Register offsets *********************************************************/
#define HBN_CTL_OFFSET (0x0)
#define HBN_RTC_CTL HBN_RTC_CTL
#define HBN_RTC_CTL_POS (0)
#define HBN_RTC_CTL_LEN (7)
#define HBN_RTC_CTL_MSK (((1 << HBN_RTC_CTL_LEN) - 1) << HBN_RTC_CTL_POS)
#define HBN_RTC_CTL_UMSK (~(((1 << HBN_RTC_CTL_LEN) - 1) << HBN_RTC_CTL_POS))
#define HBN_MODE HBN_MODE
#define HBN_MODE_POS (7)
#define HBN_MODE_LEN (1)
#define HBN_MODE_MSK (((1 << HBN_MODE_LEN) - 1) << HBN_MODE_POS)
#define HBN_MODE_UMSK (~(((1 << HBN_MODE_LEN) - 1) << HBN_MODE_POS))
#define HBN_TRAP_MODE HBN_TRAP_MODE
#define HBN_TRAP_MODE_POS (8)
#define HBN_TRAP_MODE_LEN (1)
#define HBN_TRAP_MODE_MSK \
(((1 << HBN_TRAP_MODE_LEN) - 1) << HBN_TRAP_MODE_POS)
#define HBN_TRAP_MODE_UMSK \
(~(((1 << HBN_TRAP_MODE_LEN) - 1) << HBN_TRAP_MODE_POS))
#define HBN_PWRDN_HBN_CORE HBN_PWRDN_HBN_CORE
#define HBN_PWRDN_HBN_CORE_POS (9)
#define HBN_PWRDN_HBN_CORE_LEN (1)
#define HBN_PWRDN_HBN_CORE_MSK \
(((1 << HBN_PWRDN_HBN_CORE_LEN) - 1) << HBN_PWRDN_HBN_CORE_POS)
#define HBN_PWRDN_HBN_CORE_UMSK \
(~(((1 << HBN_PWRDN_HBN_CORE_LEN) - 1) << HBN_PWRDN_HBN_CORE_POS))
#define HBN_PWRDN_HBN_RTC HBN_PWRDN_HBN_RTC
#define HBN_PWRDN_HBN_RTC_POS (11)
#define HBN_PWRDN_HBN_RTC_LEN (1)
#define HBN_PWRDN_HBN_RTC_MSK \
(((1 << HBN_PWRDN_HBN_RTC_LEN) - 1) << HBN_PWRDN_HBN_RTC_POS)
#define HBN_PWRDN_HBN_RTC_UMSK \
(~(((1 << HBN_PWRDN_HBN_RTC_LEN) - 1) << HBN_PWRDN_HBN_RTC_POS))
#define HBN_SW_RST HBN_SW_RST
#define HBN_SW_RST_POS (12)
#define HBN_SW_RST_LEN (1)
#define HBN_SW_RST_MSK (((1 << HBN_SW_RST_LEN) - 1) << HBN_SW_RST_POS)
#define HBN_SW_RST_UMSK (~(((1 << HBN_SW_RST_LEN) - 1) << HBN_SW_RST_POS))
#define HBN_DIS_PWR_OFF_LDO11 HBN_DIS_PWR_OFF_LDO11
#define HBN_DIS_PWR_OFF_LDO11_POS (13)
#define HBN_DIS_PWR_OFF_LDO11_LEN (1)
#define HBN_DIS_PWR_OFF_LDO11_MSK \
(((1 << HBN_DIS_PWR_OFF_LDO11_LEN) - 1) << HBN_DIS_PWR_OFF_LDO11_POS)
#define HBN_DIS_PWR_OFF_LDO11_UMSK \
(~(((1 << HBN_DIS_PWR_OFF_LDO11_LEN) - 1) << HBN_DIS_PWR_OFF_LDO11_POS))
#define HBN_DIS_PWR_OFF_LDO11_RT HBN_DIS_PWR_OFF_LDO11_RT
#define HBN_DIS_PWR_OFF_LDO11_RT_POS (14)
#define HBN_DIS_PWR_OFF_LDO11_RT_LEN (1)
#define HBN_DIS_PWR_OFF_LDO11_RT_MSK \
(((1 << HBN_DIS_PWR_OFF_LDO11_RT_LEN) - 1) << HBN_DIS_PWR_OFF_LDO11_RT_POS)
#define HBN_DIS_PWR_OFF_LDO11_RT_UMSK \
(~(((1 << HBN_DIS_PWR_OFF_LDO11_RT_LEN) - 1) \
<< HBN_DIS_PWR_OFF_LDO11_RT_POS))
#define HBN_LDO11_RT_VOUT_SEL HBN_LDO11_RT_VOUT_SEL
#define HBN_LDO11_RT_VOUT_SEL_POS (15)
#define HBN_LDO11_RT_VOUT_SEL_LEN (4)
#define HBN_LDO11_RT_VOUT_SEL_MSK \
(((1 << HBN_LDO11_RT_VOUT_SEL_LEN) - 1) << HBN_LDO11_RT_VOUT_SEL_POS)
#define HBN_LDO11_RT_VOUT_SEL_UMSK \
(~(((1 << HBN_LDO11_RT_VOUT_SEL_LEN) - 1) << HBN_LDO11_RT_VOUT_SEL_POS))
#define HBN_LDO11_AON_VOUT_SEL HBN_LDO11_AON_VOUT_SEL
#define HBN_LDO11_AON_VOUT_SEL_POS (19)
#define HBN_LDO11_AON_VOUT_SEL_LEN (4)
#define HBN_LDO11_AON_VOUT_SEL_MSK \
(((1 << HBN_LDO11_AON_VOUT_SEL_LEN) - 1) << HBN_LDO11_AON_VOUT_SEL_POS)
#define HBN_LDO11_AON_VOUT_SEL_UMSK \
(~(((1 << HBN_LDO11_AON_VOUT_SEL_LEN) - 1) << HBN_LDO11_AON_VOUT_SEL_POS))
#define HBN_PU_DCDC18_AON HBN_PU_DCDC18_AON
#define HBN_PU_DCDC18_AON_POS (23)
#define HBN_PU_DCDC18_AON_LEN (1)
#define HBN_PU_DCDC18_AON_MSK \
(((1 << HBN_PU_DCDC18_AON_LEN) - 1) << HBN_PU_DCDC18_AON_POS)
#define HBN_PU_DCDC18_AON_UMSK \
(~(((1 << HBN_PU_DCDC18_AON_LEN) - 1) << HBN_PU_DCDC18_AON_POS))
#define HBN_RTC_DLY_OPTION HBN_RTC_DLY_OPTION
#define HBN_RTC_DLY_OPTION_POS (24)
#define HBN_RTC_DLY_OPTION_LEN (1)
#define HBN_RTC_DLY_OPTION_MSK \
(((1 << HBN_RTC_DLY_OPTION_LEN) - 1) << HBN_RTC_DLY_OPTION_POS)
#define HBN_RTC_DLY_OPTION_UMSK \
(~(((1 << HBN_RTC_DLY_OPTION_LEN) - 1) << HBN_RTC_DLY_OPTION_POS))
#define HBN_PWR_ON_OPTION HBN_PWR_ON_OPTION
#define HBN_PWR_ON_OPTION_POS (25)
#define HBN_PWR_ON_OPTION_LEN (1)
#define HBN_PWR_ON_OPTION_MSK \
(((1 << HBN_PWR_ON_OPTION_LEN) - 1) << HBN_PWR_ON_OPTION_POS)
#define HBN_PWR_ON_OPTION_UMSK \
(~(((1 << HBN_PWR_ON_OPTION_LEN) - 1) << HBN_PWR_ON_OPTION_POS))
#define HBN_SRAM_SLP_OPTION HBN_SRAM_SLP_OPTION
#define HBN_SRAM_SLP_OPTION_POS (26)
#define HBN_SRAM_SLP_OPTION_LEN (1)
#define HBN_SRAM_SLP_OPTION_MSK \
(((1 << HBN_SRAM_SLP_OPTION_LEN) - 1) << HBN_SRAM_SLP_OPTION_POS)
#define HBN_SRAM_SLP_OPTION_UMSK \
(~(((1 << HBN_SRAM_SLP_OPTION_LEN) - 1) << HBN_SRAM_SLP_OPTION_POS))
#define HBN_SRAM_SLP HBN_SRAM_SLP
#define HBN_SRAM_SLP_POS (27)
#define HBN_SRAM_SLP_LEN (1)
#define HBN_SRAM_SLP_MSK (((1 << HBN_SRAM_SLP_LEN) - 1) << HBN_SRAM_SLP_POS)
#define HBN_SRAM_SLP_UMSK \
(~(((1 << HBN_SRAM_SLP_LEN) - 1) << HBN_SRAM_SLP_POS))
#define HBN_STATE HBN_STATE
#define HBN_STATE_POS (28)
#define HBN_STATE_LEN (4)
#define HBN_STATE_MSK (((1 << HBN_STATE_LEN) - 1) << HBN_STATE_POS)
#define HBN_STATE_UMSK (~(((1 << HBN_STATE_LEN) - 1) << HBN_STATE_POS))
#define BL602_HBN_CTL_OFFSET 0x000000 /* HBN_CTL */
#define BL602_HBN_TIME_L_OFFSET 0x000004 /* HBN_TIME_L */
#define BL602_HBN_TIME_H_OFFSET 0x000008 /* HBN_TIME_H */
#define BL602_HBN_RTC_TIME_L_OFFSET 0x00000c /* RTC_TIME_L */
#define BL602_HBN_RTC_TIME_H_OFFSET 0x000010 /* RTC_TIME_H */
#define BL602_HBN_IRQ_MODE_OFFSET 0x000014 /* HBN_IRQ_MODE */
#define BL602_HBN_IRQ_STAT_OFFSET 0x000018 /* HBN_IRQ_STAT */
#define BL602_HBN_IRQ_CLR_OFFSET 0x00001c /* HBN_IRQ_CLR */
#define BL602_HBN_PIR_CFG_OFFSET 0x000020 /* HBN_PIR_CFG */
#define BL602_HBN_PIR_VTH_OFFSET 0x000024 /* HBN_PIR_VTH */
#define BL602_HBN_PIR_INTERVAL_OFFSET 0x000028 /* HBN_PIR_INTERVAL */
#define BL602_HBN_BOR_CFG_OFFSET 0x00002c /* HBN_BOR_CFG */
#define BL602_HBN_GLB_OFFSET 0x000030 /* HBN_GLB */
#define BL602_HBN_SRAM_OFFSET 0x000034 /* HBN_SRAM */
#define BL602_HBN_RSV0_OFFSET 0x000100 /* HBN_RSV0 */
#define BL602_HBN_RSV1_OFFSET 0x000104 /* HBN_RSV1 */
#define BL602_HBN_RSV2_OFFSET 0x000108 /* HBN_RSV2 */
#define BL602_HBN_RSV3_OFFSET 0x00010c /* HBN_RSV3 */
#define BL602_HBN_RC32K_CTRL0_OFFSET 0x000200 /* rc32k_ctrl0 */
#define BL602_HBN_XTAL32K_OFFSET 0x000204 /* xtal32k */
/* 0x4 : HBN_TIME_L */
/* Register definitions *****************************************************/
#define HBN_TIME_L_OFFSET (0x4)
#define HBN_TIME_L HBN_TIME_L
#define HBN_TIME_L_POS (0)
#define HBN_TIME_L_LEN (32)
#define HBN_TIME_L_MSK (((1 << HBN_TIME_L_LEN) - 1) << HBN_TIME_L_POS)
#define HBN_TIME_L_UMSK (~(((1 << HBN_TIME_L_LEN) - 1) << HBN_TIME_L_POS))
#define BL602_HBN_CTL (BL602_HBN_BASE + BL602_HBN_CTL_OFFSET)
#define BL602_HBN_TIME_L (BL602_HBN_BASE + BL602_HBN_TIME_L_OFFSET)
#define BL602_HBN_TIME_H (BL602_HBN_BASE + BL602_HBN_TIME_H_OFFSET)
#define BL602_HBN_RTC_TIME_L (BL602_HBN_BASE + BL602_HBN_RTC_TIME_L_OFFSET)
#define BL602_HBN_RTC_TIME_H (BL602_HBN_BASE + BL602_HBN_RTC_TIME_H_OFFSET)
#define BL602_HBN_IRQ_MODE (BL602_HBN_BASE + BL602_HBN_IRQ_MODE_OFFSET)
#define BL602_HBN_IRQ_STAT (BL602_HBN_BASE + BL602_HBN_IRQ_STAT_OFFSET)
#define BL602_HBN_IRQ_CLR (BL602_HBN_BASE + BL602_HBN_IRQ_CLR_OFFSET)
#define BL602_HBN_PIR_CFG (BL602_HBN_BASE + BL602_HBN_PIR_CFG_OFFSET)
#define BL602_HBN_PIR_VTH (BL602_HBN_BASE + BL602_HBN_PIR_VTH_OFFSET)
#define BL602_HBN_PIR_INTERVAL (BL602_HBN_BASE + BL602_HBN_PIR_INTERVAL_OFFSET)
#define BL602_HBN_BOR_CFG (BL602_HBN_BASE + BL602_HBN_BOR_CFG_OFFSET)
#define BL602_HBN_GLB (BL602_HBN_BASE + BL602_HBN_GLB_OFFSET)
#define BL602_HBN_SRAM (BL602_HBN_BASE + BL602_HBN_SRAM_OFFSET)
#define BL602_HBN_RSV0 (BL602_HBN_BASE + BL602_HBN_RSV0_OFFSET)
#define BL602_HBN_RSV1 (BL602_HBN_BASE + BL602_HBN_RSV1_OFFSET)
#define BL602_HBN_RSV2 (BL602_HBN_BASE + BL602_HBN_RSV2_OFFSET)
#define BL602_HBN_RSV3 (BL602_HBN_BASE + BL602_HBN_RSV3_OFFSET)
#define BL602_HBN_RC32K_CTRL0 (BL602_HBN_BASE + BL602_HBN_RC32K_CTRL0_OFFSET)
#define BL602_HBN_XTAL32K (BL602_HBN_BASE + BL602_HBN_XTAL32K_OFFSET)
/* 0x8 : HBN_TIME_H */
/* Register bit definitions *************************************************/
#define HBN_TIME_H_OFFSET (0x8)
#define HBN_TIME_H HBN_TIME_H
#define HBN_TIME_H_POS (0)
#define HBN_TIME_H_LEN (8)
#define HBN_TIME_H_MSK (((1 << HBN_TIME_H_LEN) - 1) << HBN_TIME_H_POS)
#define HBN_TIME_H_UMSK (~(((1 << HBN_TIME_H_LEN) - 1) << HBN_TIME_H_POS))
#define HBN_CTL_HBN_STATE_SHIFT (28)
#define HBN_CTL_HBN_STATE_MASK (0x0f << HBN_CTL_HBN_STATE_SHIFT)
#define HBN_CTL_SRAM_SLP (1 << 27)
#define HBN_CTL_SRAM_SLP_OPTION (1 << 26)
#define HBN_CTL_PWR_ON_OPTION (1 << 25)
#define HBN_CTL_RTC_DLY_OPTION (1 << 24)
#define HBN_CTL_PU_DCDC18_AON (1 << 23)
#define HBN_CTL_HBN_LDO11_AON_VOUT_SEL_SHIFT (19)
#define HBN_CTL_HBN_LDO11_AON_VOUT_SEL_MASK (0x0f << HBN_CTL_HBN_LDO11_AON_VOUT_SEL_SHIFT)
#define HBN_CTL_HBN_LDO11_RT_VOUT_SEL_SHIFT (15)
#define HBN_CTL_HBN_LDO11_RT_VOUT_SEL_MASK (0x0f << HBN_CTL_HBN_LDO11_RT_VOUT_SEL_SHIFT)
#define HBN_CTL_HBN_DIS_PWR_OFF_LDO11_RT (1 << 14)
#define HBN_CTL_HBN_DIS_PWR_OFF_LDO11 (1 << 13)
#define HBN_CTL_SW_RST (1 << 12)
#define HBN_CTL_PWRDN_HBN_RTC (1 << 11)
#define HBN_CTL_PWRDN_HBN_CORE (1 << 9)
#define HBN_CTL_TRAP_MODE (1 << 8)
#define HBN_CTL_HBN_MODE (1 << 7)
#define HBN_CTL_RTC_CTL_MASK (0x7f)
/* 0xC : RTC_TIME_L */
#define HBN_TIME_H_HBN_TIME_H_MASK (0xff)
#define HBN_RTC_TIME_L_OFFSET (0xC)
#define HBN_RTC_TIME_LATCH_L HBN_RTC_TIME_LATCH_L
#define HBN_RTC_TIME_LATCH_L_POS (0)
#define HBN_RTC_TIME_LATCH_L_LEN (32)
#define HBN_RTC_TIME_LATCH_L_MSK \
(((1 << HBN_RTC_TIME_LATCH_L_LEN) - 1) << HBN_RTC_TIME_LATCH_L_POS)
#define HBN_RTC_TIME_LATCH_L_UMSK \
(~(((1 << HBN_RTC_TIME_LATCH_L_LEN) - 1) << HBN_RTC_TIME_LATCH_L_POS))
#define HBN_RTC_TIME_H_RTC_TIME_LATCH (1 << 31)
#define HBN_RTC_TIME_H_RTC_TIME_LATCH_H_MASK (0xff)
/* 0x10 : RTC_TIME_H */
#define HBN_IRQ_MODE_PIN_WAKEUP_EN (1 << 27)
#define HBN_IRQ_MODE_PIN_WAKEUP_SEL_SHIFT (24)
#define HBN_IRQ_MODE_PIN_WAKEUP_SEL_MASK (0x07 << HBN_IRQ_MODE_PIN_WAKEUP_SEL_SHIFT)
#define HBN_IRQ_MODE_IRQ_ACOMP1_EN_SHIFT (22)
#define HBN_IRQ_MODE_IRQ_ACOMP1_EN_MASK (0x03 << HBN_IRQ_MODE_IRQ_ACOMP1_EN_SHIFT)
#define HBN_IRQ_MODE_IRQ_ACOMP0_EN_SHIFT (20)
#define HBN_IRQ_MODE_IRQ_ACOMP0_EN_MASK (0x03 << HBN_IRQ_MODE_IRQ_ACOMP0_EN_SHIFT)
#define HBN_IRQ_MODE_IRQ_BOR_EN (1 << 18)
#define HBN_IRQ_MODE_REG_EN_HW_PU_PD (1 << 16)
#define HBN_IRQ_MODE_REG_AON_PAD_IE_SMT (1 << 8)
#define HBN_IRQ_MODE_HBN_PIN_WAKEUP_MASK_SHIFT (3)
#define HBN_IRQ_MODE_HBN_PIN_WAKEUP_MASK_MASK (0x03 << HBN_IRQ_MODE_HBN_PIN_WAKEUP_MASK_SHIFT)
#define HBN_IRQ_MODE_HBN_PIN_WAKEUP_MODE_MASK (0x07)
#define HBN_RTC_TIME_H_OFFSET (0x10)
#define HBN_RTC_TIME_LATCH_H HBN_RTC_TIME_LATCH_H
#define HBN_RTC_TIME_LATCH_H_POS (0)
#define HBN_RTC_TIME_LATCH_H_LEN (8)
#define HBN_RTC_TIME_LATCH_H_MSK \
(((1 << HBN_RTC_TIME_LATCH_H_LEN) - 1) << HBN_RTC_TIME_LATCH_H_POS)
#define HBN_RTC_TIME_LATCH_H_UMSK \
(~(((1 << HBN_RTC_TIME_LATCH_H_LEN) - 1) << HBN_RTC_TIME_LATCH_H_POS))
#define HBN_RTC_TIME_LATCH HBN_RTC_TIME_LATCH
#define HBN_RTC_TIME_LATCH_POS (31)
#define HBN_RTC_TIME_LATCH_LEN (1)
#define HBN_RTC_TIME_LATCH_MSK \
(((1 << HBN_RTC_TIME_LATCH_LEN) - 1) << HBN_RTC_TIME_LATCH_POS)
#define HBN_RTC_TIME_LATCH_UMSK \
(~(((1 << HBN_RTC_TIME_LATCH_LEN) - 1) << HBN_RTC_TIME_LATCH_POS))
#define HBN_PIR_CFG_GPADC_NOSYNC (1 << 9)
#define HBN_PIR_CFG_GPADC_CGEN (1 << 8)
#define HBN_PIR_CFG_PIR_EN (1 << 7)
#define HBN_PIR_CFG_PIR_DIS_SHIFT (4)
#define HBN_PIR_CFG_PIR_DIS_MASK (0x03 << HBN_PIR_CFG_PIR_DIS_SHIFT)
#define HBN_PIR_CFG_PIR_LPF_SEL (1 << 2)
#define HBN_PIR_CFG_PIR_HPF_SEL_MASK (0x03)
/* 0x14 : HBN_IRQ_MODE */
#define HBN_PIR_VTH_PIR_VTH_MASK (0x3fff)
#define HBN_IRQ_MODE_OFFSET (0x14)
#define HBN_PIN_WAKEUP_MODE HBN_PIN_WAKEUP_MODE
#define HBN_PIN_WAKEUP_MODE_POS (0)
#define HBN_PIN_WAKEUP_MODE_LEN (3)
#define HBN_PIN_WAKEUP_MODE_MSK \
(((1 << HBN_PIN_WAKEUP_MODE_LEN) - 1) << HBN_PIN_WAKEUP_MODE_POS)
#define HBN_PIN_WAKEUP_MODE_UMSK \
(~(((1 << HBN_PIN_WAKEUP_MODE_LEN) - 1) << HBN_PIN_WAKEUP_MODE_POS))
#define HBN_PIN_WAKEUP_MASK HBN_PIN_WAKEUP_MASK
#define HBN_PIN_WAKEUP_MASK_POS (3)
#define HBN_PIN_WAKEUP_MASK_LEN (2)
#define HBN_PIN_WAKEUP_MASK_MSK \
(((1 << HBN_PIN_WAKEUP_MASK_LEN) - 1) << HBN_PIN_WAKEUP_MASK_POS)
#define HBN_PIN_WAKEUP_MASK_UMSK \
(~(((1 << HBN_PIN_WAKEUP_MASK_LEN) - 1) << HBN_PIN_WAKEUP_MASK_POS))
#define HBN_REG_AON_PAD_IE_SMT HBN_REG_AON_PAD_IE_SMT
#define HBN_REG_AON_PAD_IE_SMT_POS (8)
#define HBN_REG_AON_PAD_IE_SMT_LEN (1)
#define HBN_REG_AON_PAD_IE_SMT_MSK \
(((1 << HBN_REG_AON_PAD_IE_SMT_LEN) - 1) << HBN_REG_AON_PAD_IE_SMT_POS)
#define HBN_REG_AON_PAD_IE_SMT_UMSK \
(~(((1 << HBN_REG_AON_PAD_IE_SMT_LEN) - 1) << HBN_REG_AON_PAD_IE_SMT_POS))
#define HBN_REG_EN_HW_PU_PD HBN_REG_EN_HW_PU_PD
#define HBN_REG_EN_HW_PU_PD_POS (16)
#define HBN_REG_EN_HW_PU_PD_LEN (1)
#define HBN_REG_EN_HW_PU_PD_MSK \
(((1 << HBN_REG_EN_HW_PU_PD_LEN) - 1) << HBN_REG_EN_HW_PU_PD_POS)
#define HBN_REG_EN_HW_PU_PD_UMSK \
(~(((1 << HBN_REG_EN_HW_PU_PD_LEN) - 1) << HBN_REG_EN_HW_PU_PD_POS))
#define HBN_IRQ_BOR_EN HBN_IRQ_BOR_EN
#define HBN_IRQ_BOR_EN_POS (18)
#define HBN_IRQ_BOR_EN_LEN (1)
#define HBN_IRQ_BOR_EN_MSK \
(((1 << HBN_IRQ_BOR_EN_LEN) - 1) << HBN_IRQ_BOR_EN_POS)
#define HBN_IRQ_BOR_EN_UMSK \
(~(((1 << HBN_IRQ_BOR_EN_LEN) - 1) << HBN_IRQ_BOR_EN_POS))
#define HBN_IRQ_ACOMP0_EN HBN_IRQ_ACOMP0_EN
#define HBN_IRQ_ACOMP0_EN_POS (20)
#define HBN_IRQ_ACOMP0_EN_LEN (2)
#define HBN_IRQ_ACOMP0_EN_MSK \
(((1 << HBN_IRQ_ACOMP0_EN_LEN) - 1) << HBN_IRQ_ACOMP0_EN_POS)
#define HBN_IRQ_ACOMP0_EN_UMSK \
(~(((1 << HBN_IRQ_ACOMP0_EN_LEN) - 1) << HBN_IRQ_ACOMP0_EN_POS))
#define HBN_IRQ_ACOMP1_EN HBN_IRQ_ACOMP1_EN
#define HBN_IRQ_ACOMP1_EN_POS (22)
#define HBN_IRQ_ACOMP1_EN_LEN (2)
#define HBN_IRQ_ACOMP1_EN_MSK \
(((1 << HBN_IRQ_ACOMP1_EN_LEN) - 1) << HBN_IRQ_ACOMP1_EN_POS)
#define HBN_IRQ_ACOMP1_EN_UMSK \
(~(((1 << HBN_IRQ_ACOMP1_EN_LEN) - 1) << HBN_IRQ_ACOMP1_EN_POS))
#define HBN_PIN_WAKEUP_SEL HBN_PIN_WAKEUP_SEL
#define HBN_PIN_WAKEUP_SEL_POS (24)
#define HBN_PIN_WAKEUP_SEL_LEN (3)
#define HBN_PIN_WAKEUP_SEL_MSK \
(((1 << HBN_PIN_WAKEUP_SEL_LEN) - 1) << HBN_PIN_WAKEUP_SEL_POS)
#define HBN_PIN_WAKEUP_SEL_UMSK \
(~(((1 << HBN_PIN_WAKEUP_SEL_LEN) - 1) << HBN_PIN_WAKEUP_SEL_POS))
#define HBN_PIN_WAKEUP_EN HBN_PIN_WAKEUP_EN
#define HBN_PIN_WAKEUP_EN_POS (27)
#define HBN_PIN_WAKEUP_EN_LEN (1)
#define HBN_PIN_WAKEUP_EN_MSK \
(((1 << HBN_PIN_WAKEUP_EN_LEN) - 1) << HBN_PIN_WAKEUP_EN_POS)
#define HBN_PIN_WAKEUP_EN_UMSK \
(~(((1 << HBN_PIN_WAKEUP_EN_LEN) - 1) << HBN_PIN_WAKEUP_EN_POS))
#define HBN_PIR_INTERVAL_PIR_INTERVAL_MASK (0xfff)
/* 0x18 : HBN_IRQ_STAT */
#define HBN_BOR_CFG_R_BOR_OUT (1 << 3)
#define HBN_BOR_CFG_PU_BOR (1 << 2)
#define HBN_BOR_CFG_BOR_VTH (1 << 1)
#define HBN_BOR_CFG_BOR_SEL (1 << 0)
#define HBN_IRQ_STAT_OFFSET (0x18)
#define HBN_IRQ_STAT HBN_IRQ_STAT
#define HBN_IRQ_STAT_POS (0)
#define HBN_IRQ_STAT_LEN (32)
#define HBN_IRQ_STAT_MSK (((1 << HBN_IRQ_STAT_LEN) - 1) << HBN_IRQ_STAT_POS)
#define HBN_IRQ_STAT_UMSK \
(~(((1 << HBN_IRQ_STAT_LEN) - 1) << HBN_IRQ_STAT_POS))
#define HBN_GLB_SW_LDO11_AON_VOUT_SEL_SHIFT (28)
#define HBN_GLB_SW_LDO11_AON_VOUT_SEL_MASK (0x0f << HBN_GLB_SW_LDO11_AON_VOUT_SEL_SHIFT)
#define HBN_GLB_SW_LDO11_RT_VOUT_SEL_SHIFT (24)
#define HBN_GLB_SW_LDO11_RT_VOUT_SEL_MASK (0x0f << HBN_GLB_SW_LDO11_RT_VOUT_SEL_SHIFT)
#define HBN_GLB_SW_LDO11SOC_VOUT_SEL_AON_SHIFT (16)
#define HBN_GLB_SW_LDO11SOC_VOUT_SEL_AON_MASK (0x0f << HBN_GLB_SW_LDO11SOC_VOUT_SEL_AON_SHIFT)
#define HBN_GLB_HBN_PU_RC32K (1 << 5)
#define HBN_GLB_HBN_F32K_SEL_SHIFT (3)
#define HBN_GLB_HBN_F32K_SEL_MASK (0x03 << HBN_GLB_HBN_F32K_SEL_SHIFT)
#define HBN_GLB_HBN_UART_CLK_SEL (1 << 2)
#define HBN_GLB_HBN_ROOT_CLK_SEL_MASK (0x03)
/* 0x1C : HBN_IRQ_CLR */
#define HBN_SRAM_RETRAM_SLP (1 << 7)
#define HBN_SRAM_RETRAM_RET (1 << 6)
#define HBN_IRQ_CLR_OFFSET (0x1C)
#define HBN_IRQ_CLR HBN_IRQ_CLR
#define HBN_IRQ_CLR_POS (0)
#define HBN_IRQ_CLR_LEN (32)
#define HBN_IRQ_CLR_MSK (((1 << HBN_IRQ_CLR_LEN) - 1) << HBN_IRQ_CLR_POS)
#define HBN_IRQ_CLR_UMSK (~(((1 << HBN_IRQ_CLR_LEN) - 1) << HBN_IRQ_CLR_POS))
#define HBN_RC32K_CTRL0_RC32K_CODE_FR_EXT_SHIFT (22)
#define HBN_RC32K_CTRL0_RC32K_CODE_FR_EXT_MASK (0x3ff << HBN_RC32K_CTRL0_RC32K_CODE_FR_EXT_SHIFT)
#define HBN_RC32K_CTRL0_RC32K_CAL_EN (1 << 20)
#define HBN_RC32K_CTRL0_RC32K_EXT_CODE_EN (1 << 19)
#define HBN_RC32K_CTRL0_RC32K_ALLOW_CAL (1 << 18)
#define HBN_RC32K_CTRL0_RC32K_VREF_DLY_SHIFT (16)
#define HBN_RC32K_CTRL0_RC32K_VREF_DLY_MASK (0x03 << HBN_RC32K_CTRL0_RC32K_VREF_DLY_SHIFT)
#define HBN_RC32K_CTRL0_RC32K_DIG_CODE_FR_CAL_SHIFT (6)
#define HBN_RC32K_CTRL0_RC32K_DIG_CODE_FR_CAL_MASK (0x3ff << HBN_RC32K_CTRL0_RC32K_DIG_CODE_FR_CAL_SHIFT)
#define HBN_RC32K_CTRL0_RC32K_CAL_PRECHARGE (1 << 5)
#define HBN_RC32K_CTRL0_RC32K_CAL_DIV_SHIFT (3)
#define HBN_RC32K_CTRL0_RC32K_CAL_DIV_MASK (0x03 << HBN_RC32K_CTRL0_RC32K_CAL_DIV_SHIFT)
#define HBN_RC32K_CTRL0_RC32K_CAL_INPROGRESS (1 << 2)
#define HBN_RC32K_CTRL0_RC32K_RDY (1 << 1)
#define HBN_RC32K_CTRL0_RC32K_CAL_DONE (1 << 0)
/* 0x20 : HBN_PIR_CFG */
#define HBN_XTAL32K_PU_XTAL32K (1 << 19)
#define HBN_XTAL32K_PU_XTAL32K_BUF (1 << 18)
#define HBN_XTAL32K_XTAL32K_AC_CAP_SHORT (1 << 17)
#define HBN_XTAL32K_XTAL32K_CAPBANK_SHIFT (11)
#define HBN_XTAL32K_XTAL32K_CAPBANK_MASK (0x3f << HBN_XTAL32K_XTAL32K_CAPBANK_SHIFT)
#define HBN_XTAL32K_XTAL32K_INV_STRE_SHIFT (9)
#define HBN_XTAL32K_XTAL32K_INV_STRE_MASK (0x03 << HBN_XTAL32K_XTAL32K_INV_STRE_SHIFT)
#define HBN_XTAL32K_XTAL32K_OTF_SHORT (1 << 8)
#define HBN_XTAL32K_XTAL32K_OUTBUF_STRE (1 << 7)
#define HBN_XTAL32K_XTAL32K_REG_SHIFT (5)
#define HBN_XTAL32K_XTAL32K_REG_MASK (0x03 << HBN_XTAL32K_XTAL32K_REG_SHIFT)
#define HBN_XTAL32K_XTAL32K_AMP_CTRL_SHIFT (3)
#define HBN_XTAL32K_XTAL32K_AMP_CTRL_MASK (0x03 << HBN_XTAL32K_XTAL32K_AMP_CTRL_SHIFT)
#define HBN_XTAL32K_XTAL32K_EXT_SEL (1 << 2)
#define HBN_PIR_CFG_OFFSET (0x20)
#define HBN_PIR_HPF_SEL HBN_PIR_HPF_SEL
#define HBN_PIR_HPF_SEL_POS (0)
#define HBN_PIR_HPF_SEL_LEN (2)
#define HBN_PIR_HPF_SEL_MSK \
(((1 << HBN_PIR_HPF_SEL_LEN) - 1) << HBN_PIR_HPF_SEL_POS)
#define HBN_PIR_HPF_SEL_UMSK \
(~(((1 << HBN_PIR_HPF_SEL_LEN) - 1) << HBN_PIR_HPF_SEL_POS))
#define HBN_PIR_LPF_SEL HBN_PIR_LPF_SEL
#define HBN_PIR_LPF_SEL_POS (2)
#define HBN_PIR_LPF_SEL_LEN (1)
#define HBN_PIR_LPF_SEL_MSK \
(((1 << HBN_PIR_LPF_SEL_LEN) - 1) << HBN_PIR_LPF_SEL_POS)
#define HBN_PIR_LPF_SEL_UMSK \
(~(((1 << HBN_PIR_LPF_SEL_LEN) - 1) << HBN_PIR_LPF_SEL_POS))
#define HBN_PIR_DIS HBN_PIR_DIS
#define HBN_PIR_DIS_POS (4)
#define HBN_PIR_DIS_LEN (2)
#define HBN_PIR_DIS_MSK (((1 << HBN_PIR_DIS_LEN) - 1) << HBN_PIR_DIS_POS)
#define HBN_PIR_DIS_UMSK (~(((1 << HBN_PIR_DIS_LEN) - 1) << HBN_PIR_DIS_POS))
#define HBN_PIR_EN HBN_PIR_EN
#define HBN_PIR_EN_POS (7)
#define HBN_PIR_EN_LEN (1)
#define HBN_PIR_EN_MSK (((1 << HBN_PIR_EN_LEN) - 1) << HBN_PIR_EN_POS)
#define HBN_PIR_EN_UMSK (~(((1 << HBN_PIR_EN_LEN) - 1) << HBN_PIR_EN_POS))
#define HBN_GPADC_CGEN HBN_GPADC_CGEN
#define HBN_GPADC_CGEN_POS (8)
#define HBN_GPADC_CGEN_LEN (1)
#define HBN_GPADC_CGEN_MSK \
(((1 << HBN_GPADC_CGEN_LEN) - 1) << HBN_GPADC_CGEN_POS)
#define HBN_GPADC_CGEN_UMSK \
(~(((1 << HBN_GPADC_CGEN_LEN) - 1) << HBN_GPADC_CGEN_POS))
#define HBN_GPADC_NOSYNC HBN_GPADC_NOSYNC
#define HBN_GPADC_NOSYNC_POS (9)
#define HBN_GPADC_NOSYNC_LEN (1)
#define HBN_GPADC_NOSYNC_MSK \
(((1 << HBN_GPADC_NOSYNC_LEN) - 1) << HBN_GPADC_NOSYNC_POS)
#define HBN_GPADC_NOSYNC_UMSK \
(~(((1 << HBN_GPADC_NOSYNC_LEN) - 1) << HBN_GPADC_NOSYNC_POS))
/* 0x24 : HBN_PIR_VTH */
#define HBN_PIR_VTH_OFFSET (0x24)
#define HBN_PIR_VTH HBN_PIR_VTH
#define HBN_PIR_VTH_POS (0)
#define HBN_PIR_VTH_LEN (14)
#define HBN_PIR_VTH_MSK (((1 << HBN_PIR_VTH_LEN) - 1) << HBN_PIR_VTH_POS)
#define HBN_PIR_VTH_UMSK (~(((1 << HBN_PIR_VTH_LEN) - 1) << HBN_PIR_VTH_POS))
/* 0x28 : HBN_PIR_INTERVAL */
#define HBN_PIR_INTERVAL_OFFSET (0x28)
#define HBN_PIR_INTERVAL HBN_PIR_INTERVAL
#define HBN_PIR_INTERVAL_POS (0)
#define HBN_PIR_INTERVAL_LEN (12)
#define HBN_PIR_INTERVAL_MSK \
(((1 << HBN_PIR_INTERVAL_LEN) - 1) << HBN_PIR_INTERVAL_POS)
#define HBN_PIR_INTERVAL_UMSK \
(~(((1 << HBN_PIR_INTERVAL_LEN) - 1) << HBN_PIR_INTERVAL_POS))
/* 0x2C : HBN_BOR_CFG */
#define HBN_BOR_CFG_OFFSET (0x2C)
#define HBN_BOR_SEL HBN_BOR_SEL
#define HBN_BOR_SEL_POS (0)
#define HBN_BOR_SEL_LEN (1)
#define HBN_BOR_SEL_MSK (((1 << HBN_BOR_SEL_LEN) - 1) << HBN_BOR_SEL_POS)
#define HBN_BOR_SEL_UMSK (~(((1 << HBN_BOR_SEL_LEN) - 1) << HBN_BOR_SEL_POS))
#define HBN_BOR_VTH HBN_BOR_VTH
#define HBN_BOR_VTH_POS (1)
#define HBN_BOR_VTH_LEN (1)
#define HBN_BOR_VTH_MSK (((1 << HBN_BOR_VTH_LEN) - 1) << HBN_BOR_VTH_POS)
#define HBN_BOR_VTH_UMSK (~(((1 << HBN_BOR_VTH_LEN) - 1) << HBN_BOR_VTH_POS))
#define HBN_PU_BOR HBN_PU_BOR
#define HBN_PU_BOR_POS (2)
#define HBN_PU_BOR_LEN (1)
#define HBN_PU_BOR_MSK (((1 << HBN_PU_BOR_LEN) - 1) << HBN_PU_BOR_POS)
#define HBN_PU_BOR_UMSK (~(((1 << HBN_PU_BOR_LEN) - 1) << HBN_PU_BOR_POS))
#define HBN_R_BOR_OUT HBN_R_BOR_OUT
#define HBN_R_BOR_OUT_POS (3)
#define HBN_R_BOR_OUT_LEN (1)
#define HBN_R_BOR_OUT_MSK \
(((1 << HBN_R_BOR_OUT_LEN) - 1) << HBN_R_BOR_OUT_POS)
#define HBN_R_BOR_OUT_UMSK \
(~(((1 << HBN_R_BOR_OUT_LEN) - 1) << HBN_R_BOR_OUT_POS))
/* 0x30 : HBN_GLB */
#define HBN_GLB_OFFSET (0x30)
#define HBN_ROOT_CLK_SEL HBN_ROOT_CLK_SEL
#define HBN_ROOT_CLK_SEL_POS (0)
#define HBN_ROOT_CLK_SEL_LEN (2)
#define HBN_ROOT_CLK_SEL_MSK \
(((1 << HBN_ROOT_CLK_SEL_LEN) - 1) << HBN_ROOT_CLK_SEL_POS)
#define HBN_ROOT_CLK_SEL_UMSK \
(~(((1 << HBN_ROOT_CLK_SEL_LEN) - 1) << HBN_ROOT_CLK_SEL_POS))
#define HBN_UART_CLK_SEL HBN_UART_CLK_SEL
#define HBN_UART_CLK_SEL_POS (2)
#define HBN_UART_CLK_SEL_LEN (1)
#define HBN_UART_CLK_SEL_MSK \
(((1 << HBN_UART_CLK_SEL_LEN) - 1) << HBN_UART_CLK_SEL_POS)
#define HBN_UART_CLK_SEL_UMSK \
(~(((1 << HBN_UART_CLK_SEL_LEN) - 1) << HBN_UART_CLK_SEL_POS))
#define HBN_F32K_SEL HBN_F32K_SEL
#define HBN_F32K_SEL_POS (3)
#define HBN_F32K_SEL_LEN (2)
#define HBN_F32K_SEL_MSK (((1 << HBN_F32K_SEL_LEN) - 1) << HBN_F32K_SEL_POS)
#define HBN_F32K_SEL_UMSK \
(~(((1 << HBN_F32K_SEL_LEN) - 1) << HBN_F32K_SEL_POS))
#define HBN_PU_RC32K HBN_PU_RC32K
#define HBN_PU_RC32K_POS (5)
#define HBN_PU_RC32K_LEN (1)
#define HBN_PU_RC32K_MSK (((1 << HBN_PU_RC32K_LEN) - 1) << HBN_PU_RC32K_POS)
#define HBN_PU_RC32K_UMSK \
(~(((1 << HBN_PU_RC32K_LEN) - 1) << HBN_PU_RC32K_POS))
#define HBN_SW_LDO11SOC_VOUT_SEL_AON HBN_SW_LDO11SOC_VOUT_SEL_AON
#define HBN_SW_LDO11SOC_VOUT_SEL_AON_POS (16)
#define HBN_SW_LDO11SOC_VOUT_SEL_AON_LEN (4)
#define HBN_SW_LDO11SOC_VOUT_SEL_AON_MSK \
(((1 << HBN_SW_LDO11SOC_VOUT_SEL_AON_LEN) - 1) \
<< HBN_SW_LDO11SOC_VOUT_SEL_AON_POS)
#define HBN_SW_LDO11SOC_VOUT_SEL_AON_UMSK \
(~(((1 << HBN_SW_LDO11SOC_VOUT_SEL_AON_LEN) - 1) \
<< HBN_SW_LDO11SOC_VOUT_SEL_AON_POS))
#define HBN_SW_LDO11_RT_VOUT_SEL HBN_SW_LDO11_RT_VOUT_SEL
#define HBN_SW_LDO11_RT_VOUT_SEL_POS (24)
#define HBN_SW_LDO11_RT_VOUT_SEL_LEN (4)
#define HBN_SW_LDO11_RT_VOUT_SEL_MSK \
(((1 << HBN_SW_LDO11_RT_VOUT_SEL_LEN) - 1) << HBN_SW_LDO11_RT_VOUT_SEL_POS)
#define HBN_SW_LDO11_RT_VOUT_SEL_UMSK \
(~(((1 << HBN_SW_LDO11_RT_VOUT_SEL_LEN) - 1) \
<< HBN_SW_LDO11_RT_VOUT_SEL_POS))
#define HBN_SW_LDO11_AON_VOUT_SEL HBN_SW_LDO11_AON_VOUT_SEL
#define HBN_SW_LDO11_AON_VOUT_SEL_POS (28)
#define HBN_SW_LDO11_AON_VOUT_SEL_LEN (4)
#define HBN_SW_LDO11_AON_VOUT_SEL_MSK \
(((1 << HBN_SW_LDO11_AON_VOUT_SEL_LEN) - 1) \
<< HBN_SW_LDO11_AON_VOUT_SEL_POS)
#define HBN_SW_LDO11_AON_VOUT_SEL_UMSK \
(~(((1 << HBN_SW_LDO11_AON_VOUT_SEL_LEN) - 1) \
<< HBN_SW_LDO11_AON_VOUT_SEL_POS))
/* 0x34 : HBN_SRAM */
#define HBN_SRAM_OFFSET (0x34)
#define HBN_RETRAM_RET HBN_RETRAM_RET
#define HBN_RETRAM_RET_POS (6)
#define HBN_RETRAM_RET_LEN (1)
#define HBN_RETRAM_RET_MSK \
(((1 << HBN_RETRAM_RET_LEN) - 1) << HBN_RETRAM_RET_POS)
#define HBN_RETRAM_RET_UMSK \
(~(((1 << HBN_RETRAM_RET_LEN) - 1) << HBN_RETRAM_RET_POS))
#define HBN_RETRAM_SLP HBN_RETRAM_SLP
#define HBN_RETRAM_SLP_POS (7)
#define HBN_RETRAM_SLP_LEN (1)
#define HBN_RETRAM_SLP_MSK \
(((1 << HBN_RETRAM_SLP_LEN) - 1) << HBN_RETRAM_SLP_POS)
#define HBN_RETRAM_SLP_UMSK \
(~(((1 << HBN_RETRAM_SLP_LEN) - 1) << HBN_RETRAM_SLP_POS))
/* 0x100 : HBN_RSV0 */
#define HBN_RSV0_OFFSET (0x100)
#define HBN_RSV0 HBN_RSV0
#define HBN_RSV0_POS (0)
#define HBN_RSV0_LEN (32)
#define HBN_RSV0_MSK (((1 << HBN_RSV0_LEN) - 1) << HBN_RSV0_POS)
#define HBN_RSV0_UMSK (~(((1 << HBN_RSV0_LEN) - 1) << HBN_RSV0_POS))
/* 0x104 : HBN_RSV1 */
#define HBN_RSV1_OFFSET (0x104)
#define HBN_RSV1 HBN_RSV1
#define HBN_RSV1_POS (0)
#define HBN_RSV1_LEN (32)
#define HBN_RSV1_MSK (((1 << HBN_RSV1_LEN) - 1) << HBN_RSV1_POS)
#define HBN_RSV1_UMSK (~(((1 << HBN_RSV1_LEN) - 1) << HBN_RSV1_POS))
/* 0x108 : HBN_RSV2 */
#define HBN_RSV2_OFFSET (0x108)
#define HBN_RSV2 HBN_RSV2
#define HBN_RSV2_POS (0)
#define HBN_RSV2_LEN (32)
#define HBN_RSV2_MSK (((1 << HBN_RSV2_LEN) - 1) << HBN_RSV2_POS)
#define HBN_RSV2_UMSK (~(((1 << HBN_RSV2_LEN) - 1) << HBN_RSV2_POS))
/* 0x10C : HBN_RSV3 */
#define HBN_RSV3_OFFSET (0x10C)
#define HBN_RSV3 HBN_RSV3
#define HBN_RSV3_POS (0)
#define HBN_RSV3_LEN (32)
#define HBN_RSV3_MSK (((1 << HBN_RSV3_LEN) - 1) << HBN_RSV3_POS)
#define HBN_RSV3_UMSK (~(((1 << HBN_RSV3_LEN) - 1) << HBN_RSV3_POS))
/* 0x200 : rc32k_ctrl0 */
#define HBN_RC32K_CTRL0_OFFSET (0x200)
#define HBN_RC32K_CAL_DONE HBN_RC32K_CAL_DONE
#define HBN_RC32K_CAL_DONE_POS (0)
#define HBN_RC32K_CAL_DONE_LEN (1)
#define HBN_RC32K_CAL_DONE_MSK \
(((1 << HBN_RC32K_CAL_DONE_LEN) - 1) << HBN_RC32K_CAL_DONE_POS)
#define HBN_RC32K_CAL_DONE_UMSK \
(~(((1 << HBN_RC32K_CAL_DONE_LEN) - 1) << HBN_RC32K_CAL_DONE_POS))
#define HBN_RC32K_RDY HBN_RC32K_RDY
#define HBN_RC32K_RDY_POS (1)
#define HBN_RC32K_RDY_LEN (1)
#define HBN_RC32K_RDY_MSK \
(((1 << HBN_RC32K_RDY_LEN) - 1) << HBN_RC32K_RDY_POS)
#define HBN_RC32K_RDY_UMSK \
(~(((1 << HBN_RC32K_RDY_LEN) - 1) << HBN_RC32K_RDY_POS))
#define HBN_RC32K_CAL_INPROGRESS HBN_RC32K_CAL_INPROGRESS
#define HBN_RC32K_CAL_INPROGRESS_POS (2)
#define HBN_RC32K_CAL_INPROGRESS_LEN (1)
#define HBN_RC32K_CAL_INPROGRESS_MSK \
(((1 << HBN_RC32K_CAL_INPROGRESS_LEN) - 1) << HBN_RC32K_CAL_INPROGRESS_POS)
#define HBN_RC32K_CAL_INPROGRESS_UMSK \
(~(((1 << HBN_RC32K_CAL_INPROGRESS_LEN) - 1) \
<< HBN_RC32K_CAL_INPROGRESS_POS))
#define HBN_RC32K_CAL_DIV HBN_RC32K_CAL_DIV
#define HBN_RC32K_CAL_DIV_POS (3)
#define HBN_RC32K_CAL_DIV_LEN (2)
#define HBN_RC32K_CAL_DIV_MSK \
(((1 << HBN_RC32K_CAL_DIV_LEN) - 1) << HBN_RC32K_CAL_DIV_POS)
#define HBN_RC32K_CAL_DIV_UMSK \
(~(((1 << HBN_RC32K_CAL_DIV_LEN) - 1) << HBN_RC32K_CAL_DIV_POS))
#define HBN_RC32K_CAL_PRECHARGE HBN_RC32K_CAL_PRECHARGE
#define HBN_RC32K_CAL_PRECHARGE_POS (5)
#define HBN_RC32K_CAL_PRECHARGE_LEN (1)
#define HBN_RC32K_CAL_PRECHARGE_MSK \
(((1 << HBN_RC32K_CAL_PRECHARGE_LEN) - 1) << HBN_RC32K_CAL_PRECHARGE_POS)
#define HBN_RC32K_CAL_PRECHARGE_UMSK \
(~(((1 << HBN_RC32K_CAL_PRECHARGE_LEN) - 1) << HBN_RC32K_CAL_PRECHARGE_POS))
#define HBN_RC32K_DIG_CODE_FR_CAL HBN_RC32K_DIG_CODE_FR_CAL
#define HBN_RC32K_DIG_CODE_FR_CAL_POS (6)
#define HBN_RC32K_DIG_CODE_FR_CAL_LEN (10)
#define HBN_RC32K_DIG_CODE_FR_CAL_MSK \
(((1 << HBN_RC32K_DIG_CODE_FR_CAL_LEN) - 1) \
<< HBN_RC32K_DIG_CODE_FR_CAL_POS)
#define HBN_RC32K_DIG_CODE_FR_CAL_UMSK \
(~(((1 << HBN_RC32K_DIG_CODE_FR_CAL_LEN) - 1) \
<< HBN_RC32K_DIG_CODE_FR_CAL_POS))
#define HBN_RC32K_VREF_DLY HBN_RC32K_VREF_DLY
#define HBN_RC32K_VREF_DLY_POS (16)
#define HBN_RC32K_VREF_DLY_LEN (2)
#define HBN_RC32K_VREF_DLY_MSK \
(((1 << HBN_RC32K_VREF_DLY_LEN) - 1) << HBN_RC32K_VREF_DLY_POS)
#define HBN_RC32K_VREF_DLY_UMSK \
(~(((1 << HBN_RC32K_VREF_DLY_LEN) - 1) << HBN_RC32K_VREF_DLY_POS))
#define HBN_RC32K_ALLOW_CAL HBN_RC32K_ALLOW_CAL
#define HBN_RC32K_ALLOW_CAL_POS (18)
#define HBN_RC32K_ALLOW_CAL_LEN (1)
#define HBN_RC32K_ALLOW_CAL_MSK \
(((1 << HBN_RC32K_ALLOW_CAL_LEN) - 1) << HBN_RC32K_ALLOW_CAL_POS)
#define HBN_RC32K_ALLOW_CAL_UMSK \
(~(((1 << HBN_RC32K_ALLOW_CAL_LEN) - 1) << HBN_RC32K_ALLOW_CAL_POS))
#define HBN_RC32K_EXT_CODE_EN HBN_RC32K_EXT_CODE_EN
#define HBN_RC32K_EXT_CODE_EN_POS (19)
#define HBN_RC32K_EXT_CODE_EN_LEN (1)
#define HBN_RC32K_EXT_CODE_EN_MSK \
(((1 << HBN_RC32K_EXT_CODE_EN_LEN) - 1) << HBN_RC32K_EXT_CODE_EN_POS)
#define HBN_RC32K_EXT_CODE_EN_UMSK \
(~(((1 << HBN_RC32K_EXT_CODE_EN_LEN) - 1) << HBN_RC32K_EXT_CODE_EN_POS))
#define HBN_RC32K_CAL_EN HBN_RC32K_CAL_EN
#define HBN_RC32K_CAL_EN_POS (20)
#define HBN_RC32K_CAL_EN_LEN (1)
#define HBN_RC32K_CAL_EN_MSK \
(((1 << HBN_RC32K_CAL_EN_LEN) - 1) << HBN_RC32K_CAL_EN_POS)
#define HBN_RC32K_CAL_EN_UMSK \
(~(((1 << HBN_RC32K_CAL_EN_LEN) - 1) << HBN_RC32K_CAL_EN_POS))
#define HBN_RC32K_CODE_FR_EXT HBN_RC32K_CODE_FR_EXT
#define HBN_RC32K_CODE_FR_EXT_POS (22)
#define HBN_RC32K_CODE_FR_EXT_LEN (10)
#define HBN_RC32K_CODE_FR_EXT_MSK \
(((1 << HBN_RC32K_CODE_FR_EXT_LEN) - 1) << HBN_RC32K_CODE_FR_EXT_POS)
#define HBN_RC32K_CODE_FR_EXT_UMSK \
(~(((1 << HBN_RC32K_CODE_FR_EXT_LEN) - 1) << HBN_RC32K_CODE_FR_EXT_POS))
/* 0x204 : xtal32k */
#define HBN_XTAL32K_OFFSET (0x204)
#define HBN_XTAL32K_EXT_SEL HBN_XTAL32K_EXT_SEL
#define HBN_XTAL32K_EXT_SEL_POS (2)
#define HBN_XTAL32K_EXT_SEL_LEN (1)
#define HBN_XTAL32K_EXT_SEL_MSK \
(((1 << HBN_XTAL32K_EXT_SEL_LEN) - 1) << HBN_XTAL32K_EXT_SEL_POS)
#define HBN_XTAL32K_EXT_SEL_UMSK \
(~(((1 << HBN_XTAL32K_EXT_SEL_LEN) - 1) << HBN_XTAL32K_EXT_SEL_POS))
#define HBN_XTAL32K_AMP_CTRL HBN_XTAL32K_AMP_CTRL
#define HBN_XTAL32K_AMP_CTRL_POS (3)
#define HBN_XTAL32K_AMP_CTRL_LEN (2)
#define HBN_XTAL32K_AMP_CTRL_MSK \
(((1 << HBN_XTAL32K_AMP_CTRL_LEN) - 1) << HBN_XTAL32K_AMP_CTRL_POS)
#define HBN_XTAL32K_AMP_CTRL_UMSK \
(~(((1 << HBN_XTAL32K_AMP_CTRL_LEN) - 1) << HBN_XTAL32K_AMP_CTRL_POS))
#define HBN_XTAL32K_REG HBN_XTAL32K_REG
#define HBN_XTAL32K_REG_POS (5)
#define HBN_XTAL32K_REG_LEN (2)
#define HBN_XTAL32K_REG_MSK \
(((1 << HBN_XTAL32K_REG_LEN) - 1) << HBN_XTAL32K_REG_POS)
#define HBN_XTAL32K_REG_UMSK \
(~(((1 << HBN_XTAL32K_REG_LEN) - 1) << HBN_XTAL32K_REG_POS))
#define HBN_XTAL32K_OUTBUF_STRE HBN_XTAL32K_OUTBUF_STRE
#define HBN_XTAL32K_OUTBUF_STRE_POS (7)
#define HBN_XTAL32K_OUTBUF_STRE_LEN (1)
#define HBN_XTAL32K_OUTBUF_STRE_MSK \
(((1 << HBN_XTAL32K_OUTBUF_STRE_LEN) - 1) << HBN_XTAL32K_OUTBUF_STRE_POS)
#define HBN_XTAL32K_OUTBUF_STRE_UMSK \
(~(((1 << HBN_XTAL32K_OUTBUF_STRE_LEN) - 1) << HBN_XTAL32K_OUTBUF_STRE_POS))
#define HBN_XTAL32K_OTF_SHORT HBN_XTAL32K_OTF_SHORT
#define HBN_XTAL32K_OTF_SHORT_POS (8)
#define HBN_XTAL32K_OTF_SHORT_LEN (1)
#define HBN_XTAL32K_OTF_SHORT_MSK \
(((1 << HBN_XTAL32K_OTF_SHORT_LEN) - 1) << HBN_XTAL32K_OTF_SHORT_POS)
#define HBN_XTAL32K_OTF_SHORT_UMSK \
(~(((1 << HBN_XTAL32K_OTF_SHORT_LEN) - 1) << HBN_XTAL32K_OTF_SHORT_POS))
#define HBN_XTAL32K_INV_STRE HBN_XTAL32K_INV_STRE
#define HBN_XTAL32K_INV_STRE_POS (9)
#define HBN_XTAL32K_INV_STRE_LEN (2)
#define HBN_XTAL32K_INV_STRE_MSK \
(((1 << HBN_XTAL32K_INV_STRE_LEN) - 1) << HBN_XTAL32K_INV_STRE_POS)
#define HBN_XTAL32K_INV_STRE_UMSK \
(~(((1 << HBN_XTAL32K_INV_STRE_LEN) - 1) << HBN_XTAL32K_INV_STRE_POS))
#define HBN_XTAL32K_CAPBANK HBN_XTAL32K_CAPBANK
#define HBN_XTAL32K_CAPBANK_POS (11)
#define HBN_XTAL32K_CAPBANK_LEN (6)
#define HBN_XTAL32K_CAPBANK_MSK \
(((1 << HBN_XTAL32K_CAPBANK_LEN) - 1) << HBN_XTAL32K_CAPBANK_POS)
#define HBN_XTAL32K_CAPBANK_UMSK \
(~(((1 << HBN_XTAL32K_CAPBANK_LEN) - 1) << HBN_XTAL32K_CAPBANK_POS))
#define HBN_XTAL32K_AC_CAP_SHORT HBN_XTAL32K_AC_CAP_SHORT
#define HBN_XTAL32K_AC_CAP_SHORT_POS (17)
#define HBN_XTAL32K_AC_CAP_SHORT_LEN (1)
#define HBN_XTAL32K_AC_CAP_SHORT_MSK \
(((1 << HBN_XTAL32K_AC_CAP_SHORT_LEN) - 1) << HBN_XTAL32K_AC_CAP_SHORT_POS)
#define HBN_XTAL32K_AC_CAP_SHORT_UMSK \
(~(((1 << HBN_XTAL32K_AC_CAP_SHORT_LEN) - 1) \
<< HBN_XTAL32K_AC_CAP_SHORT_POS))
#define HBN_PU_XTAL32K_BUF HBN_PU_XTAL32K_BUF
#define HBN_PU_XTAL32K_BUF_POS (18)
#define HBN_PU_XTAL32K_BUF_LEN (1)
#define HBN_PU_XTAL32K_BUF_MSK \
(((1 << HBN_PU_XTAL32K_BUF_LEN) - 1) << HBN_PU_XTAL32K_BUF_POS)
#define HBN_PU_XTAL32K_BUF_UMSK \
(~(((1 << HBN_PU_XTAL32K_BUF_LEN) - 1) << HBN_PU_XTAL32K_BUF_POS))
#define HBN_PU_XTAL32K HBN_PU_XTAL32K
#define HBN_PU_XTAL32K_POS (19)
#define HBN_PU_XTAL32K_LEN (1)
#define HBN_PU_XTAL32K_MSK \
(((1 << HBN_PU_XTAL32K_LEN) - 1) << HBN_PU_XTAL32K_POS)
#define HBN_PU_XTAL32K_UMSK \
(~(((1 << HBN_PU_XTAL32K_LEN) - 1) << HBN_PU_XTAL32K_POS))
/****************************************************************************
* Public Types
****************************************************************************/
#ifndef __ASSEMBLY__
/* HBN UART clock type definition */
#define HBN_UART_CLK_FCLK 0 /* Select FCLK as UART clock */
#define HBN_UART_CLK_160M 1 /* Select 160M as UART clock */
/****************************************************************************
* Public Data
****************************************************************************/
#ifdef __cplusplus
#define EXTERN extern "C"
extern "C"
{
#else
#define EXTERN extern
#endif
/****************************************************************************
* Public Function Prototypes
****************************************************************************/
/****************************************************************************
* Name: bl602_hbn_set_uart_clk_sel
*
* Description:
* Select uart clock source.
*
* Input Parameters:
* clk_sel: uart clock type selection
*
* Returned Value:
* Description of the value returned by this function (if any),
* including an enumeration of all possible error values.
*
* Assumptions/Limitations:
* Anything else that one might need to know to use this function.
*
****************************************************************************/
EXTERN void bl602_hbn_set_uart_clk_sel(int clk_sel);
#undef EXTERN
#ifdef __cplusplus
}
#endif
#endif /* __ASSEMBLY__ */
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_HBN_H */

View File

@ -0,0 +1,154 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_i2c.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_I2C_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_I2C_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_I2C_CONFIG_OFFSET 0x000000 /* i2c_config */
#define BL602_I2C_INT_STS_OFFSET 0x000004 /* i2c_int_sts */
#define BL602_I2C_SUB_ADDR_OFFSET 0x000008 /* i2c_sub_addr */
#define BL602_I2C_BUS_BUSY_OFFSET 0x00000c /* i2c_bus_busy */
#define BL602_I2C_PRD_START_OFFSET 0x000010 /* i2c_prd_start */
#define BL602_I2C_PRD_STOP_OFFSET 0x000014 /* i2c_prd_stop */
#define BL602_I2C_PRD_DATA_OFFSET 0x000018 /* i2c_prd_data */
#define BL602_I2C_FIFO_CONFIG_0_OFFSET 0x000080 /* i2c_fifo_config_0 */
#define BL602_I2C_FIFO_CONFIG_1_OFFSET 0x000084 /* i2c_fifo_config_1 */
#define BL602_I2C_FIFO_WDATA_OFFSET 0x000088 /* i2c_fifo_wdata */
#define BL602_I2C_FIFO_RDATA_OFFSET 0x00008c /* i2c_fifo_rdata */
/* Register definitions *****************************************************/
#define BL602_I2C_CONFIG (BL602_I2C_BASE + BL602_I2C_CONFIG_OFFSET)
#define BL602_I2C_INT_STS (BL602_I2C_BASE + BL602_I2C_INT_STS_OFFSET)
#define BL602_I2C_SUB_ADDR (BL602_I2C_BASE + BL602_I2C_SUB_ADDR_OFFSET)
#define BL602_I2C_BUS_BUSY (BL602_I2C_BASE + BL602_I2C_BUS_BUSY_OFFSET)
#define BL602_I2C_PRD_START (BL602_I2C_BASE + BL602_I2C_PRD_START_OFFSET)
#define BL602_I2C_PRD_STOP (BL602_I2C_BASE + BL602_I2C_PRD_STOP_OFFSET)
#define BL602_I2C_PRD_DATA (BL602_I2C_BASE + BL602_I2C_PRD_DATA_OFFSET)
#define BL602_I2C_FIFO_CONFIG_0 (BL602_I2C_BASE + BL602_I2C_FIFO_CONFIG_0_OFFSET)
#define BL602_I2C_FIFO_CONFIG_1 (BL602_I2C_BASE + BL602_I2C_FIFO_CONFIG_1_OFFSET)
#define BL602_I2C_FIFO_WDATA (BL602_I2C_BASE + BL602_I2C_FIFO_WDATA_OFFSET)
#define BL602_I2C_FIFO_RDATA (BL602_I2C_BASE + BL602_I2C_FIFO_RDATA_OFFSET)
/* Register bit definitions *************************************************/
#define I2C_CONFIG_CR_I2C_DEG_CNT_SHIFT (28)
#define I2C_CONFIG_CR_I2C_DEG_CNT_MASK (0x0f << I2C_CONFIG_CR_I2C_DEG_CNT_SHIFT)
#define I2C_CONFIG_CR_I2C_PKT_LEN_SHIFT (16)
#define I2C_CONFIG_CR_I2C_PKT_LEN_MASK (0xff << I2C_CONFIG_CR_I2C_PKT_LEN_SHIFT)
#define I2C_CONFIG_CR_I2C_SLV_ADDR_SHIFT (8)
#define I2C_CONFIG_CR_I2C_SLV_ADDR_MASK (0x7f << I2C_CONFIG_CR_I2C_SLV_ADDR_SHIFT)
#define I2C_CONFIG_CR_I2C_SUB_ADDR_BC_SHIFT (5)
#define I2C_CONFIG_CR_I2C_SUB_ADDR_BC_MASK (0x03 << I2C_CONFIG_CR_I2C_SUB_ADDR_BC_SHIFT)
#define I2C_CONFIG_CR_I2C_SUB_ADDR_EN (1 << 4)
#define I2C_CONFIG_CR_I2C_SCL_SYNC_EN (1 << 3)
#define I2C_CONFIG_CR_I2C_DEG_EN (1 << 2)
#define I2C_CONFIG_CR_I2C_PKT_DIR (1 << 1)
#define I2C_CONFIG_CR_I2C_M_EN (1 << 0)
#define I2C_INT_STS_CR_FER_EN (1 << 29)
#define I2C_INT_STS_CR_ARB_EN (1 << 28)
#define I2C_INT_STS_CR_NAK_EN (1 << 27)
#define I2C_INT_STS_CR_RXF_EN (1 << 26)
#define I2C_INT_STS_CR_TXF_EN (1 << 25)
#define I2C_INT_STS_CR_END_EN (1 << 24)
#define I2C_INT_STS_RSVD_21 (1 << 21)
#define I2C_INT_STS_CR_ARB_CLR (1 << 20)
#define I2C_INT_STS_CR_NAK_CLR (1 << 19)
#define I2C_INT_STS_RSVD_18 (1 << 18)
#define I2C_INT_STS_RSVD_17 (1 << 17)
#define I2C_INT_STS_CR_END_CLR (1 << 16)
#define I2C_INT_STS_CR_FER_MASK (1 << 13)
#define I2C_INT_STS_CR_ARB_MASK (1 << 12)
#define I2C_INT_STS_CR_NAK_MASK (1 << 11)
#define I2C_INT_STS_CR_RXF_MASK (1 << 10)
#define I2C_INT_STS_CR_TXF_MASK (1 << 9)
#define I2C_INT_STS_CR_END_MASK (1 << 8)
#define I2C_INT_STS_FER_INT (1 << 5)
#define I2C_INT_STS_ARB_INT (1 << 4)
#define I2C_INT_STS_NAK_INT (1 << 3)
#define I2C_INT_STS_RXF_INT (1 << 2)
#define I2C_INT_STS_TXF_INT (1 << 1)
#define I2C_INT_STS_END_INT (1 << 0)
#define I2C_SUB_ADDR_CR_SUB_ADDR_B3_SHIFT (24)
#define I2C_SUB_ADDR_CR_SUB_ADDR_B3_MASK (0xff << I2C_SUB_ADDR_CR_SUB_ADDR_B3_SHIFT)
#define I2C_SUB_ADDR_CR_SUB_ADDR_B2_SHIFT (16)
#define I2C_SUB_ADDR_CR_SUB_ADDR_B2_MASK (0xff << I2C_SUB_ADDR_CR_SUB_ADDR_B2_SHIFT)
#define I2C_SUB_ADDR_CR_SUB_ADDR_B1_SHIFT (8)
#define I2C_SUB_ADDR_CR_SUB_ADDR_B1_MASK (0xff << I2C_SUB_ADDR_CR_SUB_ADDR_B1_SHIFT)
#define I2C_SUB_ADDR_CR_SUB_ADDR_B0_MASK (0xff)
#define I2C_BUS_BUSY_CR_BUS_BUSY_CLR (1 << 1)
#define I2C_BUS_BUSY_STS_BUS_BUSY (1 << 0)
#define I2C_PRD_START_CR_PRD_S_PH_3_SHIFT (24)
#define I2C_PRD_START_CR_PRD_S_PH_3_MASK (0xff << I2C_PRD_START_CR_PRD_S_PH_3_SHIFT)
#define I2C_PRD_START_CR_PRD_S_PH_2_SHIFT (16)
#define I2C_PRD_START_CR_PRD_S_PH_2_MASK (0xff << I2C_PRD_START_CR_PRD_S_PH_2_SHIFT)
#define I2C_PRD_START_CR_PRD_S_PH_1_SHIFT (8)
#define I2C_PRD_START_CR_PRD_S_PH_1_MASK (0xff << I2C_PRD_START_CR_PRD_S_PH_1_SHIFT)
#define I2C_PRD_START_CR_PRD_S_PH_0_MASK (0xff)
#define I2C_PRD_STOP_CR_PRD_P_PH_3_SHIFT (24)
#define I2C_PRD_STOP_CR_PRD_P_PH_3_MASK (0xff << I2C_PRD_STOP_CR_PRD_P_PH_3_SHIFT)
#define I2C_PRD_STOP_CR_PRD_P_PH_2_SHIFT (16)
#define I2C_PRD_STOP_CR_PRD_P_PH_2_MASK (0xff << I2C_PRD_STOP_CR_PRD_P_PH_2_SHIFT)
#define I2C_PRD_STOP_CR_PRD_P_PH_1_SHIFT (8)
#define I2C_PRD_STOP_CR_PRD_P_PH_1_MASK (0xff << I2C_PRD_STOP_CR_PRD_P_PH_1_SHIFT)
#define I2C_PRD_STOP_CR_PRD_P_PH_0_MASK (0xff)
#define I2C_PRD_DATA_CR_PRD_D_PH_3_SHIFT (24)
#define I2C_PRD_DATA_CR_PRD_D_PH_3_MASK (0xff << I2C_PRD_DATA_CR_PRD_D_PH_3_SHIFT)
#define I2C_PRD_DATA_CR_PRD_D_PH_2_SHIFT (16)
#define I2C_PRD_DATA_CR_PRD_D_PH_2_MASK (0xff << I2C_PRD_DATA_CR_PRD_D_PH_2_SHIFT)
#define I2C_PRD_DATA_CR_PRD_D_PH_1_SHIFT (8)
#define I2C_PRD_DATA_CR_PRD_D_PH_1_MASK (0xff << I2C_PRD_DATA_CR_PRD_D_PH_1_SHIFT)
#define I2C_PRD_DATA_CR_PRD_D_PH_0_MASK (0xff)
#define I2C_FIFO_CONFIG_0_RX_FIFO_UNDERFLOW (1 << 7)
#define I2C_FIFO_CONFIG_0_RX_FIFO_OVERFLOW (1 << 6)
#define I2C_FIFO_CONFIG_0_TX_FIFO_UNDERFLOW (1 << 5)
#define I2C_FIFO_CONFIG_0_TX_FIFO_OVERFLOW (1 << 4)
#define I2C_FIFO_CONFIG_0_RX_FIFO_CLR (1 << 3)
#define I2C_FIFO_CONFIG_0_TX_FIFO_CLR (1 << 2)
#define I2C_FIFO_CONFIG_0_DMA_RX_EN (1 << 1)
#define I2C_FIFO_CONFIG_0_DMA_TX_EN (1 << 0)
#define I2C_FIFO_CONFIG_1_RX_FIFO_TH (1 << 24)
#define I2C_FIFO_CONFIG_1_TX_FIFO_TH (1 << 16)
#define I2C_FIFO_CONFIG_1_RX_FIFO_CNT_SHIFT (8)
#define I2C_FIFO_CONFIG_1_RX_FIFO_CNT_MASK (0x03 << I2C_FIFO_CONFIG_1_RX_FIFO_CNT_SHIFT)
#define I2C_FIFO_CONFIG_1_TX_FIFO_CNT_MASK (0x03)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_I2C_H */

View File

@ -0,0 +1,155 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_sec.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_IR_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_IR_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_IRTX_CONFIG_OFFSET 0x000000 /* irtx_config */
#define BL602_IRTX_INT_STS_OFFSET 0x000004 /* irtx_int_sts */
#define BL602_IRTX_DATA_WORD0_OFFSET 0x000008 /* irtx_data_word0 */
#define BL602_IRTX_DATA_WORD1_OFFSET 0x00000c /* irtx_data_word1 */
#define BL602_IRTX_PULSE_WIDTH_OFFSET 0x000010 /* irtx_pulse_width */
#define BL602_IRTX_PW_OFFSET 0x000014 /* irtx_pw */
#define BL602_IRTX_SWM_PW_0_OFFSET 0x000040 /* irtx_swm_pw_0 */
#define BL602_IRTX_SWM_PW_1_OFFSET 0x000044 /* irtx_swm_pw_1 */
#define BL602_IRTX_SWM_PW_2_OFFSET 0x000048 /* irtx_swm_pw_2 */
#define BL602_IRTX_SWM_PW_3_OFFSET 0x00004c /* irtx_swm_pw_3 */
#define BL602_IRTX_SWM_PW_4_OFFSET 0x000050 /* irtx_swm_pw_4 */
#define BL602_IRTX_SWM_PW_5_OFFSET 0x000054 /* irtx_swm_pw_5 */
#define BL602_IRTX_SWM_PW_6_OFFSET 0x000058 /* irtx_swm_pw_6 */
#define BL602_IRTX_SWM_PW_7_OFFSET 0x00005c /* irtx_swm_pw_7 */
#define BL602_IRRX_CONFIG_OFFSET 0x000080 /* irrx_config */
#define BL602_IRRX_INT_STS_OFFSET 0x000084 /* irrx_int_sts */
#define BL602_IRRX_PW_CONFIG_OFFSET 0x000088 /* irrx_pw_config */
#define BL602_IRRX_DATA_COUNT_OFFSET 0x000090 /* irrx_data_count */
#define BL602_IRRX_DATA_WORD0_OFFSET 0x000094 /* irrx_data_word0 */
#define BL602_IRRX_DATA_WORD1_OFFSET 0x000098 /* irrx_data_word1 */
#define BL602_IRRX_SWM_FIFO_CONFIG_0_OFFSET 0x0000c0 /* irrx_swm_fifo_config_0 */
#define BL602_IRRX_SWM_FIFO_RDATA_OFFSET 0x0000c4 /* irrx_swm_fifo_rdata */
/* Register definitions *****************************************************/
#define BL602_IRTX_CONFIG (BL602_IR_BASE + BL602_IRTX_CONFIG_OFFSET)
#define BL602_IRTX_INT_STS (BL602_IR_BASE + BL602_IRTX_INT_STS_OFFSET)
#define BL602_IRTX_DATA_WORD0 (BL602_IR_BASE + BL602_IRTX_DATA_WORD0_OFFSET)
#define BL602_IRTX_DATA_WORD1 (BL602_IR_BASE + BL602_IRTX_DATA_WORD1_OFFSET)
#define BL602_IRTX_PULSE_WIDTH (BL602_IR_BASE + BL602_IRTX_PULSE_WIDTH_OFFSET)
#define BL602_IRTX_PW (BL602_IR_BASE + BL602_IRTX_PW_OFFSET)
#define BL602_IRTX_SWM_PW_0 (BL602_IR_BASE + BL602_IRTX_SWM_PW_0_OFFSET)
#define BL602_IRTX_SWM_PW_1 (BL602_IR_BASE + BL602_IRTX_SWM_PW_1_OFFSET)
#define BL602_IRTX_SWM_PW_2 (BL602_IR_BASE + BL602_IRTX_SWM_PW_2_OFFSET)
#define BL602_IRTX_SWM_PW_3 (BL602_IR_BASE + BL602_IRTX_SWM_PW_3_OFFSET)
#define BL602_IRTX_SWM_PW_4 (BL602_IR_BASE + BL602_IRTX_SWM_PW_4_OFFSET)
#define BL602_IRTX_SWM_PW_5 (BL602_IR_BASE + BL602_IRTX_SWM_PW_5_OFFSET)
#define BL602_IRTX_SWM_PW_6 (BL602_IR_BASE + BL602_IRTX_SWM_PW_6_OFFSET)
#define BL602_IRTX_SWM_PW_7 (BL602_IR_BASE + BL602_IRTX_SWM_PW_7_OFFSET)
#define BL602_IRRX_CONFIG (BL602_IR_BASE + BL602_IRRX_CONFIG_OFFSET)
#define BL602_IRRX_INT_STS (BL602_IR_BASE + BL602_IRRX_INT_STS_OFFSET)
#define BL602_IRRX_PW_CONFIG (BL602_IR_BASE + BL602_IRRX_PW_CONFIG_OFFSET)
#define BL602_IRRX_DATA_COUNT (BL602_IR_BASE + BL602_IRRX_DATA_COUNT_OFFSET)
#define BL602_IRRX_DATA_WORD0 (BL602_IR_BASE + BL602_IRRX_DATA_WORD0_OFFSET)
#define BL602_IRRX_DATA_WORD1 (BL602_IR_BASE + BL602_IRRX_DATA_WORD1_OFFSET)
#define BL602_IRRX_SWM_FIFO_CONFIG_0 (BL602_IR_BASE + BL602_IRRX_SWM_FIFO_CONFIG_0_OFFSET)
#define BL602_IRRX_SWM_FIFO_RDATA (BL602_IR_BASE + BL602_IRRX_SWM_FIFO_RDATA_OFFSET)
/* Register bit definitions *************************************************/
#define IRTX_CONFIG_CR_DATA_NUM_SHIFT (12)
#define IRTX_CONFIG_CR_DATA_NUM_MASK (0x3f << IRTX_CONFIG_CR_DATA_NUM_SHIFT)
#define IRTX_CONFIG_CR_TAIL_HL_INV (1 << 11)
#define IRTX_CONFIG_CR_TAIL_EN (1 << 10)
#define IRTX_CONFIG_CR_HEAD_HL_INV (1 << 9)
#define IRTX_CONFIG_CR_HEAD_EN (1 << 8)
#define IRTX_CONFIG_CR_LOGIC1_HL_INV (1 << 6)
#define IRTX_CONFIG_CR_LOGIC0_HL_INV (1 << 5)
#define IRTX_CONFIG_CR_DATA_EN (1 << 4)
#define IRTX_CONFIG_CR_SWM_EN (1 << 3)
#define IRTX_CONFIG_CR_MOD_EN (1 << 2)
#define IRTX_CONFIG_CR_OUT_INV (1 << 1)
#define IRTX_CONFIG_CR_EN (1 << 0)
#define IRTX_INT_STS_CR_END_EN (1 << 24)
#define IRTX_INT_STS_CR_END_CLR (1 << 16)
#define IRTX_INT_STS_CR_END_MASK (1 << 8)
#define IRTX_INT_STS_END_INT (1 << 0)
#define IRTX_PULSE_WIDTH_CR_MOD_PH1_W_SHIFT (24)
#define IRTX_PULSE_WIDTH_CR_MOD_PH1_W_MASK (0xff << IRTX_PULSE_WIDTH_CR_MOD_PH1_W_SHIFT)
#define IRTX_PULSE_WIDTH_CR_MOD_PH0_W_SHIFT (16)
#define IRTX_PULSE_WIDTH_CR_MOD_PH0_W_MASK (0xff << IRTX_PULSE_WIDTH_CR_MOD_PH0_W_SHIFT)
#define IRTX_PULSE_WIDTH_CR_PW_UNIT_MASK (0xfff)
#define IRTX_PW_CR_TAIL_PH1_W_SHIFT (28)
#define IRTX_PW_CR_TAIL_PH1_W_MASK (0x0f << IRTX_PW_CR_TAIL_PH1_W_SHIFT)
#define IRTX_PW_CR_TAIL_PH0_W_SHIFT (24)
#define IRTX_PW_CR_TAIL_PH0_W_MASK (0x0f << IRTX_PW_CR_TAIL_PH0_W_SHIFT)
#define IRTX_PW_CR_HEAD_PH1_W_SHIFT (20)
#define IRTX_PW_CR_HEAD_PH1_W_MASK (0x0f << IRTX_PW_CR_HEAD_PH1_W_SHIFT)
#define IRTX_PW_CR_HEAD_PH0_W_SHIFT (16)
#define IRTX_PW_CR_HEAD_PH0_W_MASK (0x0f << IRTX_PW_CR_HEAD_PH0_W_SHIFT)
#define IRTX_PW_CR_LOGIC1_PH1_W_SHIFT (12)
#define IRTX_PW_CR_LOGIC1_PH1_W_MASK (0x0f << IRTX_PW_CR_LOGIC1_PH1_W_SHIFT)
#define IRTX_PW_CR_LOGIC1_PH0_W_SHIFT (8)
#define IRTX_PW_CR_LOGIC1_PH0_W_MASK (0x0f << IRTX_PW_CR_LOGIC1_PH0_W_SHIFT)
#define IRTX_PW_CR_LOGIC0_PH1_W_SHIFT (4)
#define IRTX_PW_CR_LOGIC0_PH1_W_MASK (0x0f << IRTX_PW_CR_LOGIC0_PH1_W_SHIFT)
#define IRTX_PW_CR_LOGIC0_PH0_W_MASK (0x0f)
#define IRRX_CONFIG_CR_DEG_CNT_SHIFT (8)
#define IRRX_CONFIG_CR_DEG_CNT_MASK (0x0f << IRRX_CONFIG_CR_DEG_CNT_SHIFT)
#define IRRX_CONFIG_CR_DEG_EN (1 << 4)
#define IRRX_CONFIG_CR_MODE_SHIFT (2)
#define IRRX_CONFIG_CR_MODE_MASK (0x03 << IRRX_CONFIG_CR_MODE_SHIFT)
#define IRRX_CONFIG_CR_IN_INV (1 << 1)
#define IRRX_CONFIG_CR_EN (1 << 0)
#define IRRX_INT_STS_CR_END_EN (1 << 24)
#define IRRX_INT_STS_CR_END_CLR (1 << 16)
#define IRRX_INT_STS_CR_END_MASK (1 << 8)
#define IRRX_INT_STS_END_INT (1 << 0)
#define IRRX_PW_CONFIG_CR_END_TH_SHIFT (16)
#define IRRX_PW_CONFIG_CR_END_TH_MASK (0xffff << IRRX_PW_CONFIG_CR_END_TH_SHIFT)
#define IRRX_PW_CONFIG_CR_DATA_TH_MASK (0xffff)
#define IRRX_DATA_COUNT_STS_DATA_CNT_MASK (0x7f)
#define IRRX_SWM_FIFO_CONFIG_0_RX_FIFO_CNT_SHIFT (4)
#define IRRX_SWM_FIFO_CONFIG_0_RX_FIFO_CNT_MASK (0x7f << IRRX_SWM_FIFO_CONFIG_0_RX_FIFO_CNT_SHIFT)
#define IRRX_SWM_FIFO_CONFIG_0_RX_FIFO_UNDERFLOW (1 << 3)
#define IRRX_SWM_FIFO_CONFIG_0_RX_FIFO_OVERFLOW (1 << 2)
#define IRRX_SWM_FIFO_CONFIG_0_RX_FIFO_CLR (1 << 0)
#define IRRX_SWM_FIFO_RDATA_RX_FIFO_RDATA_MASK (0xffff)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_IR_H */

View File

@ -0,0 +1,90 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_l1c.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_L1C_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_L1C_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_L1C_CONFIG_OFFSET 0x000000 /* l1c_config */
#define BL602_L1C_HIT_CNT_LSB_OFFSET 0x000004 /* hit_cnt_lsb */
#define BL602_L1C_HIT_CNT_MSB_OFFSET 0x000008 /* hit_cnt_msb */
#define BL602_L1C_MISS_CNT_OFFSET 0x00000c /* miss_cnt */
#define BL602_L1C_RANGE_OFFSET 0x000010 /* l1c_range */
#define BL602_L1C_BMX_ERR_ADDR_EN_OFFSET 0x000200 /* l1c_bmx_err_addr_en */
#define BL602_L1C_BMX_ERR_ADDR_OFFSET 0x000204 /* l1c_bmx_err_addr */
#define BL602_L1C_IROM1_MISR_DATAOUT_0_OFFSET 0x000208 /* irom1_misr_dataout_0 */
#define BL602_L1C_IROM1_MISR_DATAOUT_1_OFFSET 0x00020c /* irom1_misr_dataout_1 */
#define BL602_L1C_CPU_CLK_GATE_OFFSET 0x000210 /* cpu_clk_gate */
/* Register definitions *****************************************************/
#define BL602_L1C_CONFIG (BL602_L1C_BASE + BL602_L1C_CONFIG_OFFSET)
#define BL602_L1C_HIT_CNT_LSB (BL602_L1C_BASE + BL602_L1C_HIT_CNT_LSB_OFFSET)
#define BL602_L1C_HIT_CNT_MSB (BL602_L1C_BASE + BL602_L1C_HIT_CNT_MSB_OFFSET)
#define BL602_L1C_MISS_CNT (BL602_L1C_BASE + BL602_L1C_MISS_CNT_OFFSET)
#define BL602_L1C_RANGE (BL602_L1C_BASE + BL602_L1C_RANGE_OFFSET)
#define BL602_L1C_BMX_ERR_ADDR_EN (BL602_L1C_BASE + BL602_L1C_BMX_ERR_ADDR_EN_OFFSET)
#define BL602_L1C_BMX_ERR_ADDR (BL602_L1C_BASE + BL602_L1C_BMX_ERR_ADDR_OFFSET)
#define BL602_L1C_IROM1_MISR_DATAOUT_0 (BL602_L1C_BASE + BL602_L1C_IROM1_MISR_DATAOUT_0_OFFSET)
#define BL602_L1C_IROM1_MISR_DATAOUT_1 (BL602_L1C_BASE + BL602_L1C_IROM1_MISR_DATAOUT_1_OFFSET)
#define BL602_L1C_CPU_CLK_GATE (BL602_L1C_BASE + BL602_L1C_CPU_CLK_GATE_OFFSET)
/* Register bit definitions *************************************************/
#define L1C_CONFIG_WRAP_DIS (1 << 26)
#define L1C_CONFIG_EARLY_RESP_DIS (1 << 25)
#define L1C_CONFIG_BMX_BUSY_OPTION_DIS (1 << 24)
#define L1C_CONFIG_BMX_TIMEOUT_EN_SHIFT (20)
#define L1C_CONFIG_BMX_TIMEOUT_EN_MASK (0x0f << L1C_CONFIG_BMX_TIMEOUT_EN_SHIFT)
#define L1C_CONFIG_BMX_ARB_MODE_SHIFT (16)
#define L1C_CONFIG_BMX_ARB_MODE_MASK (0x03 << L1C_CONFIG_BMX_ARB_MODE_SHIFT)
#define L1C_CONFIG_BMX_ERR_EN (1 << 15)
#define L1C_CONFIG_BYPASS (1 << 14)
#define L1C_CONFIG_IROM_2T_ACCESS (1 << 12)
#define L1C_CONFIG_WAY_DIS_SHIFT (8)
#define L1C_CONFIG_WAY_DIS_MASK (0x0f << L1C_CONFIG_WAY_DIS_SHIFT)
#define L1C_CONFIG_INVALID_DONE (1 << 3)
#define L1C_CONFIG_INVALID_EN (1 << 2)
#define L1C_CONFIG_CNT_EN (1 << 1)
#define L1C_CONFIG_CACHEABLE (1 << 0)
#define L1C_BMX_ERR_ADDR_EN_HSEL_OPTION_SHIFT (16)
#define L1C_BMX_ERR_ADDR_EN_HSEL_OPTION_MASK (0x0f << L1C_BMX_ERR_ADDR_EN_HSEL_OPTION_SHIFT)
#define L1C_BMX_ERR_ADDR_EN_BMX_ERR_TZ (1 << 5)
#define L1C_BMX_ERR_ADDR_EN_BMX_ERR_DEC (1 << 4)
#define L1C_BMX_ERR_ADDR_EN_BMX_ERR_ADDR_DIS (1 << 0)
#define L1C_CPU_CLK_GATE_FORCE_E21_CLOCK_ON_2 (1 << 2)
#define L1C_CPU_CLK_GATE_FORCE_E21_CLOCK_ON_1 (1 << 1)
#define L1C_CPU_CLK_GATE_FORCE_E21_CLOCK_ON_0 (1 << 0)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_L1C_H */

View File

@ -0,0 +1,60 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_memorymap.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_MEMORYMAP_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_MEMORYMAP_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
#define BL602_CLIC_CTRL_BASE 0x02000000 /* clic */
#define BL602_CLIC_HART0_BASE 0x02800000 /* clic hart0 */
#define BL602_GLB_BASE 0x40000000 /* glb */
#define BL602_RF_BASE 0x40001000 /* rf */
#define BL602_GPIP_BASE 0x40002000 /* gpip */
#define BL602_SEC_DBG_BASE 0x40003000 /* sec_dbg */
#define BL602_SEC_ENG_BASE 0x40004000 /* sec_eng */
#define BL602_TZC_SEC_BASE 0x40005000 /* tzc_sec */
#define BL602_TZC_NSEC_BASE 0x40006000 /* tzc_nsec */
#define BL602_EF_BASE 0x40007000 /* ef_data_0 / ef_data_1 /ef_ctrl */
#define BL602_CCI_BASE 0x40008000 /* cci */
#define BL602_L1C_BASE 0x40009000 /* l1c */
#define BL602_UART0_BASE 0x4000a000 /* uart0 */
#define BL602_UART1_BASE 0x4000a100 /* uart1 */
#define BL602_SPI_BASE 0x4000a200 /* spi */
#define BL602_I2C_BASE 0x4000a300 /* i2c */
#define BL602_PWM_BASE 0x4000a400 /* pwm */
#define BL602_TIMER_BASE 0x4000a500 /* timer */
#define BL602_IR_BASE 0x4000a600 /* ir */
#define BL602_CKS_BASE 0x4000a000 /* cks (overlaps with UART0?) */
#define BL602_SF_BASE 0x4000b000 /* sf */
#define BL602_DMA_BASE 0x4000c000 /* dma */
#define BL602_PDS_BASE 0x4000e000 /* pds */
#define BL602_HBN_BASE 0x4000f000 /* hbn */
#define BL602_AON_BASE 0x4000f800 /* aon */
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_MEMORYMAP_H */

View File

@ -0,0 +1,243 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_pds.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_PDS_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_PDS_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_PDS_CTL_OFFSET 0x000000 /* PDS_CTL */
#define BL602_PDS_TIME1_OFFSET 0x000004 /* PDS_TIME1 */
#define BL602_PDS_INT_OFFSET 0x00000c /* PDS_INT */
#define BL602_PDS_CTL2_OFFSET 0x000010 /* PDS_CTL2 */
#define BL602_PDS_CTL3_OFFSET 0x000014 /* PDS_CTL3 */
#define BL602_PDS_CTL4_OFFSET 0x000018 /* PDS_CTL4 */
#define BL602_PDS_STAT_OFFSET 0x00001c /* pds_stat */
#define BL602_PDS_RAM1_OFFSET 0x000020 /* pds_ram1 */
#define BL602_PDS_RC32M_CTRL0_OFFSET 0x000300 /* rc32m_ctrl0 */
#define BL602_PDS_RC32M_CTRL1_OFFSET 0x000304 /* rc32m_ctrl1 */
#define BL602_PDS_PU_RST_CLKPLL_OFFSET 0x000400 /* pu_rst_clkpll */
#define BL602_PDS_CLKPLL_TOP_CTRL_OFFSET 0x000404 /* clkpll_top_ctrl */
#define BL602_PDS_CLKPLL_CP_OFFSET 0x000408 /* clkpll_cp */
#define BL602_PDS_CLKPLL_RZ_OFFSET 0x00040c /* clkpll_rz */
#define BL602_PDS_CLKPLL_FBDV_OFFSET 0x000410 /* clkpll_fbdv */
#define BL602_PDS_CLKPLL_VCO_OFFSET 0x000414 /* clkpll_vco */
#define BL602_PDS_CLKPLL_SDM_OFFSET 0x000418 /* clkpll_sdm */
#define BL602_PDS_CLKPLL_OUTPUT_EN_OFFSET 0x00041c /* clkpll_output_en */
/* Register definitions *****************************************************/
#define BL602_PDS_CTL (BL602_PDS_BASE + BL602_PDS_CTL_OFFSET)
#define BL602_PDS_TIME1 (BL602_PDS_BASE + BL602_PDS_TIME1_OFFSET)
#define BL602_PDS_INT (BL602_PDS_BASE + BL602_PDS_INT_OFFSET)
#define BL602_PDS_CTL2 (BL602_PDS_BASE + BL602_PDS_CTL2_OFFSET)
#define BL602_PDS_CTL3 (BL602_PDS_BASE + BL602_PDS_CTL3_OFFSET)
#define BL602_PDS_CTL4 (BL602_PDS_BASE + BL602_PDS_CTL4_OFFSET)
#define BL602_PDS_STAT (BL602_PDS_BASE + BL602_PDS_STAT_OFFSET)
#define BL602_PDS_RAM1 (BL602_PDS_BASE + BL602_PDS_RAM1_OFFSET)
#define BL602_PDS_RC32M_CTRL0 (BL602_PDS_BASE + BL602_PDS_RC32M_CTRL0_OFFSET)
#define BL602_PDS_RC32M_CTRL1 (BL602_PDS_BASE + BL602_PDS_RC32M_CTRL1_OFFSET)
#define BL602_PDS_PU_RST_CLKPLL (BL602_PDS_BASE + BL602_PDS_PU_RST_CLKPLL_OFFSET)
#define BL602_PDS_CLKPLL_TOP_CTRL (BL602_PDS_BASE + BL602_PDS_CLKPLL_TOP_CTRL_OFFSET)
#define BL602_PDS_CLKPLL_CP (BL602_PDS_BASE + BL602_PDS_CLKPLL_CP_OFFSET)
#define BL602_PDS_CLKPLL_RZ (BL602_PDS_BASE + BL602_PDS_CLKPLL_RZ_OFFSET)
#define BL602_PDS_CLKPLL_FBDV (BL602_PDS_BASE + BL602_PDS_CLKPLL_FBDV_OFFSET)
#define BL602_PDS_CLKPLL_VCO (BL602_PDS_BASE + BL602_PDS_CLKPLL_VCO_OFFSET)
#define BL602_PDS_CLKPLL_SDM (BL602_PDS_BASE + BL602_PDS_CLKPLL_SDM_OFFSET)
#define BL602_PDS_CLKPLL_OUTPUT_EN (BL602_PDS_BASE + BL602_PDS_CLKPLL_OUTPUT_EN_OFFSET)
/* Register bit definitions *************************************************/
#define PDS_CTL_CR_CTRL_PLL_SHIFT (30)
#define PDS_CTL_CR_CTRL_PLL_MASK (0x03 << PDS_CTL_CR_CTRL_PLL_SHIFT)
#define PDS_CTL_CR_CTRL_RF_SHIFT (28)
#define PDS_CTL_CR_CTRL_RF_MASK (0x03 << PDS_CTL_CR_CTRL_RF_SHIFT)
#define PDS_CTL_CR_LDO_VOL_SHIFT (24)
#define PDS_CTL_CR_LDO_VOL_MASK (0x0f << PDS_CTL_CR_LDO_VOL_SHIFT)
#define PDS_CTL_CR_PD_LDO11 (1 << 22)
#define PDS_CTL_CR_NP_WFI_MASK (1 << 21)
#define PDS_CTL_CR_LDO_VSEL_EN (1 << 18)
#define PDS_CTL_CR_RC32M_OFF_DIS (1 << 17)
#define PDS_CTL_CR_RST_SOC_EN (1 << 16)
#define PDS_CTL_CR_SOC_ENB_FORCE_ON (1 << 15)
#define PDS_CTL_CR_PD_XTAL (1 << 14)
#define PDS_CTL_CR_PWR_OFF (1 << 13)
#define PDS_CTL_CR_WAIT_XTAL_RDY (1 << 12)
#define PDS_CTL_CR_ISO_EN (1 << 11)
#define PDS_CTL_CR_MEM_STBY (1 << 9)
#define PDS_CTL_CR_GATE_CLK (1 << 8)
#define PDS_CTL_CR_PD_BG_SYS (1 << 5)
#define PDS_CTL_CR_PD_DCDC18 (1 << 4)
#define PDS_CTL_CR_WIFI_PDS_SAVE_STATE (1 << 3)
#define PDS_CTL_CR_XTAL_FORCE_OFF (1 << 2)
#define PDS_CTL_CR_SLEEP_FOREVER (1 << 1)
#define PDS_CTL_PDS_START_PS (1 << 0)
#define PDS_INT_CR_INT_CLR (1 << 16)
#define PDS_INT_CR_PLL_DONE_INT_MASK (1 << 11)
#define PDS_INT_CR_RF_DONE_INT_MASK (1 << 10)
#define PDS_INT_CR_IRQ_IN_DIS (1 << 9)
#define PDS_INT_CR_WAKE_INT_MASK (1 << 8)
#define PDS_INT_RO_PLL_DONE_INT (1 << 3)
#define PDS_INT_RO_RF_DONE_INT (1 << 2)
#define PDS_INT_RO_IRQ_IN (1 << 1)
#define PDS_INT_RO_WAKE_INT (1 << 0)
#define PDS_CTL2_CR_FORCE_WB_GATE_CLK (1 << 18)
#define PDS_CTL2_CR_FORCE_NP_GATE_CLK (1 << 16)
#define PDS_CTL2_CR_FORCE_WB_MEM_STBY (1 << 14)
#define PDS_CTL2_CR_FORCE_NP_MEM_STBY (1 << 12)
#define PDS_CTL2_CR_FORCE_WB_PDS_RST (1 << 10)
#define PDS_CTL2_CR_FORCE_NP_PDS_RST (1 << 8)
#define PDS_CTL2_CR_FORCE_WB_ISO_EN (1 << 6)
#define PDS_CTL2_CR_FORCE_NP_ISO_EN (1 << 4)
#define PDS_CTL2_CR_FORCE_WB_PWR_OFF (1 << 2)
#define PDS_CTL2_CR_FORCE_NP_PWR_OFF (1 << 0)
#define PDS_CTL3_CR_MISC_ISO_EN (1 << 30)
#define PDS_CTL3_CR_WB_ISO_EN (1 << 27)
#define PDS_CTL3_CR_NP_ISO_EN (1 << 24)
#define PDS_CTL3_CR_FORCE_MISC_GATE_CLK (1 << 13)
#define PDS_CTL3_CR_FORCE_MISC_MEM_STBY (1 << 10)
#define PDS_CTL3_CR_FORCE_MISC_PDS_RST (1 << 7)
#define PDS_CTL3_CR_FORCE_MISC_ISO_EN (1 << 4)
#define PDS_CTL3_CR_FORCE_MISC_PWR_OFF (1 << 1)
#define PDS_CTL4_CR_MISC_GATE_CLK (1 << 27)
#define PDS_CTL4_CR_MISC_MEM_STBY (1 << 26)
#define PDS_CTL4_CR_MISC_RESET (1 << 25)
#define PDS_CTL4_CR_MISC_PWR_OFF (1 << 24)
#define PDS_CTL4_CR_WB_GATE_CLK (1 << 15)
#define PDS_CTL4_CR_WB_MEM_STBY (1 << 14)
#define PDS_CTL4_CR_WB_RESET (1 << 13)
#define PDS_CTL4_CR_WB_PWR_OFF (1 << 12)
#define PDS_CTL4_CR_NP_GATE_CLK (1 << 3)
#define PDS_CTL4_CR_NP_MEM_STBY (1 << 2)
#define PDS_CTL4_CR_NP_RESET (1 << 1)
#define PDS_CTL4_CR_NP_PWR_OFF (1 << 0)
#define PDS_STAT_RO_PLL_STATE_SHIFT (16)
#define PDS_STAT_RO_PLL_STATE_MASK (0x03 << PDS_STAT_RO_PLL_STATE_SHIFT)
#define PDS_STAT_RO_RF_STATE_SHIFT (8)
#define PDS_STAT_RO_RF_STATE_MASK (0x0f << PDS_STAT_RO_RF_STATE_SHIFT)
#define PDS_STAT_RO_STATE_MASK (0x0f)
#define PDS_RAM1_CR_NP_SRAM_PWR_MASK (0xff)
#define PDS_RC32M_CTRL0_CODE_FR_EXT_SHIFT (22)
#define PDS_RC32M_CTRL0_CODE_FR_EXT_MASK (0xff << PDS_RC32M_CTRL0_CODE_FR_EXT_SHIFT)
#define PDS_RC32M_CTRL0_PD (1 << 21)
#define PDS_RC32M_CTRL0_CAL_EN (1 << 20)
#define PDS_RC32M_CTRL0_EXT_CODE_EN (1 << 19)
#define PDS_RC32M_CTRL0_REFCLK_HALF (1 << 18)
#define PDS_RC32M_CTRL0_ALLOW_CAL (1 << 17)
#define PDS_RC32M_CTRL0_DIG_CODE_FR_CAL_SHIFT (6)
#define PDS_RC32M_CTRL0_DIG_CODE_FR_CAL_MASK (0xff << PDS_RC32M_CTRL0_DIG_CODE_FR_CAL_SHIFT)
#define PDS_RC32M_CTRL0_CAL_PRECHARGE (1 << 5)
#define PDS_RC32M_CTRL0_CAL_DIV_SHIFT (3)
#define PDS_RC32M_CTRL0_CAL_DIV_MASK (0x03 << PDS_RC32M_CTRL0_CAL_DIV_SHIFT)
#define PDS_RC32M_CTRL0_CAL_INPROGRESS (1 << 2)
#define PDS_RC32M_CTRL0_RDY (1 << 1)
#define PDS_RC32M_CTRL0_CAL_DONE (1 << 0)
#define PDS_RC32M_CTRL1_RC32M_CLK_FORCE_ON (1 << 4)
#define PDS_RC32M_CTRL1_RC32M_CLK_INV (1 << 3)
#define PDS_RC32M_CTRL1_RC32M_CLK_SOFT_RST (1 << 2)
#define PDS_RC32M_CTRL1_RC32M_SOFT_RST (1 << 1)
#define PDS_RC32M_CTRL1_RC32M_TEST_EN (1 << 0)
#define PDS_PU_RST_CLKPLL_PU_CLKPLL (1 << 10)
#define PDS_PU_RST_CLKPLL_PU_CLKPLL_SFREG (1 << 9)
#define PDS_PU_RST_CLKPLL_PU_CP (1 << 8)
#define PDS_PU_RST_CLKPLL_PU_PFD (1 << 7)
#define PDS_PU_RST_CLKPLL_PU_CLAMP_OP (1 << 6)
#define PDS_PU_RST_CLKPLL_PU_FBDV (1 << 5)
#define PDS_PU_RST_CLKPLL_PU_POSTDIV (1 << 4)
#define PDS_PU_RST_CLKPLL_RESET_REFDIV (1 << 3)
#define PDS_PU_RST_CLKPLL_RESET_FBDV (1 << 2)
#define PDS_PU_RST_CLKPLL_RESET_POSTDIV (1 << 1)
#define PDS_PU_RST_CLKPLL_SDM_RESET (1 << 0)
#define PDS_CLKPLL_TOP_CTRL_VG13_SEL_SHIFT (24)
#define PDS_CLKPLL_TOP_CTRL_VG13_SEL_MASK (0x03 << PDS_CLKPLL_TOP_CTRL_VG13_SEL_SHIFT)
#define PDS_CLKPLL_TOP_CTRL_VG11_SEL_SHIFT (20)
#define PDS_CLKPLL_TOP_CTRL_VG11_SEL_MASK (0x03 << PDS_CLKPLL_TOP_CTRL_VG11_SEL_SHIFT)
#define PDS_CLKPLL_TOP_CTRL_REFCLK_SEL (1 << 16)
#define PDS_CLKPLL_TOP_CTRL_XTAL_RC32M_SEL (1 << 12)
#define PDS_CLKPLL_TOP_CTRL_REFDIV_RATIO_SHIFT (8)
#define PDS_CLKPLL_TOP_CTRL_REFDIV_RATIO_MASK (0x0f << PDS_CLKPLL_TOP_CTRL_REFDIV_RATIO_SHIFT)
#define PDS_CLKPLL_TOP_CTRL_POSTDIV_MASK (0x7f)
#define PDS_CLKPLL_CP_CP_OPAMP_EN (1 << 10)
#define PDS_CLKPLL_CP_CP_STARTUP_EN (1 << 9)
#define PDS_CLKPLL_CP_INT_FRAC_SW (1 << 8)
#define PDS_CLKPLL_CP_ICP_1U_SHIFT (6)
#define PDS_CLKPLL_CP_ICP_1U_MASK (0x03 << PDS_CLKPLL_CP_ICP_1U_SHIFT)
#define PDS_CLKPLL_CP_ICP_5U_SHIFT (4)
#define PDS_CLKPLL_CP_ICP_5U_MASK (0x03 << PDS_CLKPLL_CP_ICP_5U_SHIFT)
#define PDS_CLKPLL_CP_SEL_CP_BIAS (1 << 0)
#define PDS_CLKPLL_RZ_RZ_SHIFT (16)
#define PDS_CLKPLL_RZ_MASK (0x07 << PDS_CLKPLL_RZ_RZ_SHIFT)
#define PDS_CLKPLL_RZ_CZ_SHIFT (14)
#define PDS_CLKPLL_RZ_CZ_MASK (0x03 << PDS_CLKPLL_RZ_CZ_SHIFT)
#define PDS_CLKPLL_RZ_C3_SHIFT (12)
#define PDS_CLKPLL_RZ_C3_MASK (0x03 << PDS_CLKPLL_RZ_C3_SHIFT)
#define PDS_CLKPLL_RZ_R4_SHORT (1 << 8)
#define PDS_CLKPLL_RZ_R4_SHIFT (4)
#define PDS_CLKPLL_RZ_R4_MASK (0x03 << PDS_CLKPLL_RZ_R4_SHIFT)
#define PDS_CLKPLL_RZ_C4_EN (1 << 0)
#define PDS_CLKPLL_FBDV_SEL_FB_CLK_SHIFT (2)
#define PDS_CLKPLL_FBDV_SEL_FB_CLK_MASK (0x03 << PDS_CLKPLL_FBDV_SEL_FB_CLK_SHIFT)
#define PDS_CLKPLL_FBDV_SEL_SAMPLE_CLK_MASK (0x03)
#define PDS_CLKPLL_VCO_SHRTR (1 << 3)
#define PDS_CLKPLL_VCO_VCO_SPEED_MASK (0x07)
#define PDS_CLKPLL_SDM_SDM_BYPASS (1 << 29)
#define PDS_CLKPLL_SDM_SDM_FLAG (1 << 28)
#define PDS_CLKPLL_SDM_DITHER_SEL_SHIFT (24)
#define PDS_CLKPLL_SDM_DITHER_SEL_MASK (0x03 << PDS_CLKPLL_SDM_DITHER_SEL_SHIFT)
#define PDS_CLKPLL_SDM_SDMIN_MASK (0xffffff)
#define PDS_CLKPLL_OUTPUT_EN_EN_DIV2_480M (1 << 9)
#define PDS_CLKPLL_OUTPUT_EN_EN_32M (1 << 8)
#define PDS_CLKPLL_OUTPUT_EN_EN_48M (1 << 7)
#define PDS_CLKPLL_OUTPUT_EN_EN_80M (1 << 6)
#define PDS_CLKPLL_OUTPUT_EN_EN_96M (1 << 5)
#define PDS_CLKPLL_OUTPUT_EN_EN_120M (1 << 4)
#define PDS_CLKPLL_OUTPUT_EN_EN_160M (1 << 3)
#define PDS_CLKPLL_OUTPUT_EN_EN_192M (1 << 2)
#define PDS_CLKPLL_OUTPUT_EN_EN_240M (1 << 1)
#define PDS_CLKPLL_OUTPUT_EN_EN_480M (1 << 0)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_PDS_H */

View File

@ -0,0 +1,143 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_pwm.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_PWM_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_PWM_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* PWM0,1,2,3,4 are the same so create this helper for register offsets */
#define BL602_PWM_N_BASE_OFFSET(n) (BL602_PWM_BASE + (BL602_PWM1_BASE_OFFSET - BL602_PWM0_BASE_OFFSET))
/* Register offsets *********************************************************/
#define BL602_PWM_INT_CONFIG_OFFSET 0x000000 /* pwm_int_config */
#define BL602_PWM0_BASE_OFFSET 0x000020 /* pwm0 base */
#define BL602_PWM0_CLKDIV_OFFSET 0x000020 /* pwm0_clkdiv */
#define BL602_PWM0_THRE1_OFFSET 0x000024 /* pwm0_thre1 */
#define BL602_PWM0_THRE2_OFFSET 0x000028 /* pwm0_thre2 */
#define BL602_PWM0_PERIOD_OFFSET 0x00002c /* pwm0_period */
#define BL602_PWM0_CONFIG_OFFSET 0x000030 /* pwm0_config */
#define BL602_PWM0_INTERRUPT_OFFSET 0x000034 /* pwm0_interrupt */
#define BL602_PWM1_BASE_OFFSET 0x000040 /* pwm1 base */
#define BL602_PWM1_CLKDIV_OFFSET 0x000040 /* pwm1_clkdiv */
#define BL602_PWM1_THRE1_OFFSET 0x000044 /* pwm1_thre1 */
#define BL602_PWM1_THRE2_OFFSET 0x000048 /* pwm1_thre2 */
#define BL602_PWM1_PERIOD_OFFSET 0x00004c /* pwm1_period */
#define BL602_PWM1_CONFIG_OFFSET 0x000050 /* pwm1_config */
#define BL602_PWM1_INTERRUPT_OFFSET 0x000054 /* pwm1_interrupt */
#define BL602_PWM2_BASE_OFFSET 0x000060 /* pwm2 base */
#define BL602_PWM2_CLKDIV_OFFSET 0x000060 /* pwm2_clkdiv */
#define BL602_PWM2_THRE1_OFFSET 0x000064 /* pwm2_thre1 */
#define BL602_PWM2_THRE2_OFFSET 0x000068 /* pwm2_thre2 */
#define BL602_PWM2_PERIOD_OFFSET 0x00006c /* pwm2_period */
#define BL602_PWM2_CONFIG_OFFSET 0x000070 /* pwm2_config */
#define BL602_PWM2_INTERRUPT_OFFSET 0x000074 /* pwm2_interrupt */
#define BL602_PWM3_BASE_OFFSET 0x000080 /* pwm3 base */
#define BL602_PWM3_CLKDIV_OFFSET 0x000080 /* pwm3_clkdiv */
#define BL602_PWM3_THRE1_OFFSET 0x000084 /* pwm3_thre1 */
#define BL602_PWM3_THRE2_OFFSET 0x000088 /* pwm3_thre2 */
#define BL602_PWM3_PERIOD_OFFSET 0x00008c /* pwm3_period */
#define BL602_PWM3_CONFIG_OFFSET 0x000090 /* pwm3_config */
#define BL602_PWM3_INTERRUPT_OFFSET 0x000094 /* pwm3_interrupt */
#define BL602_PWM4_BASE_OFFSET 0x0000a0 /* pwm4 base */
#define BL602_PWM4_CLKDIV_OFFSET 0x0000a0 /* pwm4_clkdiv */
#define BL602_PWM4_THRE1_OFFSET 0x0000a4 /* pwm4_thre1 */
#define BL602_PWM4_THRE2_OFFSET 0x0000a8 /* pwm4_thre2 */
#define BL602_PWM4_PERIOD_OFFSET 0x0000ac /* pwm4_period */
#define BL602_PWM4_CONFIG_OFFSET 0x0000b0 /* pwm4_config */
#define BL602_PWM4_INTERRUPT_OFFSET 0x0000b4 /* pwm4_interrupt */
/* Register definitions *****************************************************/
#define BL602_PWM_INT_CONFIG (BL602_PWM_BASE + BL602_PWM_INT_CONFIG_OFFSET)
#define BL602_PWM_N_CLKDIV(n) (BL602_PWM_N_BASE_OFFSET(n) + BL602_PWM0_CLKDIV_OFFSET)
#define BL602_PWM_N_THRE1(n) (BL602_PWM_N_BASE_OFFSET(n) + BL602_PWM0_THRE1_OFFSET)
#define BL602_PWM_N_THRE2(n) (BL602_PWM_N_BASE_OFFSET(n) + BL602_PWM0_THRE2_OFFSET)
#define BL602_PWM_N_PERIOD(n) (BL602_PWM_N_BASE_OFFSET(n) + BL602_PWM0_PERIOD_OFFSET)
#define BL602_PWM_N_CONFIG(n) (BL602_PWM_N_BASE_OFFSET(n) + BL602_PWM0_CONFIG_OFFSET)
#define BL602_PWM_N_INTERRUPT(n) (BL602_PWM_N_BASE_OFFSET(n) + BL602_PWM0_INTERRUPT_OFFSET)
#define BL602_PWM0_CLKDIV BL602_PWM_N_CLKDIV(0)
#define BL602_PWM0_THRE1 BL602_PWM_N_THRE1(0)
#define BL602_PWM0_THRE2 BL602_PWM_N_THRE2(0)
#define BL602_PWM0_PERIOD BL602_PWM_N_PERIOD(0)
#define BL602_PWM0_CONFIG BL602_PWM_N_CONFIG(0)
#define BL602_PWM0_INTERRUPT BL602_PWM_N_INTERRUPT(0)
#define BL602_PWM1_CLKDIV BL602_PWM_N_CLKDIV(1)
#define BL602_PWM1_THRE1 BL602_PWM_N_THRE1(1)
#define BL602_PWM1_THRE2 BL602_PWM_N_THRE2(1)
#define BL602_PWM1_PERIOD BL602_PWM_N_PERIOD(1)
#define BL602_PWM1_CONFIG BL602_PWM_N_CONFIG(1)
#define BL602_PWM1_INTERRUPT BL602_PWM_N_INTERRUPT(1)
#define BL602_PWM2_CLKDIV BL602_PWM_N_CLKDIV(2)
#define BL602_PWM2_THRE1 BL602_PWM_N_THRE1(2)
#define BL602_PWM2_THRE2 BL602_PWM_N_THRE2(2)
#define BL602_PWM2_PERIOD BL602_PWM_N_PERIOD(2)
#define BL602_PWM2_CONFIG BL602_PWM_N_CONFIG(2)
#define BL602_PWM2_INTERRUPT BL602_PWM_N_INTERRUPT(2)
#define BL602_PWM3_CLKDIV BL602_PWM_N_CLKDIV(3)
#define BL602_PWM3_THRE1 BL602_PWM_N_THRE1(3)
#define BL602_PWM3_THRE2 BL602_PWM_N_THRE2(3)
#define BL602_PWM3_PERIOD BL602_PWM_N_PERIOD(3)
#define BL602_PWM3_CONFIG BL602_PWM_N_CONFIG(3)
#define BL602_PWM3_INTERRUPT BL602_PWM_N_INTERRUPT(3)
#define BL602_PWM4_CLKDIV BL602_PWM_N_CLKDIV(4)
#define BL602_PWM4_THRE1 BL602_PWM_N_THRE1(4)
#define BL602_PWM4_THRE2 BL602_PWM_N_THRE2(4)
#define BL602_PWM4_PERIOD BL602_PWM_N_PERIOD(4)
#define BL602_PWM4_CONFIG BL602_PWM_N_CONFIG(4)
#define BL602_PWM4_INTERRUPT BL602_PWM_N_INTERRUPT(4)
/* Register bit definitions *************************************************/
#define INT_CONFIG_PWM_INT_CLEAR_SHIFT (8)
#define INT_CONFIG_PWM_INT_CLEAR_MASK (0x3f << INT_CONFIG_PWM_INT_CLEAR_SHIFT)
#define INT_CONFIG_PWM_INTERRUPT_STS_MASK (0x3f)
#define CLKDIV_PWM_CLK_DIV_MASK (0xffff)
#define THRE1_PWM_THRE1_MASK (0xffff)
#define THRE2_PWM_THRE2_MASK (0xffff)
#define PERIOD_PWM_PERIOD_MASK (0xffff)
#define CONFIG_PWM_STS_TOP (1 << 7)
#define CONFIG_PWM_STOP_EN (1 << 6)
#define CONFIG_PWM_SW_MODE (1 << 5)
#define CONFIG_PWM_SW_FORCE_VAL (1 << 4)
#define CONFIG_PWM_STOP_MODE (1 << 3)
#define CONFIG_PWM_OUT_INV (1 << 2)
#define CONFIG_REG_CLK_SEL_MASK (0x03)
#define INTERRUPT_PWM_INT_ENABLE (1 << 16)
#define INTERRUPT_PWM_INT_PERIOD_CNT_MASK (0xffff)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_PWM_H */

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,399 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_sec.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_SEC_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_SEC_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_SD_CHIP_ID_LOW_OFFSET 0x000000 /* sd_chip_id_low */
#define BL602_SD_CHIP_ID_HIGH_OFFSET 0x000004 /* sd_chip_id_high */
#define BL602_SD_WIFI_MAC_LOW_OFFSET 0x000008 /* sd_wifi_mac_low */
#define BL602_SD_WIFI_MAC_HIGH_OFFSET 0x00000c /* sd_wifi_mac_high */
#define BL602_SD_DBG_PWD_LOW_OFFSET 0x000010 /* sd_dbg_pwd_low */
#define BL602_SD_DBG_PWD_HIGH_OFFSET 0x000014 /* sd_dbg_pwd_high */
#define BL602_SD_STATUS_OFFSET 0x000018 /* sd_status */
#define BL602_SD_DBG_RESERVED_OFFSET 0x00001c /* sd_dbg_reserved */
#define BL602_SE_SHA_CTRL_OFFSET 0x000000 /* se_sha_0_ctrl */
#define BL602_SE_SHA_MSA_OFFSET 0x000004 /* se_sha_0_msa */
#define BL602_SE_SHA_STATUS_OFFSET 0x000008 /* se_sha_0_status */
#define BL602_SE_SHA_ENDIAN_OFFSET 0x00000c /* se_sha_0_endian */
#define BL602_SE_SHA_HASH_L_0_OFFSET 0x000010 /* se_sha_0_hash_l_0 */
#define BL602_SE_SHA_HASH_L_1_OFFSET 0x000014 /* se_sha_0_hash_l_1 */
#define BL602_SE_SHA_HASH_L_2_OFFSET 0x000018 /* se_sha_0_hash_l_2 */
#define BL602_SE_SHA_HASH_L_3_OFFSET 0x00001c /* se_sha_0_hash_l_3 */
#define BL602_SE_SHA_HASH_L_4_OFFSET 0x000020 /* se_sha_0_hash_l_4 */
#define BL602_SE_SHA_HASH_L_5_OFFSET 0x000024 /* se_sha_0_hash_l_5 */
#define BL602_SE_SHA_HASH_L_6_OFFSET 0x000028 /* se_sha_0_hash_l_6 */
#define BL602_SE_SHA_HASH_L_7_OFFSET 0x00002c /* se_sha_0_hash_l_7 */
#define BL602_SE_SHA_HASH_H_0_OFFSET 0x000030 /* se_sha_0_hash_h_0 */
#define BL602_SE_SHA_HASH_H_1_OFFSET 0x000034 /* se_sha_0_hash_h_1 */
#define BL602_SE_SHA_HASH_H_2_OFFSET 0x000038 /* se_sha_0_hash_h_2 */
#define BL602_SE_SHA_HASH_H_3_OFFSET 0x00003c /* se_sha_0_hash_h_3 */
#define BL602_SE_SHA_HASH_H_4_OFFSET 0x000040 /* se_sha_0_hash_h_4 */
#define BL602_SE_SHA_HASH_H_5_OFFSET 0x000044 /* se_sha_0_hash_h_5 */
#define BL602_SE_SHA_HASH_H_6_OFFSET 0x000048 /* se_sha_0_hash_h_6 */
#define BL602_SE_SHA_HASH_H_7_OFFSET 0x00004c /* se_sha_0_hash_h_7 */
#define BL602_SE_SHA_LINK_OFFSET 0x000050 /* se_sha_0_link */
#define BL602_SE_SHA_CTRL_PROT_OFFSET 0x0000fc /* se_sha_0_ctrl_prot */
#define BL602_SE_AES_CTRL_OFFSET 0x000100 /* se_aes_0_ctrl */
#define BL602_SE_AES_MSA_OFFSET 0x000104 /* se_aes_0_msa */
#define BL602_SE_AES_MDA_OFFSET 0x000108 /* se_aes_0_mda */
#define BL602_SE_AES_STATUS_OFFSET 0x00010c /* se_aes_0_status */
#define BL602_SE_AES_IV_0_OFFSET 0x000110 /* se_aes_0_iv_0 */
#define BL602_SE_AES_IV_1_OFFSET 0x000114 /* se_aes_0_iv_1 */
#define BL602_SE_AES_IV_2_OFFSET 0x000118 /* se_aes_0_iv_2 */
#define BL602_SE_AES_IV_3_OFFSET 0x00011c /* se_aes_0_iv_3 */
#define BL602_SE_AES_KEY_0_OFFSET 0x000120 /* se_aes_0_key_0 */
#define BL602_SE_AES_KEY_1_OFFSET 0x000124 /* se_aes_0_key_1 */
#define BL602_SE_AES_KEY_2_OFFSET 0x000128 /* se_aes_0_key_2 */
#define BL602_SE_AES_KEY_3_OFFSET 0x00012c /* se_aes_0_key_3 */
#define BL602_SE_AES_KEY_4_OFFSET 0x000130 /* se_aes_0_key_4 */
#define BL602_SE_AES_KEY_5_OFFSET 0x000134 /* se_aes_0_key_5 */
#define BL602_SE_AES_KEY_6_OFFSET 0x000138 /* se_aes_0_key_6 */
#define BL602_SE_AES_KEY_7_OFFSET 0x00013c /* se_aes_0_key_7 */
#define BL602_SE_AES_KEY_SEL_0_OFFSET 0x000140 /* se_aes_0_key_sel_0 */
#define BL602_SE_AES_KEY_SEL_1_OFFSET 0x000144 /* se_aes_0_key_sel_1 */
#define BL602_SE_AES_ENDIAN_OFFSET 0x000148 /* se_aes_0_endian */
#define BL602_SE_AES_SBOOT_OFFSET 0x00014c /* se_aes_0_sboot */
#define BL602_SE_AES_LINK_OFFSET 0x000150 /* se_aes_0_link */
#define BL602_SE_AES_CTRL_PROT_OFFSET 0x0001fc /* se_aes_0_ctrl_prot */
#define BL602_SE_TRNG_CTRL_0_OFFSET 0x000200 /* se_trng_0_ctrl_0 */
#define BL602_SE_TRNG_STATUS_OFFSET 0x000204 /* se_trng_0_status */
#define BL602_SE_TRNG_DOUT_0_OFFSET 0x000208 /* se_trng_0_dout_0 */
#define BL602_SE_TRNG_DOUT_1_OFFSET 0x00020c /* se_trng_0_dout_1 */
#define BL602_SE_TRNG_DOUT_2_OFFSET 0x000210 /* se_trng_0_dout_2 */
#define BL602_SE_TRNG_DOUT_3_OFFSET 0x000214 /* se_trng_0_dout_3 */
#define BL602_SE_TRNG_DOUT_4_OFFSET 0x000218 /* se_trng_0_dout_4 */
#define BL602_SE_TRNG_DOUT_5_OFFSET 0x00021c /* se_trng_0_dout_5 */
#define BL602_SE_TRNG_DOUT_6_OFFSET 0x000220 /* se_trng_0_dout_6 */
#define BL602_SE_TRNG_DOUT_7_OFFSET 0x000224 /* se_trng_0_dout_7 */
#define BL602_SE_TRNG_TEST_OFFSET 0x000228 /* se_trng_0_test */
#define BL602_SE_TRNG_CTRL_1_OFFSET 0x00022c /* se_trng_0_ctrl_1 */
#define BL602_SE_TRNG_CTRL_2_OFFSET 0x000230 /* se_trng_0_ctrl_2 */
#define BL602_SE_TRNG_CTRL_3_OFFSET 0x000234 /* se_trng_0_ctrl_3 */
#define BL602_SE_TRNG_TEST_OUT_0_OFFSET 0x000240 /* se_trng_0_test_out_0 */
#define BL602_SE_TRNG_TEST_OUT_1_OFFSET 0x000244 /* se_trng_0_test_out_1 */
#define BL602_SE_TRNG_TEST_OUT_2_OFFSET 0x000248 /* se_trng_0_test_out_2 */
#define BL602_SE_TRNG_TEST_OUT_3_OFFSET 0x00024c /* se_trng_0_test_out_3 */
#define BL602_SE_TRNG_CTRL_PROT_OFFSET 0x0002fc /* se_trng_0_ctrl_prot */
#define BL602_SE_PKA_CTRL_0_OFFSET 0x000300 /* se_pka_0_ctrl_0 */
#define BL602_SE_PKA_SEED_OFFSET 0x00030c /* se_pka_0_seed */
#define BL602_SE_PKA_CTRL_1_OFFSET 0x000310 /* se_pka_0_ctrl_1 */
#define BL602_SE_PKA_RW_OFFSET 0x000340 /* se_pka_0_rw */
#define BL602_SE_PKA_RW_BURST_OFFSET 0x000360 /* se_pka_0_rw_burst */
#define BL602_SE_PKA_CTRL_PROT_OFFSET 0x0003fc /* se_pka_0_ctrl_prot */
#define BL602_SE_CDET_CTRL_0_OFFSET 0x000400 /* se_cdet_0_ctrl_0 */
#define BL602_SE_CDET_CTRL_1_OFFSET 0x000404 /* se_cdet_0_ctrl_1 */
#define BL602_SE_CDET_CTRL_PROT_OFFSET 0x0004fc /* se_cdet_0_ctrl_prot */
#define BL602_SE_GMAC_CTRL_0_OFFSET 0x000500 /* se_gmac_0_ctrl_0 */
#define BL602_SE_GMAC_LCA_OFFSET 0x000504 /* se_gmac_0_lca */
#define BL602_SE_GMAC_STATUS_OFFSET 0x000508 /* se_gmac_0_status */
#define BL602_SE_GMAC_CTRL_PROT_OFFSET 0x0005fc /* se_gmac_0_ctrl_prot */
#define BL602_SE_CTRL_PROT_RD_OFFSET 0x000f00 /* se_ctrl_prot_rd */
#define BL602_SE_CTRL_RESERVED_0_OFFSET 0x000f04 /* se_ctrl_reserved_0 */
#define BL602_SE_CTRL_RESERVED_1_OFFSET 0x000f08 /* se_ctrl_reserved_1 */
#define BL602_SE_CTRL_RESERVED_2_OFFSET 0x000f0c /* se_ctrl_reserved_2 */
/* Register definitions *****************************************************/
#define BL602_SD_CHIP_ID_LOW (BL602_SEC_DBG_BASE + BL602_SD_CHIP_ID_LOW_OFFSET)
#define BL602_SD_CHIP_ID_HIGH (BL602_SEC_DBG_BASE + BL602_SD_CHIP_ID_HIGH_OFFSET)
#define BL602_SD_WIFI_MAC_LOW (BL602_SEC_DBG_BASE + BL602_SD_WIFI_MAC_LOW_OFFSET)
#define BL602_SD_WIFI_MAC_HIGH (BL602_SEC_DBG_BASE + BL602_SD_WIFI_MAC_HIGH_OFFSET)
#define BL602_SD_DBG_PWD_LOW (BL602_SEC_DBG_BASE + BL602_SD_DBG_PWD_LOW_OFFSET)
#define BL602_SD_DBG_PWD_HIGH (BL602_SEC_DBG_BASE + BL602_SD_DBG_PWD_HIGH_OFFSET)
#define BL602_SD_STATUS (BL602_SEC_DBG_BASE + BL602_SD_STATUS_OFFSET)
#define BL602_SD_DBG_RESERVED (BL602_SEC_DBG_BASE + BL602_SD_DBG_RESERVED_OFFSET)
#define BL602_SE_SHA_CTRL (BL602_SEC_ENG_BASE + BL602_SE_SHA_CTRL_OFFSET)
#define BL602_SE_SHA_MSA (BL602_SEC_ENG_BASE + BL602_SE_SHA_MSA_OFFSET)
#define BL602_SE_SHA_STATUS (BL602_SEC_ENG_BASE + BL602_SE_SHA_STATUS_OFFSET)
#define BL602_SE_SHA_ENDIAN (BL602_SEC_ENG_BASE + BL602_SE_SHA_ENDIAN_OFFSET)
#define BL602_SE_SHA_HASH_L_0 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_L_0_OFFSET)
#define BL602_SE_SHA_HASH_L_1 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_L_1_OFFSET)
#define BL602_SE_SHA_HASH_L_2 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_L_2_OFFSET)
#define BL602_SE_SHA_HASH_L_3 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_L_3_OFFSET)
#define BL602_SE_SHA_HASH_L_4 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_L_4_OFFSET)
#define BL602_SE_SHA_HASH_L_5 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_L_5_OFFSET)
#define BL602_SE_SHA_HASH_L_6 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_L_6_OFFSET)
#define BL602_SE_SHA_HASH_L_7 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_L_7_OFFSET)
#define BL602_SE_SHA_HASH_H_0 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_H_0_OFFSET)
#define BL602_SE_SHA_HASH_H_1 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_H_1_OFFSET)
#define BL602_SE_SHA_HASH_H_2 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_H_2_OFFSET)
#define BL602_SE_SHA_HASH_H_3 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_H_3_OFFSET)
#define BL602_SE_SHA_HASH_H_4 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_H_4_OFFSET)
#define BL602_SE_SHA_HASH_H_5 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_H_5_OFFSET)
#define BL602_SE_SHA_HASH_H_6 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_H_6_OFFSET)
#define BL602_SE_SHA_HASH_H_7 (BL602_SEC_ENG_BASE + BL602_SE_SHA_HASH_H_7_OFFSET)
#define BL602_SE_SHA_LINK (BL602_SEC_ENG_BASE + BL602_SE_SHA_LINK_OFFSET)
#define BL602_SE_SHA_CTRL_PROT (BL602_SEC_ENG_BASE + BL602_SE_SHA_CTRL_PROT_OFFSET)
#define BL602_SE_AES_CTRL (BL602_SEC_ENG_BASE + BL602_SE_AES_CTRL_OFFSET)
#define BL602_SE_AES_MSA (BL602_SEC_ENG_BASE + BL602_SE_AES_MSA_OFFSET)
#define BL602_SE_AES_MDA (BL602_SEC_ENG_BASE + BL602_SE_AES_MDA_OFFSET)
#define BL602_SE_AES_STATUS (BL602_SEC_ENG_BASE + BL602_SE_AES_STATUS_OFFSET)
#define BL602_SE_AES_IV_0 (BL602_SEC_ENG_BASE + BL602_SE_AES_IV_0_OFFSET)
#define BL602_SE_AES_IV_1 (BL602_SEC_ENG_BASE + BL602_SE_AES_IV_1_OFFSET)
#define BL602_SE_AES_IV_2 (BL602_SEC_ENG_BASE + BL602_SE_AES_IV_2_OFFSET)
#define BL602_SE_AES_IV_3 (BL602_SEC_ENG_BASE + BL602_SE_AES_IV_3_OFFSET)
#define BL602_SE_AES_KEY_0 (BL602_SEC_ENG_BASE + BL602_SE_AES_KEY_0_OFFSET)
#define BL602_SE_AES_KEY_1 (BL602_SEC_ENG_BASE + BL602_SE_AES_KEY_1_OFFSET)
#define BL602_SE_AES_KEY_2 (BL602_SEC_ENG_BASE + BL602_SE_AES_KEY_2_OFFSET)
#define BL602_SE_AES_KEY_3 (BL602_SEC_ENG_BASE + BL602_SE_AES_KEY_3_OFFSET)
#define BL602_SE_AES_KEY_4 (BL602_SEC_ENG_BASE + BL602_SE_AES_KEY_4_OFFSET)
#define BL602_SE_AES_KEY_5 (BL602_SEC_ENG_BASE + BL602_SE_AES_KEY_5_OFFSET)
#define BL602_SE_AES_KEY_6 (BL602_SEC_ENG_BASE + BL602_SE_AES_KEY_6_OFFSET)
#define BL602_SE_AES_KEY_7 (BL602_SEC_ENG_BASE + BL602_SE_AES_KEY_7_OFFSET)
#define BL602_SE_AES_KEY_SEL_0 (BL602_SEC_ENG_BASE + BL602_SE_AES_KEY_SEL_0_OFFSET)
#define BL602_SE_AES_KEY_SEL_1 (BL602_SEC_ENG_BASE + BL602_SE_AES_KEY_SEL_1_OFFSET)
#define BL602_SE_AES_ENDIAN (BL602_SEC_ENG_BASE + BL602_SE_AES_ENDIAN_OFFSET)
#define BL602_SE_AES_SBOOT (BL602_SEC_ENG_BASE + BL602_SE_AES_SBOOT_OFFSET)
#define BL602_SE_AES_LINK (BL602_SEC_ENG_BASE + BL602_SE_AES_LINK_OFFSET)
#define BL602_SE_AES_CTRL_PROT (BL602_SEC_ENG_BASE + BL602_SE_AES_CTRL_PROT_OFFSET)
#define BL602_SE_TRNG_CTRL_0 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_CTRL_0_OFFSET)
#define BL602_SE_TRNG_STATUS (BL602_SEC_ENG_BASE + BL602_SE_TRNG_STATUS_OFFSET)
#define BL602_SE_TRNG_DOUT_0 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_DOUT_0_OFFSET)
#define BL602_SE_TRNG_DOUT_1 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_DOUT_1_OFFSET)
#define BL602_SE_TRNG_DOUT_2 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_DOUT_2_OFFSET)
#define BL602_SE_TRNG_DOUT_3 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_DOUT_3_OFFSET)
#define BL602_SE_TRNG_DOUT_4 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_DOUT_4_OFFSET)
#define BL602_SE_TRNG_DOUT_5 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_DOUT_5_OFFSET)
#define BL602_SE_TRNG_DOUT_6 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_DOUT_6_OFFSET)
#define BL602_SE_TRNG_DOUT_7 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_DOUT_7_OFFSET)
#define BL602_SE_TRNG_TEST (BL602_SEC_ENG_BASE + BL602_SE_TRNG_TEST_OFFSET)
#define BL602_SE_TRNG_CTRL_1 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_CTRL_1_OFFSET)
#define BL602_SE_TRNG_CTRL_2 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_CTRL_2_OFFSET)
#define BL602_SE_TRNG_CTRL_3 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_CTRL_3_OFFSET)
#define BL602_SE_TRNG_TEST_OUT_0 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_TEST_OUT_0_OFFSET)
#define BL602_SE_TRNG_TEST_OUT_1 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_TEST_OUT_1_OFFSET)
#define BL602_SE_TRNG_TEST_OUT_2 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_TEST_OUT_2_OFFSET)
#define BL602_SE_TRNG_TEST_OUT_3 (BL602_SEC_ENG_BASE + BL602_SE_TRNG_TEST_OUT_3_OFFSET)
#define BL602_SE_TRNG_CTRL_PROT (BL602_SEC_ENG_BASE + BL602_SE_TRNG_CTRL_PROT_OFFSET)
#define BL602_SE_PKA_CTRL_0 (BL602_SEC_ENG_BASE + BL602_SE_PKA_CTRL_0_OFFSET)
#define BL602_SE_PKA_SEED (BL602_SEC_ENG_BASE + BL602_SE_PKA_SEED_OFFSET)
#define BL602_SE_PKA_CTRL_1 (BL602_SEC_ENG_BASE + BL602_SE_PKA_CTRL_1_OFFSET)
#define BL602_SE_PKA_RW (BL602_SEC_ENG_BASE + BL602_SE_PKA_RW_OFFSET)
#define BL602_SE_PKA_RW_BURST (BL602_SEC_ENG_BASE + BL602_SE_PKA_RW_BURST_OFFSET)
#define BL602_SE_PKA_CTRL_PROT (BL602_SEC_ENG_BASE + BL602_SE_PKA_CTRL_PROT_OFFSET)
#define BL602_SE_CDET_CTRL_0 (BL602_SEC_ENG_BASE + BL602_SE_CDET_CTRL_0_OFFSET)
#define BL602_SE_CDET_CTRL_1 (BL602_SEC_ENG_BASE + BL602_SE_CDET_CTRL_1_OFFSET)
#define BL602_SE_CDET_CTRL_PROT (BL602_SEC_ENG_BASE + BL602_SE_CDET_CTRL_PROT_OFFSET)
#define BL602_SE_GMAC_CTRL_0 (BL602_SEC_ENG_BASE + BL602_SE_GMAC_CTRL_0_OFFSET)
#define BL602_SE_GMAC_LCA (BL602_SEC_ENG_BASE + BL602_SE_GMAC_LCA_OFFSET)
#define BL602_SE_GMAC_STATUS (BL602_SEC_ENG_BASE + BL602_SE_GMAC_STATUS_OFFSET)
#define BL602_SE_GMAC_CTRL_PROT (BL602_SEC_ENG_BASE + BL602_SE_GMAC_CTRL_PROT_OFFSET)
#define BL602_SE_CTRL_PROT_RD (BL602_SEC_ENG_BASE + BL602_SE_CTRL_PROT_RD_OFFSET)
#define BL602_SE_CTRL_RESERVED_0 (BL602_SEC_ENG_BASE + BL602_SE_CTRL_RESERVED_0_OFFSET)
#define BL602_SE_CTRL_RESERVED_1 (BL602_SEC_ENG_BASE + BL602_SE_CTRL_RESERVED_1_OFFSET)
#define BL602_SE_CTRL_RESERVED_2 (BL602_SEC_ENG_BASE + BL602_SE_CTRL_RESERVED_2_OFFSET)
/* Register bit definitions *************************************************/
#define SD_STATUS_ENA_SHIFT (28)
#define SD_STATUS_ENA_MASK (0x0f << SD_STATUS_ENA_SHIFT)
#define SD_STATUS_MODE_SHIFT (24)
#define SD_STATUS_MODE_MASK (0x0f << SD_STATUS_MODE_SHIFT)
#define SD_STATUS_PWD_CNT_SHIFT (4)
#define SD_STATUS_PWD_CNT_MASK (0xfffff << SD_STATUS_PWD_CNT_SHIFT)
#define SD_STATUS_CCI_CLK_SEL (1 << 3)
#define SD_STATUS_CCI_READ_EN (1 << 2)
#define SD_STATUS_PWD_TRIG (1 << 1)
#define SD_STATUS_PWD_BUSY (1 << 0)
#define SE_SHA_CTRL_MSG_LEN_SHIFT (16)
#define SE_SHA_CTRL_MSG_LEN_MASK (0xffff << SE_SHA_CTRL_MSG_LEN_SHIFT)
#define SE_SHA_CTRL_LINK_MODE (1 << 15)
#define SE_SHA_CTRL_INT_MASK (1 << 11)
#define SE_SHA_CTRL_INT_SET_1T (1 << 10)
#define SE_SHA_CTRL_INT_CLR_1T (1 << 9)
#define SE_SHA_CTRL_INT (1 << 8)
#define SE_SHA_CTRL_HASH_SEL (1 << 6)
#define SE_SHA_CTRL_EN (1 << 5)
#define SE_SHA_CTRL_MODE_SHIFT (2)
#define SE_SHA_CTRL_MODE_MASK (0x07 << SE_SHA_CTRL_MODE_SHIFT)
#define SE_SHA_CTRL_TRIG_1T (1 << 1)
#define SE_SHA_CTRL_BUSY (1 << 0)
#define SE_SHA_ENDIAN_DOUT_ENDIAN (1 << 0)
#define SE_SHA_CTRL_PROT_ID1_EN (1 << 2)
#define SE_SHA_CTRL_PROT_ID0_EN (1 << 1)
#define SE_SHA_CTRL_PROT_PROT_EN (1 << 0)
#define SE_AES_CTRL_MSG_LEN_SHIFT (16)
#define SE_AES_CTRL_MSG_LEN_MASK (0xffff << SE_AES_CTRL_MSG_LEN_SHIFT)
#define SE_AES_CTRL_LINK_MODE (1 << 15)
#define SE_AES_CTRL_IV_SEL (1 << 14)
#define SE_AES_CTRL_BLOCK_MODE_SHIFT (12)
#define SE_AES_CTRL_BLOCK_MODE_MASK (0x03 << SE_AES_CTRL_BLOCK_MODE_SHIFT)
#define SE_AES_CTRL_INT_MASK (1 << 11)
#define SE_AES_CTRL_INT_SET_1T (1 << 10)
#define SE_AES_CTRL_INT_CLR_1T (1 << 9)
#define SE_AES_CTRL_INT (1 << 8)
#define SE_AES_CTRL_HW_KEY_EN (1 << 7)
#define SE_AES_CTRL_DEC_KEY_SEL (1 << 6)
#define SE_AES_CTRL_DEC_EN (1 << 5)
#define SE_AES_CTRL_MODE_SHIFT (3)
#define SE_AES_CTRL_MODE_MASK (0x03 << SE_AES_CTRL_MODE_SHIFT)
#define SE_AES_CTRL_EN (1 << 2)
#define SE_AES_CTRL_TRIG_1T (1 << 1)
#define SE_AES_CTRL_BUSY (1 << 0)
#define SE_AES_KEY_SEL_0_MASK (0x03)
#define SE_AES_KEY_SEL_1_MASK (0x03)
#define SE_AES_ENDIAN_CTR_LEN_SHIFT (30)
#define SE_AES_ENDIAN_CTR_LEN_MASK (0x03 << SE_AES_ENDIAN_CTR_LEN_SHIFT)
#define SE_AES_ENDIAN_IV_ENDIAN (1 << 3)
#define SE_AES_ENDIAN_KEY_ENDIAN (1 << 2)
#define SE_AES_ENDIAN_DIN_ENDIAN (1 << 1)
#define SE_AES_ENDIAN_DOUT_ENDIAN (1 << 0)
#define SE_AES_SBOOT_SBOOT_KEY_SEL (1 << 0)
#define SE_AES_CTRL_PROT_ID1_EN (1 << 2)
#define SE_AES_CTRL_PROT_ID0_EN (1 << 1)
#define SE_AES_CTRL_PROT_PROT_EN (1 << 0)
#define SE_TRNG_CTRL_0_MANUAL_EN (1 << 15)
#define SE_TRNG_CTRL_0_MANUAL_RESEED (1 << 14)
#define SE_TRNG_CTRL_0_MANUAL_FUN_SEL (1 << 13)
#define SE_TRNG_CTRL_0_INT_MASK (1 << 11)
#define SE_TRNG_CTRL_0_INT_SET_1T (1 << 10)
#define SE_TRNG_CTRL_0_INT_CLR_1T (1 << 9)
#define SE_TRNG_CTRL_0_INT (1 << 8)
#define SE_TRNG_CTRL_0_HT_ERROR (1 << 4)
#define SE_TRNG_CTRL_0_DOUT_CLR_1T (1 << 3)
#define SE_TRNG_CTRL_0_EN (1 << 2)
#define SE_TRNG_CTRL_0_TRIG_1T (1 << 1)
#define SE_TRNG_CTRL_0_BUSY (1 << 0)
#define SE_TRNG_TEST_HT_ALARM_N_SHIFT (4)
#define SE_TRNG_TEST_HT_ALARM_N_MASK (0xff << SE_TRNG_TEST_HT_ALARM_N_SHIFT)
#define SE_TRNG_TEST_HT_DIS (1 << 3)
#define SE_TRNG_TEST_CP_BYPASS (1 << 2)
#define SE_TRNG_TEST_CP_TEST_EN (1 << 1)
#define SE_TRNG_TEST_TEST_EN (1 << 0)
#define SE_TRNG_CTRL_2_SERESEED_N_MSB_MASK (0xffff)
#define SE_TRNG_CTRL_3_ROSC_EN (1 << 31)
#define SE_TRNG_CTRL_3_HT_OD_EN (1 << 26)
#define SE_TRNG_CTRL_3_HT_APT_C_SHIFT (16)
#define SE_TRNG_CTRL_3_HT_APT_C_MASK (0x3ff << SE_TRNG_CTRL_3_HT_APT_C_SHIFT)
#define SE_TRNG_CTRL_3_HT_RCT_C_SHIFT (8)
#define SE_TRNG_CTRL_3_HT_RCT_C_MASK (0xff << SE_TRNG_CTRL_3_HT_RCT_C_SHIFT)
#define SE_TRNG_CTRL_3_CP_RATIO_MASK (0xff)
#define SE_TRNG_CTRL_PROT_ID1_EN (1 << 2)
#define SE_TRNG_CTRL_PROT_ID0_EN (1 << 1)
#define SE_TRNG_CTRL_PROT_PROT_EN (1 << 0)
#define SE_PKA_CTRL_0_STATUS_SHIFT (17)
#define SE_PKA_CTRL_0_STATUS_MASK (0x7fff << SE_PKA_CTRL_0_STATUS_SHIFT)
#define SE_PKA_CTRL_0_STATUS_CLR_1T (1 << 16)
#define SE_PKA_CTRL_0_RAM_CLR_MD (1 << 13)
#define SE_PKA_CTRL_0_ENDIAN (1 << 12)
#define SE_PKA_CTRL_0_INT_MASK (1 << 11)
#define SE_PKA_CTRL_0_INT_SET (1 << 10)
#define SE_PKA_CTRL_0_INT_CLR_1T (1 << 9)
#define SE_PKA_CTRL_0_INT (1 << 8)
#define SE_PKA_CTRL_0_PROT_MD_SHIFT (4)
#define SE_PKA_CTRL_0_PROT_MD_MASK (0x0f << SE_PKA_CTRL_0_PROT_MD_SHIFT)
#define SE_PKA_CTRL_0_EN (1 << 3)
#define SE_PKA_CTRL_0_BUSY (1 << 2)
#define SE_PKA_CTRL_0_DONE_CLR_1T (1 << 1)
#define SE_PKA_CTRL_0_DONE (1 << 0)
#define SE_PKA_CTRL_1_HBYPASS (1 << 3)
#define SE_PKA_CTRL_1_HBURST_MASK (0x07)
#define SE_PKA_CTRL_PROT_ID1_EN (1 << 2)
#define SE_PKA_CTRL_PROT_ID0_EN (1 << 1)
#define SE_PKA_CTRL_PROT_PROT_EN (1 << 0)
#define SE_CDET_CTRL_0_G_LOOP_MIN_SHIFT (24)
#define SE_CDET_CTRL_0_G_LOOP_MIN_MASK (0xff << SE_CDET_CTRL_0_G_LOOP_MIN_SHIFT)
#define SE_CDET_CTRL_0_G_LOOP_MAX_SHIFT (16)
#define SE_CDET_CTRL_0_G_LOOP_MAX_MASK (0xff << SE_CDET_CTRL_0_G_LOOP_MAX_SHIFT)
#define SE_CDET_CTRL_0_STATUS_SHIFT (2)
#define SE_CDET_CTRL_0_STATUS_MASK (0x3fff << SE_CDET_CTRL_0_STATUS_SHIFT)
#define SE_CDET_CTRL_0_ERROR (1 << 1)
#define SE_CDET_CTRL_0_EN (1 << 0)
#define SE_CDET_CTRL_1_G_SLP_N_SHIFT (16)
#define SE_CDET_CTRL_1_G_SLP_N_MASK (0xff << SE_CDET_CTRL_1_G_SLP_N_SHIFT)
#define SE_CDET_CTRL_1_T_DLY_N_SHIFT (8)
#define SE_CDET_CTRL_1_T_DLY_N_MASK (0xff << SE_CDET_CTRL_1_T_DLY_N_SHIFT)
#define SE_CDET_CTRL_1_T_LOOP_N_MASK (0xff)
#define SE_CDET_CTRL_PROT_ID1_EN (1 << 2)
#define SE_CDET_CTRL_PROT_ID0_EN (1 << 1)
#define SE_CDET_CTRL_PROT_PROT_EN (1 << 0)
#define SE_GMAC_CTRL_0_X_ENDIAN (1 << 14)
#define SE_GMAC_CTRL_0_H_ENDIAN (1 << 13)
#define SE_GMAC_CTRL_0_T_ENDIAN (1 << 12)
#define SE_GMAC_CTRL_0_INT_MASK (1 << 11)
#define SE_GMAC_CTRL_0_INT_SET_1T (1 << 10)
#define SE_GMAC_CTRL_0_INT_CLR_1T (1 << 9)
#define SE_GMAC_CTRL_0_INT (1 << 8)
#define SE_GMAC_CTRL_0_EN (1 << 2)
#define SE_GMAC_CTRL_0_TRIG_1T (1 << 1)
#define SE_GMAC_CTRL_0_BUSY (1 << 0)
#define SE_GMAC_CTRL_PROT_ID1_EN (1 << 2)
#define SE_GMAC_CTRL_PROT_ID0_EN (1 << 1)
#define SE_GMAC_CTRL_PROT_PROT_EN (1 << 0)
#define SE_CTRL_PROT_RD_DBG_DIS (1 << 31)
#define SE_CTRL_PROT_RD_GMAC_ID1_EN_RD (1 << 22)
#define SE_CTRL_PROT_RD_GMAC_ID0_EN_RD (1 << 21)
#define SE_CTRL_PROT_RD_GMAC_PROT_EN_RD (1 << 20)
#define SE_CTRL_PROT_RD_CDET_ID1_EN_RD (1 << 18)
#define SE_CTRL_PROT_RD_CDET_ID0_EN_RD (1 << 17)
#define SE_CTRL_PROT_RD_CDET_PROT_EN_RD (1 << 16)
#define SE_CTRL_PROT_RD_PKA_ID1_EN_RD (1 << 14)
#define SE_CTRL_PROT_RD_PKA_ID0_EN_RD (1 << 13)
#define SE_CTRL_PROT_RD_PKA_PROT_EN_RD (1 << 12)
#define SE_CTRL_PROT_RD_TRNG_ID1_EN_RD (1 << 10)
#define SE_CTRL_PROT_RD_TRNG_ID0_EN_RD (1 << 9)
#define SE_CTRL_PROT_RD_TRNG_PROT_EN_RD (1 << 8)
#define SE_CTRL_PROT_RD_AES_ID1_EN_RD (1 << 6)
#define SE_CTRL_PROT_RD_AES_ID0_EN_RD (1 << 5)
#define SE_CTRL_PROT_RD_AES_PROT_EN_RD (1 << 4)
#define SE_CTRL_PROT_RD_SHA_ID1_EN_RD (1 << 2)
#define SE_CTRL_PROT_RD_SHA_ID0_EN_RD (1 << 1)
#define SE_CTRL_PROT_RD_SHA_PROT_EN_RD (1 << 0)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_SEC_H */

View File

@ -0,0 +1,449 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_sf.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_SF_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_SF_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_SF_0_OFFSET 0x000000 /* sf_ctrl_0 */
#define BL602_SF_1_OFFSET 0x000004 /* sf_ctrl_1 */
#define BL602_SF_IF_SAHB_0_OFFSET 0x000008 /* sf_if_sahb_0 */
#define BL602_SF_IF_SAHB_1_OFFSET 0x00000c /* sf_if_sahb_1 */
#define BL602_SF_IF_SAHB_2_OFFSET 0x000010 /* sf_if_sahb_2 */
#define BL602_SF_IF_IAHB_0_OFFSET 0x000014 /* sf_if_iahb_0 */
#define BL602_SF_IF_IAHB_1_OFFSET 0x000018 /* sf_if_iahb_1 */
#define BL602_SF_IF_IAHB_2_OFFSET 0x00001c /* sf_if_iahb_2 */
#define BL602_SF_IF_STATUS_0_OFFSET 0x000020 /* sf_if_status_0 */
#define BL602_SF_IF_STATUS_1_OFFSET 0x000024 /* sf_if_status_1 */
#define BL602_SF_AES_OFFSET 0x000028 /* sf_aes */
#define BL602_SF_AHB2SIF_STATUS_OFFSET 0x00002c /* sf_ahb2sif_status */
#define BL602_SF_IF_IO_DLY_0_OFFSET 0x000030 /* sf_if_io_dly_0 */
#define BL602_SF_IF_IO_DLY_1_OFFSET 0x000034 /* sf_if_io_dly_1 */
#define BL602_SF_IF_IO_DLY_2_OFFSET 0x000038 /* sf_if_io_dly_2 */
#define BL602_SF_IF_IO_DLY_3_OFFSET 0x00003c /* sf_if_io_dly_3 */
#define BL602_SF_IF_IO_DLY_4_OFFSET 0x000040 /* sf_if_io_dly_4 */
#define BL602_SF_RESERVED_OFFSET 0x000044 /* sf_reserved */
#define BL602_SF2_IF_IO_DLY_0_OFFSET 0x000048 /* sf2_if_io_dly_0 */
#define BL602_SF2_IF_IO_DLY_1_OFFSET 0x00004c /* sf2_if_io_dly_1 */
#define BL602_SF2_IF_IO_DLY_2_OFFSET 0x000050 /* sf2_if_io_dly_2 */
#define BL602_SF2_IF_IO_DLY_3_OFFSET 0x000054 /* sf2_if_io_dly_3 */
#define BL602_SF2_IF_IO_DLY_4_OFFSET 0x000058 /* sf2_if_io_dly_4 */
#define BL602_SF3_IF_IO_DLY_0_OFFSET 0x00005c /* sf3_if_io_dly_0 */
#define BL602_SF3_IF_IO_DLY_1_OFFSET 0x000060 /* sf3_if_io_dly_1 */
#define BL602_SF3_IF_IO_DLY_2_OFFSET 0x000064 /* sf3_if_io_dly_2 */
#define BL602_SF3_IF_IO_DLY_3_OFFSET 0x000068 /* sf3_if_io_dly_3 */
#define BL602_SF3_IF_IO_DLY_4_OFFSET 0x00006c /* sf3_if_io_dly_4 */
#define BL602_SF_2_OFFSET 0x000070 /* sf_ctrl_2 */
#define BL602_SF_3_OFFSET 0x000074 /* sf_ctrl_3 */
#define BL602_SF_IF_IAHB_3_OFFSET 0x000078 /* sf_if_iahb_3 */
#define BL602_SF_IF_IAHB_4_OFFSET 0x00007c /* sf_if_iahb_4 */
#define BL602_SF_IF_IAHB_5_OFFSET 0x000080 /* sf_if_iahb_5 */
#define BL602_SF_IF_IAHB_6_OFFSET 0x000084 /* sf_if_iahb_6 */
#define BL602_SF_IF_IAHB_7_OFFSET 0x000088 /* sf_if_iahb_7 */
#define BL602_SF_PROT_EN_RD_OFFSET 0x000100 /* sf_ctrl_prot_en_rd */
#define BL602_SF_PROT_EN_OFFSET 0x000104 /* sf_ctrl_prot_en */
#define BL602_SF_AES_KEY_R0_0_OFFSET 0x000200 /* sf_aes_key_r0_0 */
#define BL602_SF_AES_KEY_R0_1_OFFSET 0x000204 /* sf_aes_key_r0_1 */
#define BL602_SF_AES_KEY_R0_2_OFFSET 0x000208 /* sf_aes_key_r0_2 */
#define BL602_SF_AES_KEY_R0_3_OFFSET 0x00020c /* sf_aes_key_r0_3 */
#define BL602_SF_AES_KEY_R0_4_OFFSET 0x000210 /* sf_aes_key_r0_4 */
#define BL602_SF_AES_KEY_R0_5_OFFSET 0x000214 /* sf_aes_key_r0_5 */
#define BL602_SF_AES_KEY_R0_6_OFFSET 0x000218 /* sf_aes_key_r0_6 */
#define BL602_SF_AES_KEY_R0_7_OFFSET 0x00021c /* sf_aes_key_r0_7 */
#define BL602_SF_AES_IV_R0_W0_OFFSET 0x000220 /* sf_aes_iv_r0_w0 */
#define BL602_SF_AES_IV_R0_W1_OFFSET 0x000224 /* sf_aes_iv_r0_w1 */
#define BL602_SF_AES_IV_R0_W2_OFFSET 0x000228 /* sf_aes_iv_r0_w2 */
#define BL602_SF_AES_IV_R0_W3_OFFSET 0x00022c /* sf_aes_iv_r0_w3 */
#define BL602_SF_AES_CFG_R0_OFFSET 0x000230 /* sf_aes_cfg_r0 */
#define BL602_SF_AES_KEY_R1_0_OFFSET 0x000300 /* sf_aes_key_r1_0 */
#define BL602_SF_AES_KEY_R1_1_OFFSET 0x000304 /* sf_aes_key_r1_1 */
#define BL602_SF_AES_KEY_R1_2_OFFSET 0x000308 /* sf_aes_key_r1_2 */
#define BL602_SF_AES_KEY_R1_3_OFFSET 0x00030c /* sf_aes_key_r1_3 */
#define BL602_SF_AES_KEY_R1_4_OFFSET 0x000310 /* sf_aes_key_r1_4 */
#define BL602_SF_AES_KEY_R1_5_OFFSET 0x000314 /* sf_aes_key_r1_5 */
#define BL602_SF_AES_KEY_R1_6_OFFSET 0x000318 /* sf_aes_key_r1_6 */
#define BL602_SF_AES_KEY_R1_7_OFFSET 0x00031c /* sf_aes_key_r1_7 */
#define BL602_SF_AES_IV_R1_W0_OFFSET 0x000320 /* sf_aes_iv_r1_w0 */
#define BL602_SF_AES_IV_R1_W1_OFFSET 0x000324 /* sf_aes_iv_r1_w1 */
#define BL602_SF_AES_IV_R1_W2_OFFSET 0x000328 /* sf_aes_iv_r1_w2 */
#define BL602_SF_AES_IV_R1_W3_OFFSET 0x00032c /* sf_aes_iv_r1_w3 */
#define BL602_SF_AES_R1_OFFSET 0x000330 /* sf_aes_r1 */
#define BL602_SF_AES_KEY_R2_0_OFFSET 0x000400 /* sf_aes_key_r2_0 */
#define BL602_SF_AES_KEY_R2_1_OFFSET 0x000404 /* sf_aes_key_r2_1 */
#define BL602_SF_AES_KEY_R2_2_OFFSET 0x000408 /* sf_aes_key_r2_2 */
#define BL602_SF_AES_KEY_R2_3_OFFSET 0x00040c /* sf_aes_key_r2_3 */
#define BL602_SF_AES_KEY_R2_4_OFFSET 0x000410 /* sf_aes_key_r2_4 */
#define BL602_SF_AES_KEY_R2_5_OFFSET 0x000414 /* sf_aes_key_r2_5 */
#define BL602_SF_AES_KEY_R2_6_OFFSET 0x000418 /* sf_aes_key_r2_6 */
#define BL602_SF_AES_KEY_R2_7_OFFSET 0x00041c /* sf_aes_key_r2_7 */
#define BL602_SF_AES_IV_R2_W0_OFFSET 0x000420 /* sf_aes_iv_r2_w0 */
#define BL602_SF_AES_IV_R2_W1_OFFSET 0x000424 /* sf_aes_iv_r2_w1 */
#define BL602_SF_AES_IV_R2_W2_OFFSET 0x000428 /* sf_aes_iv_r2_w2 */
#define BL602_SF_AES_IV_R2_W3_OFFSET 0x00042c /* sf_aes_iv_r2_w3 */
#define BL602_SF_AES_R2_OFFSET 0x000430 /* sf_aes_r2 */
#define BL602_SF_ID0_OFFSET_OFFSET 0x000434 /* sf_id0_offset */
#define BL602_SF_ID1_OFFSET_OFFSET 0x000438 /* sf_id1_offset */
/* Register definitions *****************************************************/
#define BL602_SF_0 (BL602_SF_BASE + BL602_SF_0_OFFSET)
#define BL602_SF_1 (BL602_SF_BASE + BL602_SF_1_OFFSET)
#define BL602_SF_IF_SAHB_0 (BL602_SF_BASE + BL602_SF_IF_SAHB_0_OFFSET)
#define BL602_SF_IF_SAHB_1 (BL602_SF_BASE + BL602_SF_IF_SAHB_1_OFFSET)
#define BL602_SF_IF_SAHB_2 (BL602_SF_BASE + BL602_SF_IF_SAHB_2_OFFSET)
#define BL602_SF_IF_IAHB_0 (BL602_SF_BASE + BL602_SF_IF_IAHB_0_OFFSET)
#define BL602_SF_IF_IAHB_1 (BL602_SF_BASE + BL602_SF_IF_IAHB_1_OFFSET)
#define BL602_SF_IF_IAHB_2 (BL602_SF_BASE + BL602_SF_IF_IAHB_2_OFFSET)
#define BL602_SF_IF_STATUS_0 (BL602_SF_BASE + BL602_SF_IF_STATUS_0_OFFSET)
#define BL602_SF_IF_STATUS_1 (BL602_SF_BASE + BL602_SF_IF_STATUS_1_OFFSET)
#define BL602_SF_AES (BL602_SF_BASE + BL602_SF_AES_OFFSET)
#define BL602_SF_AHB2SIF_STATUS (BL602_SF_BASE + BL602_SF_AHB2SIF_STATUS_OFFSET)
#define BL602_SF_IF_IO_DLY_0 (BL602_SF_BASE + BL602_SF_IF_IO_DLY_0_OFFSET)
#define BL602_SF_IF_IO_DLY_1 (BL602_SF_BASE + BL602_SF_IF_IO_DLY_1_OFFSET)
#define BL602_SF_IF_IO_DLY_2 (BL602_SF_BASE + BL602_SF_IF_IO_DLY_2_OFFSET)
#define BL602_SF_IF_IO_DLY_3 (BL602_SF_BASE + BL602_SF_IF_IO_DLY_3_OFFSET)
#define BL602_SF_IF_IO_DLY_4 (BL602_SF_BASE + BL602_SF_IF_IO_DLY_4_OFFSET)
#define BL602_SF_RESERVED (BL602_SF_BASE + BL602_SF_RESERVED_OFFSET)
#define BL602_SF2_IF_IO_DLY_0 (BL602_SF_BASE + BL602_SF2_IF_IO_DLY_0_OFFSET)
#define BL602_SF2_IF_IO_DLY_1 (BL602_SF_BASE + BL602_SF2_IF_IO_DLY_1_OFFSET)
#define BL602_SF2_IF_IO_DLY_2 (BL602_SF_BASE + BL602_SF2_IF_IO_DLY_2_OFFSET)
#define BL602_SF2_IF_IO_DLY_3 (BL602_SF_BASE + BL602_SF2_IF_IO_DLY_3_OFFSET)
#define BL602_SF2_IF_IO_DLY_4 (BL602_SF_BASE + BL602_SF2_IF_IO_DLY_4_OFFSET)
#define BL602_SF3_IF_IO_DLY_0 (BL602_SF_BASE + BL602_SF3_IF_IO_DLY_0_OFFSET)
#define BL602_SF3_IF_IO_DLY_1 (BL602_SF_BASE + BL602_SF3_IF_IO_DLY_1_OFFSET)
#define BL602_SF3_IF_IO_DLY_2 (BL602_SF_BASE + BL602_SF3_IF_IO_DLY_2_OFFSET)
#define BL602_SF3_IF_IO_DLY_3 (BL602_SF_BASE + BL602_SF3_IF_IO_DLY_3_OFFSET)
#define BL602_SF3_IF_IO_DLY_4 (BL602_SF_BASE + BL602_SF3_IF_IO_DLY_4_OFFSET)
#define BL602_SF_2 (BL602_SF_BASE + BL602_SF_2_OFFSET)
#define BL602_SF_3 (BL602_SF_BASE + BL602_SF_3_OFFSET)
#define BL602_SF_IF_IAHB_3 (BL602_SF_BASE + BL602_SF_IF_IAHB_3_OFFSET)
#define BL602_SF_IF_IAHB_4 (BL602_SF_BASE + BL602_SF_IF_IAHB_4_OFFSET)
#define BL602_SF_IF_IAHB_5 (BL602_SF_BASE + BL602_SF_IF_IAHB_5_OFFSET)
#define BL602_SF_IF_IAHB_6 (BL602_SF_BASE + BL602_SF_IF_IAHB_6_OFFSET)
#define BL602_SF_IF_IAHB_7 (BL602_SF_BASE + BL602_SF_IF_IAHB_7_OFFSET)
#define BL602_SF_PROT_EN_RD (BL602_SF_BASE + BL602_SF_PROT_EN_RD_OFFSET)
#define BL602_SF_PROT_EN (BL602_SF_BASE + BL602_SF_PROT_EN_OFFSET)
#define BL602_SF_AES_KEY_R0_0 (BL602_SF_BASE + BL602_SF_AES_KEY_R0_0_OFFSET)
#define BL602_SF_AES_KEY_R0_1 (BL602_SF_BASE + BL602_SF_AES_KEY_R0_1_OFFSET)
#define BL602_SF_AES_KEY_R0_2 (BL602_SF_BASE + BL602_SF_AES_KEY_R0_2_OFFSET)
#define BL602_SF_AES_KEY_R0_3 (BL602_SF_BASE + BL602_SF_AES_KEY_R0_3_OFFSET)
#define BL602_SF_AES_KEY_R0_4 (BL602_SF_BASE + BL602_SF_AES_KEY_R0_4_OFFSET)
#define BL602_SF_AES_KEY_R0_5 (BL602_SF_BASE + BL602_SF_AES_KEY_R0_5_OFFSET)
#define BL602_SF_AES_KEY_R0_6 (BL602_SF_BASE + BL602_SF_AES_KEY_R0_6_OFFSET)
#define BL602_SF_AES_KEY_R0_7 (BL602_SF_BASE + BL602_SF_AES_KEY_R0_7_OFFSET)
#define BL602_SF_AES_IV_R0_W0 (BL602_SF_BASE + BL602_SF_AES_IV_R0_W0_OFFSET)
#define BL602_SF_AES_IV_R0_W1 (BL602_SF_BASE + BL602_SF_AES_IV_R0_W1_OFFSET)
#define BL602_SF_AES_IV_R0_W2 (BL602_SF_BASE + BL602_SF_AES_IV_R0_W2_OFFSET)
#define BL602_SF_AES_IV_R0_W3 (BL602_SF_BASE + BL602_SF_AES_IV_R0_W3_OFFSET)
#define BL602_SF_AES_CFG_R0 (BL602_SF_BASE + BL602_SF_AES_CFG_R0_OFFSET)
#define BL602_SF_AES_KEY_R1_0 (BL602_SF_BASE + BL602_SF_AES_KEY_R1_0_OFFSET)
#define BL602_SF_AES_KEY_R1_1 (BL602_SF_BASE + BL602_SF_AES_KEY_R1_1_OFFSET)
#define BL602_SF_AES_KEY_R1_2 (BL602_SF_BASE + BL602_SF_AES_KEY_R1_2_OFFSET)
#define BL602_SF_AES_KEY_R1_3 (BL602_SF_BASE + BL602_SF_AES_KEY_R1_3_OFFSET)
#define BL602_SF_AES_KEY_R1_4 (BL602_SF_BASE + BL602_SF_AES_KEY_R1_4_OFFSET)
#define BL602_SF_AES_KEY_R1_5 (BL602_SF_BASE + BL602_SF_AES_KEY_R1_5_OFFSET)
#define BL602_SF_AES_KEY_R1_6 (BL602_SF_BASE + BL602_SF_AES_KEY_R1_6_OFFSET)
#define BL602_SF_AES_KEY_R1_7 (BL602_SF_BASE + BL602_SF_AES_KEY_R1_7_OFFSET)
#define BL602_SF_AES_IV_R1_W0 (BL602_SF_BASE + BL602_SF_AES_IV_R1_W0_OFFSET)
#define BL602_SF_AES_IV_R1_W1 (BL602_SF_BASE + BL602_SF_AES_IV_R1_W1_OFFSET)
#define BL602_SF_AES_IV_R1_W2 (BL602_SF_BASE + BL602_SF_AES_IV_R1_W2_OFFSET)
#define BL602_SF_AES_IV_R1_W3 (BL602_SF_BASE + BL602_SF_AES_IV_R1_W3_OFFSET)
#define BL602_SF_AES_R1 (BL602_SF_BASE + BL602_SF_AES_R1_OFFSET)
#define BL602_SF_AES_KEY_R2_0 (BL602_SF_BASE + BL602_SF_AES_KEY_R2_0_OFFSET)
#define BL602_SF_AES_KEY_R2_1 (BL602_SF_BASE + BL602_SF_AES_KEY_R2_1_OFFSET)
#define BL602_SF_AES_KEY_R2_2 (BL602_SF_BASE + BL602_SF_AES_KEY_R2_2_OFFSET)
#define BL602_SF_AES_KEY_R2_3 (BL602_SF_BASE + BL602_SF_AES_KEY_R2_3_OFFSET)
#define BL602_SF_AES_KEY_R2_4 (BL602_SF_BASE + BL602_SF_AES_KEY_R2_4_OFFSET)
#define BL602_SF_AES_KEY_R2_5 (BL602_SF_BASE + BL602_SF_AES_KEY_R2_5_OFFSET)
#define BL602_SF_AES_KEY_R2_6 (BL602_SF_BASE + BL602_SF_AES_KEY_R2_6_OFFSET)
#define BL602_SF_AES_KEY_R2_7 (BL602_SF_BASE + BL602_SF_AES_KEY_R2_7_OFFSET)
#define BL602_SF_AES_IV_R2_W0 (BL602_SF_BASE + BL602_SF_AES_IV_R2_W0_OFFSET)
#define BL602_SF_AES_IV_R2_W1 (BL602_SF_BASE + BL602_SF_AES_IV_R2_W1_OFFSET)
#define BL602_SF_AES_IV_R2_W2 (BL602_SF_BASE + BL602_SF_AES_IV_R2_W2_OFFSET)
#define BL602_SF_AES_IV_R2_W3 (BL602_SF_BASE + BL602_SF_AES_IV_R2_W3_OFFSET)
#define BL602_SF_AES_R2 (BL602_SF_BASE + BL602_SF_AES_R2_OFFSET)
#define BL602_SF_ID0_OFFSET (BL602_SF_BASE + BL602_SF_ID0_OFFSET_OFFSET)
#define BL602_SF_ID1_OFFSET (BL602_SF_BASE + BL602_SF_ID1_OFFSET_OFFSET)
/* Register bit definitions *************************************************/
#define SF_0_SF_ID_SHIFT (24)
#define SF_0_SF_ID_MASK (0xff << SF_0_SF_ID_SHIFT)
#define SF_0_SF_AES_IV_ENDIAN (1 << 23)
#define SF_0_SF_AES_KEY_ENDIAN (1 << 22)
#define SF_0_SF_AES_CTR_PLUS_EN (1 << 21)
#define SF_0_SF_AES_DOUT_ENDIAN (1 << 20)
#define SF_0_SF_AES_DLY_MODE (1 << 19)
#define SF_0_SF_IF_INT_SET (1 << 18)
#define SF_0_SF_IF_INT_CLR (1 << 17)
#define SF_0_SF_IF_INT (1 << 16)
#define SF_0_SF_IF_READ_DLY_EN (1 << 11)
#define SF_0_SF_IF_READ_DLY_N_SHIFT (8)
#define SF_0_SF_IF_READ_DLY_N_MASK (0x07 << SF_0_SF_IF_READ_DLY_N_SHIFT)
#define SF_0_SF_CLK_SAHB_SRAM_SEL (1 << 5)
#define SF_0_SF_CLK_OUT_INV_SEL (1 << 4)
#define SF_0_SF_CLK_OUT_GATE_EN (1 << 3)
#define SF_0_SF_CLK_SF_RX_INV_SEL (1 << 2)
#define SF_1_SF_AHB2SRAM_EN (1 << 31)
#define SF_1_SF_AHB2SIF_EN (1 << 30)
#define SF_1_IF_EN (1 << 29)
#define SF_1_IF_FN_SEL (1 << 28)
#define SF_1_SF_AHB2SIF_STOP (1 << 27)
#define SF_1_SF_AHB2SIF_STOPPED (1 << 26)
#define SF_1_IF_REG_WP (1 << 25)
#define SF_1_IF_REG_HOLD (1 << 24)
#define SF_1_IF_0_ACK_LAT_SHIFT (20)
#define SF_1_IF_0_ACK_LAT_MASK (0x07 << SF_1_IF_0_ACK_LAT_SHIFT)
#define SF_1_IF_SR_INT_SET (1 << 18)
#define SF_1_IF_SR_INT_EN (1 << 17)
#define SF_1_IF_SR_INT (1 << 16)
#define SF_1_IF_SR_PAT_SHIFT (8)
#define SF_1_IF_SR_PAT_MASK (0xff << SF_1_IF_SR_PAT_SHIFT)
#define SF_1_IF_SR_PAT_MASK_MASK (0xff)
#define SF_IF_SAHB_0_SF_IF_0_QPI_MODE_EN (1 << 31)
#define SF_IF_SAHB_0_SF_IF_0_SPI_MODE_SHIFT (28)
#define SF_IF_SAHB_0_SF_IF_0_SPI_MODE_MASK (0x07 << SF_IF_SAHB_0_SF_IF_0_SPI_MODE_SHIFT)
#define SF_IF_SAHB_0_SF_IF_0_CMD_EN (1 << 27)
#define SF_IF_SAHB_0_SF_IF_0_ADR_EN (1 << 26)
#define SF_IF_SAHB_0_SF_IF_0_DMY_EN (1 << 25)
#define SF_IF_SAHB_0_SF_IF_0_DAT_EN (1 << 24)
#define SF_IF_SAHB_0_SF_IF_0_DAT_RW (1 << 23)
#define SF_IF_SAHB_0_SF_IF_0_CMD_BYTE_SHIFT (20)
#define SF_IF_SAHB_0_SF_IF_0_CMD_BYTE_MASK (0x07 << SF_IF_SAHB_0_SF_IF_0_CMD_BYTE_SHIFT)
#define SF_IF_SAHB_0_SF_IF_0_ADR_BYTE_SHIFT (17)
#define SF_IF_SAHB_0_SF_IF_0_ADR_BYTE_MASK (0x07 << SF_IF_SAHB_0_SF_IF_0_ADR_BYTE_SHIFT)
#define SF_IF_SAHB_0_SF_IF_0_DMY_BYTE_SHIFT (12)
#define SF_IF_SAHB_0_SF_IF_0_DMY_BYTE_MASK (0x1f << SF_IF_SAHB_0_SF_IF_0_DMY_BYTE_SHIFT)
#define SF_IF_SAHB_0_SF_IF_0_DAT_BYTE_SHIFT (2)
#define SF_IF_SAHB_0_SF_IF_0_DAT_BYTE_MASK (0x3ff << SF_IF_SAHB_0_SF_IF_0_DAT_BYTE_SHIFT)
#define SF_IF_SAHB_0_SF_IF_0_TRIG (1 << 1)
#define SF_IF_SAHB_0_SF_IF_BUSY (1 << 0)
#define SF_IF_IAHB_0_SF_IF_1_QPI_MODE_EN (1 << 31)
#define SF_IF_IAHB_0_SF_IF_1_SPI_MODE_SHIFT (28)
#define SF_IF_IAHB_0_SF_IF_1_SPI_MODE_MASK (0x07 << SF_IF_IAHB_0_SF_IF_1_SPI_MODE_SHIFT)
#define SF_IF_IAHB_0_SF_IF_1_CMD_EN (1 << 27)
#define SF_IF_IAHB_0_SF_IF_1_ADR_EN (1 << 26)
#define SF_IF_IAHB_0_SF_IF_1_DMY_EN (1 << 25)
#define SF_IF_IAHB_0_SF_IF_1_DAT_EN (1 << 24)
#define SF_IF_IAHB_0_SF_IF_1_DAT_RW (1 << 23)
#define SF_IF_IAHB_0_SF_IF_1_CMD_BYTE_SHIFT (20)
#define SF_IF_IAHB_0_SF_IF_1_CMD_BYTE_MASK (0x07 << SF_IF_IAHB_0_SF_IF_1_CMD_BYTE_SHIFT)
#define SF_IF_IAHB_0_SF_IF_1_ADR_BYTE_SHIFT (17)
#define SF_IF_IAHB_0_SF_IF_1_ADR_BYTE_MASK (0x07 << SF_IF_IAHB_0_SF_IF_1_ADR_BYTE_SHIFT)
#define SF_IF_IAHB_0_SF_IF_1_DMY_BYTE_SHIFT (12)
#define SF_IF_IAHB_0_SF_IF_1_DMY_BYTE_MASK (0x1f << SF_IF_IAHB_0_SF_IF_1_DMY_BYTE_SHIFT)
#define SF_AES_SF_AES_STATUS_SHIFT (5)
#define SF_AES_SF_AES_STATUS_MASK (0x7ffffff << SF_AES_SF_AES_STATUS_SHIFT)
#define SF_AES_SF_AES_PREF_BUSY (1 << 4)
#define SF_AES_SF_AES_PREF_TRIG (1 << 3)
#define SF_AES_SF_AES_MODE_SHIFT (1)
#define SF_AES_SF_AES_MODE_MASK (0x03 << SF_AES_SF_AES_MODE_SHIFT)
#define SF_AES_SF_AES_EN (1 << 0)
#define SF_IF_IO_DLY_0_SF_DQS_DO_DLY_SEL_SHIFT (30)
#define SF_IF_IO_DLY_0_SF_DQS_DO_DLY_SEL_MASK (0x03 << SF_IF_IO_DLY_0_SF_DQS_DO_DLY_SEL_SHIFT)
#define SF_IF_IO_DLY_0_SF_DQS_DI_DLY_SEL_SHIFT (28)
#define SF_IF_IO_DLY_0_SF_DQS_DI_DLY_SEL_MASK (0x03 << SF_IF_IO_DLY_0_SF_DQS_DI_DLY_SEL_SHIFT)
#define SF_IF_IO_DLY_0_SF_DQS_OE_DLY_SEL_SHIFT (26)
#define SF_IF_IO_DLY_0_SF_DQS_OE_DLY_SEL_MASK (0x03 << SF_IF_IO_DLY_0_SF_DQS_OE_DLY_SEL_SHIFT)
#define SF_IF_IO_DLY_0_SF_CLK_OUT_DLY_SEL_SHIFT (8)
#define SF_IF_IO_DLY_0_SF_CLK_OUT_DLY_SEL_MASK (0x03 << SF_IF_IO_DLY_0_SF_CLK_OUT_DLY_SEL_SHIFT)
#define SF_IF_IO_DLY_0_SF_CS_DLY_SEL_MASK (0x03)
#define SF_IF_IO_DLY_1_SF_IO_0_DO_DLY_SEL_SHIFT (16)
#define SF_IF_IO_DLY_1_SF_IO_0_DO_DLY_SEL_MASK (0x03 << SF_IF_IO_DLY_1_SF_IO_0_DO_DLY_SEL_SHIFT)
#define SF_IF_IO_DLY_1_SF_IO_0_DI_DLY_SEL_SHIFT (8)
#define SF_IF_IO_DLY_1_SF_IO_0_DI_DLY_SEL_MASK (0x03 << SF_IF_IO_DLY_1_SF_IO_0_DI_DLY_SEL_SHIFT)
#define SF_IF_IO_DLY_1_SF_IO_0_OE_DLY_SEL_MASK (0x03)
#define SF_IF_IO_DLY_2_SF_IO_1_DO_DLY_SEL_SHIFT (16)
#define SF_IF_IO_DLY_2_SF_IO_1_DO_DLY_SEL_MASK (0x03 << SF_IF_IO_DLY_2_SF_IO_1_DO_DLY_SEL_SHIFT)
#define SF_IF_IO_DLY_2_SF_IO_1_DI_DLY_SEL_SHIFT (8)
#define SF_IF_IO_DLY_2_SF_IO_1_DI_DLY_SEL_MASK (0x03 << SF_IF_IO_DLY_2_SF_IO_1_DI_DLY_SEL_SHIFT)
#define SF_IF_IO_DLY_2_SF_IO_1_OE_DLY_SEL_MASK (0x03)
#define SF_IF_IO_DLY_3_SF_IO_2_DO_DLY_SEL_SHIFT (16)
#define SF_IF_IO_DLY_3_SF_IO_2_DO_DLY_SEL_MASK (0x03 << SF_IF_IO_DLY_3_SF_IO_2_DO_DLY_SEL_SHIFT)
#define SF_IF_IO_DLY_3_SF_IO_2_DI_DLY_SEL_SHIFT (8)
#define SF_IF_IO_DLY_3_SF_IO_2_DI_DLY_SEL_MASK (0x03 << SF_IF_IO_DLY_3_SF_IO_2_DI_DLY_SEL_SHIFT)
#define SF_IF_IO_DLY_3_SF_IO_2_OE_DLY_SEL_MASK (0x03)
#define SF_IF_IO_DLY_4_SF_IO_3_DO_DLY_SEL_SHIFT (16)
#define SF_IF_IO_DLY_4_SF_IO_3_DO_DLY_SEL_MASK (0x03 << SF_IF_IO_DLY_4_SF_IO_3_DO_DLY_SEL_SHIFT)
#define SF_IF_IO_DLY_4_SF_IO_3_DI_DLY_SEL_SHIFT (8)
#define SF_IF_IO_DLY_4_SF_IO_3_DI_DLY_SEL_MASK (0x03 << SF_IF_IO_DLY_4_SF_IO_3_DI_DLY_SEL_SHIFT)
#define SF_IF_IO_DLY_4_SF_IO_3_OE_DLY_SEL_MASK (0x03)
#define SF2_IF_IO_DLY_0_SF2_DQS_DO_DLY_SEL_SHIFT (30)
#define SF2_IF_IO_DLY_0_SF2_DQS_DO_DLY_SEL_MASK (0x03 << SF2_IF_IO_DLY_0_SF2_DQS_DO_DLY_SEL_SHIFT)
#define SF2_IF_IO_DLY_0_SF2_DQS_DI_DLY_SEL_SHIFT (28)
#define SF2_IF_IO_DLY_0_SF2_DQS_DI_DLY_SEL_MASK (0x03 << SF2_IF_IO_DLY_0_SF2_DQS_DI_DLY_SEL_SHIFT)
#define SF2_IF_IO_DLY_0_SF2_DQS_OE_DLY_SEL_SHIFT (26)
#define SF2_IF_IO_DLY_0_SF2_DQS_OE_DLY_SEL_MASK (0x03 << SF2_IF_IO_DLY_0_SF2_DQS_OE_DLY_SEL_SHIFT)
#define SF2_IF_IO_DLY_0_SF2_CLK_OUT_DLY_SEL_SHIFT (8)
#define SF2_IF_IO_DLY_0_SF2_CLK_OUT_DLY_SEL_MASK (0x03 << SF2_IF_IO_DLY_0_SF2_CLK_OUT_DLY_SEL_SHIFT)
#define SF2_IF_IO_DLY_0_SF2_CS_DLY_SEL_MASK (0x03)
#define SF2_IF_IO_DLY_1_SF2_IO_0_DO_DLY_SEL_SHIFT (16)
#define SF2_IF_IO_DLY_1_SF2_IO_0_DO_DLY_SEL_MASK (0x03 << SF2_IF_IO_DLY_1_SF2_IO_0_DO_DLY_SEL_SHIFT)
#define SF2_IF_IO_DLY_1_SF2_IO_0_DI_DLY_SEL_SHIFT (8)
#define SF2_IF_IO_DLY_1_SF2_IO_0_DI_DLY_SEL_MASK (0x03 << SF2_IF_IO_DLY_1_SF2_IO_0_DI_DLY_SEL_SHIFT)
#define SF2_IF_IO_DLY_1_SF2_IO_0_OE_DLY_SEL_MASK (0x03)
#define SF2_IF_IO_DLY_2_SF2_IO_1_DO_DLY_SEL_SHIFT (16)
#define SF2_IF_IO_DLY_2_SF2_IO_1_DO_DLY_SEL_MASK (0x03 << SF2_IF_IO_DLY_2_SF2_IO_1_DO_DLY_SEL_SHIFT)
#define SF2_IF_IO_DLY_2_SF2_IO_1_DI_DLY_SEL_SHIFT (8)
#define SF2_IF_IO_DLY_2_SF2_IO_1_DI_DLY_SEL_MASK (0x03 << SF2_IF_IO_DLY_2_SF2_IO_1_DI_DLY_SEL_SHIFT)
#define SF2_IF_IO_DLY_2_SF2_IO_1_OE_DLY_SEL_MASK (0x03)
#define SF2_IF_IO_DLY_3_SF2_IO_2_DO_DLY_SEL_SHIFT (16)
#define SF2_IF_IO_DLY_3_SF2_IO_2_DO_DLY_SEL_MASK (0x03 << SF2_IF_IO_DLY_3_SF2_IO_2_DO_DLY_SEL_SHIFT)
#define SF2_IF_IO_DLY_3_SF2_IO_2_DI_DLY_SEL_SHIFT (8)
#define SF2_IF_IO_DLY_3_SF2_IO_2_DI_DLY_SEL_MASK (0x03 << SF2_IF_IO_DLY_3_SF2_IO_2_DI_DLY_SEL_SHIFT)
#define SF2_IF_IO_DLY_3_SF2_IO_2_OE_DLY_SEL_MASK (0x03)
#define SF2_IF_IO_DLY_4_SF2_IO_3_DO_DLY_SEL_SHIFT (16)
#define SF2_IF_IO_DLY_4_SF2_IO_3_DO_DLY_SEL_MASK (0x03 << SF2_IF_IO_DLY_4_SF2_IO_3_DO_DLY_SEL_SHIFT)
#define SF2_IF_IO_DLY_4_SF2_IO_3_DI_DLY_SEL_SHIFT (8)
#define SF2_IF_IO_DLY_4_SF2_IO_3_DI_DLY_SEL_MASK (0x03 << SF2_IF_IO_DLY_4_SF2_IO_3_DI_DLY_SEL_SHIFT)
#define SF2_IF_IO_DLY_4_SF2_IO_3_OE_DLY_SEL_MASK (0x03)
#define SF3_IF_IO_DLY_0_SF3_DQS_DO_DLY_SEL_SHIFT (30)
#define SF3_IF_IO_DLY_0_SF3_DQS_DO_DLY_SEL_MASK (0x03 << SF3_IF_IO_DLY_0_SF3_DQS_DO_DLY_SEL_SHIFT)
#define SF3_IF_IO_DLY_0_SF3_DQS_DI_DLY_SEL_SHIFT (28)
#define SF3_IF_IO_DLY_0_SF3_DQS_DI_DLY_SEL_MASK (0x03 << SF3_IF_IO_DLY_0_SF3_DQS_DI_DLY_SEL_SHIFT)
#define SF3_IF_IO_DLY_0_SF3_DQS_OE_DLY_SEL_SHIFT (26)
#define SF3_IF_IO_DLY_0_SF3_DQS_OE_DLY_SEL_MASK (0x03 << SF3_IF_IO_DLY_0_SF3_DQS_OE_DLY_SEL_SHIFT)
#define SF3_IF_IO_DLY_0_SF3_CLK_OUT_DLY_SEL_SHIFT (8)
#define SF3_IF_IO_DLY_0_SF3_CLK_OUT_DLY_SEL_MASK (0x03 << SF3_IF_IO_DLY_0_SF3_CLK_OUT_DLY_SEL_SHIFT)
#define SF3_IF_IO_DLY_0_SF3_CS_DLY_SEL_MASK (0x03)
#define SF3_IF_IO_DLY_1_SF3_IO_0_DO_DLY_SEL_SHIFT (16)
#define SF3_IF_IO_DLY_1_SF3_IO_0_DO_DLY_SEL_MASK (0x03 << SF3_IF_IO_DLY_1_SF3_IO_0_DO_DLY_SEL_SHIFT)
#define SF3_IF_IO_DLY_1_SF3_IO_0_DI_DLY_SEL_SHIFT (8)
#define SF3_IF_IO_DLY_1_SF3_IO_0_DI_DLY_SEL_MASK (0x03 << SF3_IF_IO_DLY_1_SF3_IO_0_DI_DLY_SEL_SHIFT)
#define SF3_IF_IO_DLY_1_SF3_IO_0_OE_DLY_SEL_MASK (0x03)
#define SF3_IF_IO_DLY_2_SF3_IO_1_DO_DLY_SEL_SHIFT (16)
#define SF3_IF_IO_DLY_2_SF3_IO_1_DO_DLY_SEL_MASK (0x03 << SF3_IF_IO_DLY_2_SF3_IO_1_DO_DLY_SEL_SHIFT)
#define SF3_IF_IO_DLY_2_SF3_IO_1_DI_DLY_SEL_SHIFT (8)
#define SF3_IF_IO_DLY_2_SF3_IO_1_DI_DLY_SEL_MASK (0x03 << SF3_IF_IO_DLY_2_SF3_IO_1_DI_DLY_SEL_SHIFT)
#define SF3_IF_IO_DLY_2_SF3_IO_1_OE_DLY_SEL_MASK (0x03)
#define SF3_IF_IO_DLY_3_SF3_IO_2_DO_DLY_SEL_SHIFT (16)
#define SF3_IF_IO_DLY_3_SF3_IO_2_DO_DLY_SEL_MASK (0x03 << SF3_IF_IO_DLY_3_SF3_IO_2_DO_DLY_SEL_SHIFT)
#define SF3_IF_IO_DLY_3_SF3_IO_2_DI_DLY_SEL_SHIFT (8)
#define SF3_IF_IO_DLY_3_SF3_IO_2_DI_DLY_SEL_MASK (0x03 << SF3_IF_IO_DLY_3_SF3_IO_2_DI_DLY_SEL_SHIFT)
#define SF3_IF_IO_DLY_3_SF3_IO_2_OE_DLY_SEL_MASK (0x03)
#define SF3_IF_IO_DLY_4_SF3_IO_3_DO_DLY_SEL_SHIFT (16)
#define SF3_IF_IO_DLY_4_SF3_IO_3_DO_DLY_SEL_MASK (0x03 << SF3_IF_IO_DLY_4_SF3_IO_3_DO_DLY_SEL_SHIFT)
#define SF3_IF_IO_DLY_4_SF3_IO_3_DI_DLY_SEL_SHIFT (8)
#define SF3_IF_IO_DLY_4_SF3_IO_3_DI_DLY_SEL_MASK (0x03 << SF3_IF_IO_DLY_4_SF3_IO_3_DI_DLY_SEL_SHIFT)
#define SF3_IF_IO_DLY_4_SF3_IO_3_OE_DLY_SEL_MASK (0x03)
#define SF_2_IF_DQS_EN (1 << 5)
#define SF_2_IF_DTR_EN (1 << 4)
#define SF_2_IF_PAD_SEL_LOCK (1 << 3)
#define SF_2_IF_PAD_SEL_MASK (0x03)
#define SF_3_IF_1_ACK_LAT_SHIFT (29)
#define SF_3_IF_1_ACK_LAT_MASK (0x07 << SF_3_IF_1_ACK_LAT_SHIFT)
#define SF_3_SF_CMDS_WRAP_MODE (1 << 10)
#define SF_3_SF_CMDS_WRAP_Q_INI (1 << 9)
#define SF_3_SF_CMDS_BT_EN (1 << 8)
#define SF_3_SF_CMDS_BT_DLY_SHIFT (5)
#define SF_3_SF_CMDS_BT_DLY_MASK (0x07 << SF_3_SF_CMDS_BT_DLY_SHIFT)
#define SF_3_SF_CMDS_EN (1 << 4)
#define SF_3_SF_CMDS_WRAP_LEN_MASK (0x0f)
#define SF_IF_IAHB_3_IF_2_QPI_MODE_EN (1 << 31)
#define SF_IF_IAHB_3_IF_2_SPI_MODE_SHIFT (28)
#define SF_IF_IAHB_3_IF_2_SPI_MODE_MASK (0x07 << SF_IF_IAHB_3_IF_2_SPI_MODE_SHIFT)
#define SF_IF_IAHB_3_IF_2_CMD_EN (1 << 27)
#define SF_IF_IAHB_3_IF_2_ADR_EN (1 << 26)
#define SF_IF_IAHB_3_IF_2_DMY_EN (1 << 25)
#define SF_IF_IAHB_3_IF_2_DAT_EN (1 << 24)
#define SF_IF_IAHB_3_IF_2_DAT_RW (1 << 23)
#define SF_IF_IAHB_3_IF_2_CMD_BYTE_SHIFT (20)
#define SF_IF_IAHB_3_IF_2_CMD_BYTE_MASK (0x07 << SF_IF_IAHB_3_IF_2_CMD_BYTE_SHIFT)
#define SF_IF_IAHB_3_IF_2_ADR_BYTE_SHIFT (17)
#define SF_IF_IAHB_3_IF_2_ADR_BYTE_MASK (0x07 << SF_IF_IAHB_3_IF_2_ADR_BYTE_SHIFT)
#define SF_IF_IAHB_3_IF_2_DMY_BYTE_SHIFT (12)
#define SF_IF_IAHB_3_IF_2_DMY_BYTE_MASK (0x1f << SF_IF_IAHB_3_IF_2_DMY_BYTE_SHIFT)
#define SF_IF_IAHB_6_IF_3_QPI_MODE_EN (1 << 31)
#define SF_IF_IAHB_6_IF_3_SPI_MODE_SHIFT (28)
#define SF_IF_IAHB_6_IF_3_SPI_MODE_MASK (0x07 << SF_IF_IAHB_6_IF_3_SPI_MODE_SHIFT)
#define SF_IF_IAHB_6_IF_3_CMD_BYTE_SHIFT (20)
#define SF_IF_IAHB_6_IF_3_CMD_BYTE_MASK (0x07 << SF_IF_IAHB_6_IF_3_CMD_BYTE_SHIFT)
#define SF_PROT_EN_RD_SF_DBG_DIS (1 << 31)
#define SF_PROT_EN_RD_SF_IF_0_TRIG_WR_LOCK (1 << 30)
#define SF_PROT_EN_RD_SF_ID1_EN_RD (1 << 2)
#define SF_PROT_EN_RD_SF_ID0_EN_RD (1 << 1)
#define SF_PROT_EN_RD (1 << 0)
#define SF_PROT_EN_SF_ID1_EN (1 << 2)
#define SF_PROT_EN_SF_ID0_EN (1 << 1)
#define SF_PROT_EN (1 << 0)
#define SF_AES_CFG_R0_SF_AES_REGION_R0_LOCK (1 << 31)
#define SF_AES_CFG_R0_SF_AES_REGION_R0_EN (1 << 30)
#define SF_AES_CFG_R0_SF_AES_REGION_R0_HW_KEY_EN (1 << 29)
#define SF_AES_CFG_R0_SF_AES_REGION_R0_START_SHIFT (14)
#define SF_AES_CFG_R0_SF_AES_REGION_R0_START_MASK (0x3fff << SF_AES_CFG_R0_SF_AES_REGION_R0_START_SHIFT)
#define SF_AES_CFG_R0_SF_AES_REGION_R0_END_MASK (0x3fff)
#define SF_AES_R1_SF_AES_R1_LOCK (1 << 31)
#define SF_AES_R1_SF_AES_R1_EN (1 << 30)
#define SF_AES_R1_SF_AES_R1_HW_KEY_EN (1 << 29)
#define SF_AES_R1_SF_AES_R1_START_SHIFT (14)
#define SF_AES_R1_SF_AES_R1_START_MASK (0x3fff << SF_AES_R1_SF_AES_R1_START_SHIFT)
#define SF_AES_R1_SF_AES_R1_END_MASK (0x3fff)
#define SF_AES_R2_SF_AES_R2_LOCK (1 << 31)
#define SF_AES_R2_SF_AES_R2_EN (1 << 30)
#define SF_AES_R2_SF_AES_R2_HW_KEY_EN (1 << 29)
#define SF_AES_R2_SF_AES_R2_START_SHIFT (14)
#define SF_AES_R2_SF_AES_R2_START_MASK (0x3fff << SF_AES_R2_SF_AES_R2_START_SHIFT)
#define SF_AES_R2_SF_AES_R2_END_MASK (0x3fff)
#define SF_ID0_OFFSET_MASK (0xffffff)
#define SF_ID1_OFFSET_MASK (0xffffff)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_SF_H */

View File

@ -0,0 +1,139 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_spi.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_SPI_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_SPI_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_SPI_CFG_OFFSET 0x000000 /* spi_config */
#define BL602_SPI_INT_STS_OFFSET 0x000004 /* spi_int_sts */
#define BL602_SPI_BUS_BUSY_OFFSET 0x000008 /* spi_bus_busy */
#define BL602_SPI_PRD_0_OFFSET 0x000010 /* spi_prd_0 */
#define BL602_SPI_PRD_1_OFFSET 0x000014 /* spi_prd_1 */
#define BL602_SPI_RXD_IGNR_OFFSET 0x000018 /* spi_rxd_ignr */
#define BL602_SPI_STO_VALUE_OFFSET 0x00001c /* spi_sto_value */
#define BL602_SPI_FIFO_CFG_0_OFFSET 0x000080 /* spi_fifo_config_0 */
#define BL602_SPI_FIFO_CFG_1_OFFSET 0x000084 /* spi_fifo_config_1 */
#define BL602_SPI_FIFO_WDATA_OFFSET 0x000088 /* spi_fifo_wdata */
#define BL602_SPI_FIFO_RDATA_OFFSET 0x00008c /* spi_fifo_rdata */
/* Register definitions *****************************************************/
#define BL602_SPI_CFG (BL602_SPI_BASE + BL602_SPI_CFG_OFFSET)
#define BL602_SPI_INT_STS (BL602_SPI_BASE + BL602_SPI_INT_STS_OFFSET)
#define BL602_SPI_BUS_BUSY (BL602_SPI_BASE + BL602_SPI_BUS_BUSY_OFFSET)
#define BL602_SPI_PRD_0 (BL602_SPI_BASE + BL602_SPI_PRD_0_OFFSET)
#define BL602_SPI_PRD_1 (BL602_SPI_BASE + BL602_SPI_PRD_1_OFFSET)
#define BL602_SPI_RXD_IGNR (BL602_SPI_BASE + BL602_SPI_RXD_IGNR_OFFSET)
#define BL602_SPI_STO_VALUE (BL602_SPI_BASE + BL602_SPI_STO_VALUE_OFFSET)
#define BL602_SPI_FIFO_CFG_0 (BL602_SPI_BASE + BL602_SPI_FIFO_CFG_0_OFFSET)
#define BL602_SPI_FIFO_CFG_1 (BL602_SPI_BASE + BL602_SPI_FIFO_CFG_1_OFFSET)
#define BL602_SPI_FIFO_WDATA (BL602_SPI_BASE + BL602_SPI_FIFO_WDATA_OFFSET)
#define BL602_SPI_FIFO_RDATA (BL602_SPI_BASE + BL602_SPI_FIFO_RDATA_OFFSET)
/* Register bit definitions *************************************************/
#define SPI_CFG_CR_DEG_CNT_SHIFT (12)
#define SPI_CFG_CR_DEG_CNT_MASK (0x0f << SPI_CFG_CR_DEG_CNT_SHIFT)
#define SPI_CFG_CR_DEG_EN (1 << 11)
#define SPI_CFG_CR_M_CONT_EN (1 << 9)
#define SPI_CFG_CR_RXD_IGNR_EN (1 << 8)
#define SPI_CFG_CR_BYTE_INV (1 << 7)
#define SPI_CFG_CR_BIT_INV (1 << 6)
#define SPI_CFG_CR_SCLK_PH (1 << 5)
#define SPI_CFG_CR_SCLK_POL (1 << 4)
#define SPI_CFG_CR_FRAME_SIZE_SHIFT (2)
#define SPI_CFG_CR_FRAME_SIZE_MASK (0x03 << SPI_CFG_CR_FRAME_SIZE_SHIFT)
#define SPI_CFG_CR_S_EN (1 << 1)
#define SPI_CFG_CR_M_EN (1 << 0)
#define SPI_INT_STS_CR_FER_EN (1 << 29)
#define SPI_INT_STS_CR_TXU_EN (1 << 28)
#define SPI_INT_STS_CR_STO_EN (1 << 27)
#define SPI_INT_STS_CR_RXF_EN (1 << 26)
#define SPI_INT_STS_CR_TXF_EN (1 << 25)
#define SPI_INT_STS_CR_END_EN (1 << 24)
#define SPI_INT_STS_RSVD_21 (1 << 21)
#define SPI_INT_STS_CR_TXU_CLR (1 << 20)
#define SPI_INT_STS_CR_STO_CLR (1 << 19)
#define SPI_INT_STS_RSVD_18 (1 << 18)
#define SPI_INT_STS_RSVD_17 (1 << 17)
#define SPI_INT_STS_CR_END_CLR (1 << 16)
#define SPI_INT_STS_CR_FER_MASK (1 << 13)
#define SPI_INT_STS_CR_TXU_MASK (1 << 12)
#define SPI_INT_STS_CR_STO_MASK (1 << 11)
#define SPI_INT_STS_CR_RXF_MASK (1 << 10)
#define SPI_INT_STS_CR_TXF_MASK (1 << 9)
#define SPI_INT_STS_CR_END_MASK (1 << 8)
#define SPI_INT_STS_FER_INT (1 << 5)
#define SPI_INT_STS_TXU_INT (1 << 4)
#define SPI_INT_STS_STO_INT (1 << 3)
#define SPI_INT_STS_RXF_INT (1 << 2)
#define SPI_INT_STS_TXF_INT (1 << 1)
#define SPI_INT_STS_END_INT (1 << 0)
#define SPI_BUS_BUSY_STS_BUS_BUSY (1 << 0)
#define SPI_PRD_0_CR_D_PH_1_SHIFT (24)
#define SPI_PRD_0_CR_D_PH_1_MASK (0xff << SPI_PRD_0_CR_D_PH_1_SHIFT)
#define SPI_PRD_0_CR_D_PH_0_SHIFT (16)
#define SPI_PRD_0_CR_D_PH_0_MASK (0xff << SPI_PRD_0_CR_D_PH_0_SHIFT)
#define SPI_PRD_0_CR_P_SHIFT (8)
#define SPI_PRD_0_CR_P_MASK (0xff << SPI_PRD_0_CR_P_SHIFT)
#define SPI_PRD_0_CR_S_MASK (0xff)
#define SPI_PRD_1_CR_I_MASK (0xff)
#define SPI_RXD_IGNR_CR_IGNR_S_SHIFT (16)
#define SPI_RXD_IGNR_CR_IGNR_S_MASK (0x1f << SPI_RXD_IGNR_CR_RXD_IGNR_S_SHIFT)
#define SPI_RXD_IGNR_CR_IGNR_P_MASK (0x1f)
#define SPI_STO_VALUE_CR_VALUE_MASK (0xfff)
#define SPI_FIFO_CFG_0_RX_UNDERFLOW (1 << 7)
#define SPI_FIFO_CFG_0_RX_OVERFLOW (1 << 6)
#define SPI_FIFO_CFG_0_TX_UNDERFLOW (1 << 5)
#define SPI_FIFO_CFG_0_TX_OVERFLOW (1 << 4)
#define SPI_FIFO_CFG_0_RX_CLR (1 << 3)
#define SPI_FIFO_CFG_0_TX_CLR (1 << 2)
#define SPI_FIFO_CFG_0_DMA_RX_EN (1 << 1)
#define SPI_FIFO_CFG_0_DMA_TX_EN (1 << 0)
#define SPI_FIFO_CFG_1_RX_TH_SHIFT (24)
#define SPI_FIFO_CFG_1_RX_TH_MASK (0x03 << SPI_FIFO_CFG_1_RX_TH_SHIFT)
#define SPI_FIFO_CFG_1_TX_TH_SHIFT (16)
#define SPI_FIFO_CFG_1_TX_TH_MASK (0x03 << SPI_FIFO_CFG_1_TX_TH_SHIFT)
#define SPI_FIFO_CFG_1_RX_CNT_SHIFT (8)
#define SPI_FIFO_CFG_1_RX_CNT_MASK (0x07 << SPI_FIFO_CFG_1_RX_CNT_SHIFT)
#define SPI_FIFO_CFG_1_TX_CNT_MASK (0x07)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_SPI_H */

View File

@ -25,608 +25,164 @@
* Included Files
****************************************************************************/
#include "hardware/bl602_common.h"
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* 0x0 : TCCR */
#define TIMER_TCCR_OFFSET (0x0)
#define TIMER_CS_1 TIMER_CS_1
#define TIMER_CS_1_POS (2U)
#define TIMER_CS_1_LEN (2U)
#define TIMER_CS_1_MSK (((1U << TIMER_CS_1_LEN) - 1) << TIMER_CS_1_POS)
#define TIMER_CS_1_UMSK (~(((1U << TIMER_CS_1_LEN) - 1) << TIMER_CS_1_POS))
#define TIMER_CS_2 TIMER_CS_2
#define TIMER_CS_2_POS (5U)
#define TIMER_CS_2_LEN (2U)
#define TIMER_CS_2_MSK (((1U << TIMER_CS_2_LEN) - 1) << TIMER_CS_2_POS)
#define TIMER_CS_2_UMSK (~(((1U << TIMER_CS_2_LEN) - 1) << TIMER_CS_2_POS))
#define TIMER_CS_WDT TIMER_CS_WDT
#define TIMER_CS_WDT_POS (8U)
#define TIMER_CS_WDT_LEN (2U)
#define TIMER_CS_WDT_MSK (((1U << TIMER_CS_WDT_LEN) - 1) << TIMER_CS_WDT_POS)
#define TIMER_CS_WDT_UMSK \
(~(((1U << TIMER_CS_WDT_LEN) - 1) << TIMER_CS_WDT_POS))
/* 0x10 : TMR2_0 */
#define TIMER_TMR2_0_OFFSET (0x10)
#define TIMER_TMR TIMER_TMR
#define TIMER_TMR_POS (0U)
#define TIMER_TMR_LEN (32U)
#define TIMER_TMR_MSK (((1U << TIMER_TMR_LEN) - 1) << TIMER_TMR_POS)
#define TIMER_TMR_UMSK (~(((1U << TIMER_TMR_LEN) - 1) << TIMER_TMR_POS))
/* 0x14 : TMR2_1 */
#define TIMER_TMR2_1_OFFSET (0x14)
#define TIMER_TMR TIMER_TMR
#define TIMER_TMR_POS (0U)
#define TIMER_TMR_LEN (32U)
#define TIMER_TMR_MSK (((1U << TIMER_TMR_LEN) - 1) << TIMER_TMR_POS)
#define TIMER_TMR_UMSK (~(((1U << TIMER_TMR_LEN) - 1) << TIMER_TMR_POS))
/* 0x18 : TMR2_2 */
#define TIMER_TMR2_2_OFFSET (0x18)
#define TIMER_TMR TIMER_TMR
#define TIMER_TMR_POS (0U)
#define TIMER_TMR_LEN (32U)
#define TIMER_TMR_MSK (((1U << TIMER_TMR_LEN) - 1) << TIMER_TMR_POS)
#define TIMER_TMR_UMSK (~(((1U << TIMER_TMR_LEN) - 1) << TIMER_TMR_POS))
/* 0x1C : TMR3_0 */
#define TIMER_TMR3_0_OFFSET (0x1C)
#define TIMER_TMR TIMER_TMR
#define TIMER_TMR_POS (0U)
#define TIMER_TMR_LEN (32U)
#define TIMER_TMR_MSK (((1U << TIMER_TMR_LEN) - 1) << TIMER_TMR_POS)
#define TIMER_TMR_UMSK (~(((1U << TIMER_TMR_LEN) - 1) << TIMER_TMR_POS))
/* 0x20 : TMR3_1 */
#define TIMER_TMR3_1_OFFSET (0x20)
#define TIMER_TMR TIMER_TMR
#define TIMER_TMR_POS (0U)
#define TIMER_TMR_LEN (32U)
#define TIMER_TMR_MSK (((1U << TIMER_TMR_LEN) - 1) << TIMER_TMR_POS)
#define TIMER_TMR_UMSK (~(((1U << TIMER_TMR_LEN) - 1) << TIMER_TMR_POS))
/* 0x24 : TMR3_2 */
#define TIMER_TMR3_2_OFFSET (0x24)
#define TIMER_TMR TIMER_TMR
#define TIMER_TMR_POS (0U)
#define TIMER_TMR_LEN (32U)
#define TIMER_TMR_MSK (((1U << TIMER_TMR_LEN) - 1) << TIMER_TMR_POS)
#define TIMER_TMR_UMSK (~(((1U << TIMER_TMR_LEN) - 1) << TIMER_TMR_POS))
/* 0x2C : TCR2 */
#define TIMER_TCR2_OFFSET (0x2C)
#define TIMER_TCR TIMER_TCR
#define TIMER_TCR_POS (0U)
#define TIMER_TCR_LEN (32U)
#define TIMER_TCR_MSK (((1U << TIMER_TCR_LEN) - 1) << TIMER_TCR_POS)
#define TIMER_TCR_UMSK (~(((1U << TIMER_TCR_LEN) - 1) << TIMER_TCR_POS))
/* 0x30 : TCR3 */
#define TIMER_TCR3_OFFSET (0x30)
#define TIMER_TCR3_COUNTER TIMER_TCR3_COUNTER
#define TIMER_TCR3_COUNTER_POS (0U)
#define TIMER_TCR3_COUNTER_LEN (32U)
#define TIMER_TCR3_COUNTER_MSK \
(((1U << TIMER_TCR3_COUNTER_LEN) - 1) << TIMER_TCR3_COUNTER_POS)
#define TIMER_TCR3_COUNTER_UMSK \
(~(((1U << TIMER_TCR3_COUNTER_LEN) - 1) << TIMER_TCR3_COUNTER_POS))
/* 0x38 : TMSR2 */
#define TIMER_TMSR2_OFFSET (0x38)
#define TIMER_TMSR_0 TIMER_TMSR_0
#define TIMER_TMSR_0_POS (0U)
#define TIMER_TMSR_0_LEN (1U)
#define TIMER_TMSR_0_MSK (((1U << TIMER_TMSR_0_LEN) - 1) << TIMER_TMSR_0_POS)
#define TIMER_TMSR_0_UMSK \
(~(((1U << TIMER_TMSR_0_LEN) - 1) << TIMER_TMSR_0_POS))
#define TIMER_TMSR_1 TIMER_TMSR_1
#define TIMER_TMSR_1_POS (1U)
#define TIMER_TMSR_1_LEN (1U)
#define TIMER_TMSR_1_MSK (((1U << TIMER_TMSR_1_LEN) - 1) << TIMER_TMSR_1_POS)
#define TIMER_TMSR_1_UMSK \
(~(((1U << TIMER_TMSR_1_LEN) - 1) << TIMER_TMSR_1_POS))
#define TIMER_TMSR_2 TIMER_TMSR_2
#define TIMER_TMSR_2_POS (2U)
#define TIMER_TMSR_2_LEN (1U)
#define TIMER_TMSR_2_MSK (((1U << TIMER_TMSR_2_LEN) - 1) << TIMER_TMSR_2_POS)
#define TIMER_TMSR_2_UMSK \
(~(((1U << TIMER_TMSR_2_LEN) - 1) << TIMER_TMSR_2_POS))
/* 0x3C : TMSR3 */
#define TIMER_TMSR3_OFFSET (0x3C)
#define TIMER_TMSR_0 TIMER_TMSR_0
#define TIMER_TMSR_0_POS (0U)
#define TIMER_TMSR_0_LEN (1U)
#define TIMER_TMSR_0_MSK (((1U << TIMER_TMSR_0_LEN) - 1) << TIMER_TMSR_0_POS)
#define TIMER_TMSR_0_UMSK \
(~(((1U << TIMER_TMSR_0_LEN) - 1) << TIMER_TMSR_0_POS))
#define TIMER_TMSR_1 TIMER_TMSR_1
#define TIMER_TMSR_1_POS (1U)
#define TIMER_TMSR_1_LEN (1U)
#define TIMER_TMSR_1_MSK (((1U << TIMER_TMSR_1_LEN) - 1) << TIMER_TMSR_1_POS)
#define TIMER_TMSR_1_UMSK \
(~(((1U << TIMER_TMSR_1_LEN) - 1) << TIMER_TMSR_1_POS))
#define TIMER_TMSR_2 TIMER_TMSR_2
#define TIMER_TMSR_2_POS (2U)
#define TIMER_TMSR_2_LEN (1U)
#define TIMER_TMSR_2_MSK (((1U << TIMER_TMSR_2_LEN) - 1) << TIMER_TMSR_2_POS)
#define TIMER_TMSR_2_UMSK \
(~(((1U << TIMER_TMSR_2_LEN) - 1) << TIMER_TMSR_2_POS))
/* 0x44 : TIER2 */
#define TIMER_TIER2_OFFSET (0x44)
#define TIMER_TIER_0 TIMER_TIER_0
#define TIMER_TIER_0_POS (0U)
#define TIMER_TIER_0_LEN (1U)
#define TIMER_TIER_0_MSK (((1U << TIMER_TIER_0_LEN) - 1) << TIMER_TIER_0_POS)
#define TIMER_TIER_0_UMSK \
(~(((1U << TIMER_TIER_0_LEN) - 1) << TIMER_TIER_0_POS))
#define TIMER_TIER_1 TIMER_TIER_1
#define TIMER_TIER_1_POS (1U)
#define TIMER_TIER_1_LEN (1U)
#define TIMER_TIER_1_MSK (((1U << TIMER_TIER_1_LEN) - 1) << TIMER_TIER_1_POS)
#define TIMER_TIER_1_UMSK \
(~(((1U << TIMER_TIER_1_LEN) - 1) << TIMER_TIER_1_POS))
#define TIMER_TIER_2 TIMER_TIER_2
#define TIMER_TIER_2_POS (2U)
#define TIMER_TIER_2_LEN (1U)
#define TIMER_TIER_2_MSK (((1U << TIMER_TIER_2_LEN) - 1) << TIMER_TIER_2_POS)
#define TIMER_TIER_2_UMSK \
(~(((1U << TIMER_TIER_2_LEN) - 1) << TIMER_TIER_2_POS))
/* 0x48 : TIER3 */
#define TIMER_TIER3_OFFSET (0x48)
#define TIMER_TIER_0 TIMER_TIER_0
#define TIMER_TIER_0_POS (0U)
#define TIMER_TIER_0_LEN (1U)
#define TIMER_TIER_0_MSK (((1U << TIMER_TIER_0_LEN) - 1) << TIMER_TIER_0_POS)
#define TIMER_TIER_0_UMSK \
(~(((1U << TIMER_TIER_0_LEN) - 1) << TIMER_TIER_0_POS))
#define TIMER_TIER_1 TIMER_TIER_1
#define TIMER_TIER_1_POS (1U)
#define TIMER_TIER_1_LEN (1U)
#define TIMER_TIER_1_MSK (((1U << TIMER_TIER_1_LEN) - 1) << TIMER_TIER_1_POS)
#define TIMER_TIER_1_UMSK \
(~(((1U << TIMER_TIER_1_LEN) - 1) << TIMER_TIER_1_POS))
#define TIMER_TIER_2 TIMER_TIER_2
#define TIMER_TIER_2_POS (2U)
#define TIMER_TIER_2_LEN (1U)
#define TIMER_TIER_2_MSK (((1U << TIMER_TIER_2_LEN) - 1) << TIMER_TIER_2_POS)
#define TIMER_TIER_2_UMSK \
(~(((1U << TIMER_TIER_2_LEN) - 1) << TIMER_TIER_2_POS))
/* 0x50 : TPLVR2 */
#define TIMER_TPLVR2_OFFSET (0x50)
#define TIMER_TPLVR TIMER_TPLVR
#define TIMER_TPLVR_POS (0U)
#define TIMER_TPLVR_LEN (32U)
#define TIMER_TPLVR_MSK (((1U << TIMER_TPLVR_LEN) - 1) << TIMER_TPLVR_POS)
#define TIMER_TPLVR_UMSK (~(((1U << TIMER_TPLVR_LEN) - 1) << TIMER_TPLVR_POS))
/* 0x54 : TPLVR3 */
#define TIMER_TPLVR3_OFFSET (0x54)
#define TIMER_TPLVR TIMER_TPLVR
#define TIMER_TPLVR_POS (0U)
#define TIMER_TPLVR_LEN (32U)
#define TIMER_TPLVR_MSK (((1U << TIMER_TPLVR_LEN) - 1) << TIMER_TPLVR_POS)
#define TIMER_TPLVR_UMSK (~(((1U << TIMER_TPLVR_LEN) - 1) << TIMER_TPLVR_POS))
/* 0x5C : TPLCR2 */
#define TIMER_TPLCR2_OFFSET (0x5C)
#define TIMER_TPLCR TIMER_TPLCR
#define TIMER_TPLCR_POS (0U)
#define TIMER_TPLCR_LEN (2U)
#define TIMER_TPLCR_MSK (((1U << TIMER_TPLCR_LEN) - 1) << TIMER_TPLCR_POS)
#define TIMER_TPLCR_UMSK (~(((1U << TIMER_TPLCR_LEN) - 1) << TIMER_TPLCR_POS))
/* 0x60 : TPLCR3 */
#define TIMER_TPLCR3_OFFSET (0x60)
#define TIMER_TPLCR TIMER_TPLCR
#define TIMER_TPLCR_POS (0U)
#define TIMER_TPLCR_LEN (2U)
#define TIMER_TPLCR_MSK (((1U << TIMER_TPLCR_LEN) - 1) << TIMER_TPLCR_POS)
#define TIMER_TPLCR_UMSK (~(((1U << TIMER_TPLCR_LEN) - 1) << TIMER_TPLCR_POS))
/* 0x64 : WMER */
#define TIMER_WMER_OFFSET (0x64)
#define TIMER_WE TIMER_WE
#define TIMER_WE_POS (0U)
#define TIMER_WE_LEN (1U)
#define TIMER_WE_MSK (((1U << TIMER_WE_LEN) - 1) << TIMER_WE_POS)
#define TIMER_WE_UMSK (~(((1U << TIMER_WE_LEN) - 1) << TIMER_WE_POS))
#define TIMER_WRIE TIMER_WRIE
#define TIMER_WRIE_POS (1U)
#define TIMER_WRIE_LEN (1U)
#define TIMER_WRIE_MSK (((1U << TIMER_WRIE_LEN) - 1) << TIMER_WRIE_POS)
#define TIMER_WRIE_UMSK (~(((1U << TIMER_WRIE_LEN) - 1) << TIMER_WRIE_POS))
/* 0x68 : WMR */
#define TIMER_WMR_OFFSET (0x68)
#define TIMER_WMR TIMER_WMR
#define TIMER_WMR_POS (0U)
#define TIMER_WMR_LEN (16U)
#define TIMER_WMR_MSK (((1U << TIMER_WMR_LEN) - 1) << TIMER_WMR_POS)
#define TIMER_WMR_UMSK (~(((1U << TIMER_WMR_LEN) - 1) << TIMER_WMR_POS))
/* 0x6C : WVR */
#define TIMER_WVR_OFFSET (0x6C)
#define TIMER_WVR TIMER_WVR
#define TIMER_WVR_POS (0U)
#define TIMER_WVR_LEN (16U)
#define TIMER_WVR_MSK (((1U << TIMER_WVR_LEN) - 1) << TIMER_WVR_POS)
#define TIMER_WVR_UMSK (~(((1U << TIMER_WVR_LEN) - 1) << TIMER_WVR_POS))
/* 0x70 : WSR */
#define TIMER_WSR_OFFSET (0x70)
#define TIMER_WTS TIMER_WTS
#define TIMER_WTS_POS (0U)
#define TIMER_WTS_LEN (1U)
#define TIMER_WTS_MSK (((1U << TIMER_WTS_LEN) - 1) << TIMER_WTS_POS)
#define TIMER_WTS_UMSK (~(((1U << TIMER_WTS_LEN) - 1) << TIMER_WTS_POS))
/* 0x78 : TICR2 */
#define TIMER_TICR2_OFFSET (0x78)
#define TIMER_TCLR_0 TIMER_TCLR_0
#define TIMER_TCLR_0_POS (0U)
#define TIMER_TCLR_0_LEN (1U)
#define TIMER_TCLR_0_MSK (((1U << TIMER_TCLR_0_LEN) - 1) << TIMER_TCLR_0_POS)
#define TIMER_TCLR_0_UMSK \
(~(((1U << TIMER_TCLR_0_LEN) - 1) << TIMER_TCLR_0_POS))
#define TIMER_TCLR_1 TIMER_TCLR_1
#define TIMER_TCLR_1_POS (1U)
#define TIMER_TCLR_1_LEN (1U)
#define TIMER_TCLR_1_MSK (((1U << TIMER_TCLR_1_LEN) - 1) << TIMER_TCLR_1_POS)
#define TIMER_TCLR_1_UMSK \
(~(((1U << TIMER_TCLR_1_LEN) - 1) << TIMER_TCLR_1_POS))
#define TIMER_TCLR_2 TIMER_TCLR_2
#define TIMER_TCLR_2_POS (2U)
#define TIMER_TCLR_2_LEN (1U)
#define TIMER_TCLR_2_MSK (((1U << TIMER_TCLR_2_LEN) - 1) << TIMER_TCLR_2_POS)
#define TIMER_TCLR_2_UMSK \
(~(((1U << TIMER_TCLR_2_LEN) - 1) << TIMER_TCLR_2_POS))
/* 0x7C : TICR3 */
#define TIMER_TICR3_OFFSET (0x7C)
#define TIMER_TCLR_0 TIMER_TCLR_0
#define TIMER_TCLR_0_POS (0U)
#define TIMER_TCLR_0_LEN (1U)
#define TIMER_TCLR_0_MSK (((1U << TIMER_TCLR_0_LEN) - 1) << TIMER_TCLR_0_POS)
#define TIMER_TCLR_0_UMSK \
(~(((1U << TIMER_TCLR_0_LEN) - 1) << TIMER_TCLR_0_POS))
#define TIMER_TCLR_1 TIMER_TCLR_1
#define TIMER_TCLR_1_POS (1U)
#define TIMER_TCLR_1_LEN (1U)
#define TIMER_TCLR_1_MSK (((1U << TIMER_TCLR_1_LEN) - 1) << TIMER_TCLR_1_POS)
#define TIMER_TCLR_1_UMSK \
(~(((1U << TIMER_TCLR_1_LEN) - 1) << TIMER_TCLR_1_POS))
#define TIMER_TCLR_2 TIMER_TCLR_2
#define TIMER_TCLR_2_POS (2U)
#define TIMER_TCLR_2_LEN (1U)
#define TIMER_TCLR_2_MSK (((1U << TIMER_TCLR_2_LEN) - 1) << TIMER_TCLR_2_POS)
#define TIMER_TCLR_2_UMSK \
(~(((1U << TIMER_TCLR_2_LEN) - 1) << TIMER_TCLR_2_POS))
/* 0x80 : WICR */
#define TIMER_WICR_OFFSET (0x80)
#define TIMER_WICLR TIMER_WICLR
#define TIMER_WICLR_POS (0U)
#define TIMER_WICLR_LEN (1U)
#define TIMER_WICLR_MSK (((1U << TIMER_WICLR_LEN) - 1) << TIMER_WICLR_POS)
#define TIMER_WICLR_UMSK (~(((1U << TIMER_WICLR_LEN) - 1) << TIMER_WICLR_POS))
/* 0x84 : TCER */
#define TIMER_TCER_OFFSET (0x84)
#define TIMER2_EN TIMER2_EN
#define TIMER2_EN_POS (1U)
#define TIMER2_EN_LEN (1U)
#define TIMER2_EN_MSK (((1U << TIMER2_EN_LEN) - 1) << TIMER2_EN_POS)
#define TIMER2_EN_UMSK (~(((1U << TIMER2_EN_LEN) - 1) << TIMER2_EN_POS))
#define TIMER3_EN TIMER3_EN
#define TIMER3_EN_POS (2U)
#define TIMER3_EN_LEN (1U)
#define TIMER3_EN_MSK (((1U << TIMER3_EN_LEN) - 1) << TIMER3_EN_POS)
#define TIMER3_EN_UMSK (~(((1U << TIMER3_EN_LEN) - 1) << TIMER3_EN_POS))
/* 0x88 : TCMR */
#define TIMER_TCMR_OFFSET (0x88)
#define TIMER2_MODE TIMER2_MODE
#define TIMER2_MODE_POS (1U)
#define TIMER2_MODE_LEN (1U)
#define TIMER2_MODE_MSK (((1U << TIMER2_MODE_LEN) - 1) << TIMER2_MODE_POS)
#define TIMER2_MODE_UMSK (~(((1U << TIMER2_MODE_LEN) - 1) << TIMER2_MODE_POS))
#define TIMER3_MODE TIMER3_MODE
#define TIMER3_MODE_POS (2U)
#define TIMER3_MODE_LEN (1U)
#define TIMER3_MODE_MSK (((1U << TIMER3_MODE_LEN) - 1) << TIMER3_MODE_POS)
#define TIMER3_MODE_UMSK (~(((1U << TIMER3_MODE_LEN) - 1) << TIMER3_MODE_POS))
/* 0x90 : TILR2 */
#define TIMER_TILR2_OFFSET (0x90)
#define TIMER_TILR_0 TIMER_TILR_0
#define TIMER_TILR_0_POS (0U)
#define TIMER_TILR_0_LEN (1U)
#define TIMER_TILR_0_MSK (((1U << TIMER_TILR_0_LEN) - 1) << TIMER_TILR_0_POS)
#define TIMER_TILR_0_UMSK \
(~(((1U << TIMER_TILR_0_LEN) - 1) << TIMER_TILR_0_POS))
#define TIMER_TILR_1 TIMER_TILR_1
#define TIMER_TILR_1_POS (1U)
#define TIMER_TILR_1_LEN (1U)
#define TIMER_TILR_1_MSK (((1U << TIMER_TILR_1_LEN) - 1) << TIMER_TILR_1_POS)
#define TIMER_TILR_1_UMSK \
(~(((1U << TIMER_TILR_1_LEN) - 1) << TIMER_TILR_1_POS))
#define TIMER_TILR_2 TIMER_TILR_2
#define TIMER_TILR_2_POS (2U)
#define TIMER_TILR_2_LEN (1U)
#define TIMER_TILR_2_MSK (((1U << TIMER_TILR_2_LEN) - 1) << TIMER_TILR_2_POS)
#define TIMER_TILR_2_UMSK \
(~(((1U << TIMER_TILR_2_LEN) - 1) << TIMER_TILR_2_POS))
/* 0x94 : TILR3 */
#define TIMER_TILR3_OFFSET (0x94)
#define TIMER_TILR_0 TIMER_TILR_0
#define TIMER_TILR_0_POS (0U)
#define TIMER_TILR_0_LEN (1U)
#define TIMER_TILR_0_MSK (((1U << TIMER_TILR_0_LEN) - 1) << TIMER_TILR_0_POS)
#define TIMER_TILR_0_UMSK \
(~(((1U << TIMER_TILR_0_LEN) - 1) << TIMER_TILR_0_POS))
#define TIMER_TILR_1 TIMER_TILR_1
#define TIMER_TILR_1_POS (1U)
#define TIMER_TILR_1_LEN (1U)
#define TIMER_TILR_1_MSK (((1U << TIMER_TILR_1_LEN) - 1) << TIMER_TILR_1_POS)
#define TIMER_TILR_1_UMSK \
(~(((1U << TIMER_TILR_1_LEN) - 1) << TIMER_TILR_1_POS))
#define TIMER_TILR_2 TIMER_TILR_2
#define TIMER_TILR_2_POS (2U)
#define TIMER_TILR_2_LEN (1U)
#define TIMER_TILR_2_MSK (((1U << TIMER_TILR_2_LEN) - 1) << TIMER_TILR_2_POS)
#define TIMER_TILR_2_UMSK \
(~(((1U << TIMER_TILR_2_LEN) - 1) << TIMER_TILR_2_POS))
/* 0x98 : WCR */
#define TIMER_WCR_OFFSET (0x98)
#define TIMER_WCR TIMER_WCR
#define TIMER_WCR_POS (0U)
#define TIMER_WCR_LEN (1U)
#define TIMER_WCR_MSK (((1U << TIMER_WCR_LEN) - 1) << TIMER_WCR_POS)
#define TIMER_WCR_UMSK (~(((1U << TIMER_WCR_LEN) - 1) << TIMER_WCR_POS))
/* 0x9C : WFAR */
#define TIMER_WFAR_OFFSET (0x9C)
#define TIMER_WFAR TIMER_WFAR
#define TIMER_WFAR_POS (0U)
#define TIMER_WFAR_LEN (16U)
#define TIMER_WFAR_MSK (((1U << TIMER_WFAR_LEN) - 1) << TIMER_WFAR_POS)
#define TIMER_WFAR_UMSK (~(((1U << TIMER_WFAR_LEN) - 1) << TIMER_WFAR_POS))
/* 0xA0 : WSAR */
#define TIMER_WSAR_OFFSET (0xA0)
#define TIMER_WSAR TIMER_WSAR
#define TIMER_WSAR_POS (0U)
#define TIMER_WSAR_LEN (16U)
#define TIMER_WSAR_MSK (((1U << TIMER_WSAR_LEN) - 1) << TIMER_WSAR_POS)
#define TIMER_WSAR_UMSK (~(((1U << TIMER_WSAR_LEN) - 1) << TIMER_WSAR_POS))
/* 0xA8 : TCVWR2 */
#define TIMER_TCVWR2_OFFSET (0xA8)
#define TIMER_TCVWR TIMER_TCVWR
#define TIMER_TCVWR_POS (0U)
#define TIMER_TCVWR_LEN (32U)
#define TIMER_TCVWR_MSK (((1U << TIMER_TCVWR_LEN) - 1) << TIMER_TCVWR_POS)
#define TIMER_TCVWR_UMSK (~(((1U << TIMER_TCVWR_LEN) - 1) << TIMER_TCVWR_POS))
/* 0xAC : TCVWR3 */
#define TIMER_TCVWR3_OFFSET (0xAC)
#define TIMER_TCVWR TIMER_TCVWR
#define TIMER_TCVWR_POS (0U)
#define TIMER_TCVWR_LEN (32U)
#define TIMER_TCVWR_MSK (((1U << TIMER_TCVWR_LEN) - 1) << TIMER_TCVWR_POS)
#define TIMER_TCVWR_UMSK (~(((1U << TIMER_TCVWR_LEN) - 1) << TIMER_TCVWR_POS))
/* 0xB4 : TCVSYN2 */
#define TIMER_TCVSYN2_OFFSET (0xB4)
#define TIMER_TCVSYN2 TIMER_TCVSYN2
#define TIMER_TCVSYN2_POS (0U)
#define TIMER_TCVSYN2_LEN (32U)
#define TIMER_TCVSYN2_MSK \
(((1U << TIMER_TCVSYN2_LEN) - 1) << TIMER_TCVSYN2_POS)
#define TIMER_TCVSYN2_UMSK \
(~(((1U << TIMER_TCVSYN2_LEN) - 1) << TIMER_TCVSYN2_POS))
/* 0xB8 : TCVSYN3 */
#define TIMER_TCVSYN3_OFFSET (0xB8)
#define TIMER_TCVSYN3 TIMER_TCVSYN3
#define TIMER_TCVSYN3_POS (0U)
#define TIMER_TCVSYN3_LEN (32U)
#define TIMER_TCVSYN3_MSK \
(((1U << TIMER_TCVSYN3_LEN) - 1) << TIMER_TCVSYN3_POS)
#define TIMER_TCVSYN3_UMSK \
(~(((1U << TIMER_TCVSYN3_LEN) - 1) << TIMER_TCVSYN3_POS))
/* 0xBC : TCDR */
#define TIMER_TCDR_OFFSET (0xBC)
#define TIMER_TCDR2 TIMER_TCDR2
#define TIMER_TCDR2_POS (8U)
#define TIMER_TCDR2_LEN (8U)
#define TIMER_TCDR2_MSK (((1U << TIMER_TCDR2_LEN) - 1) << TIMER_TCDR2_POS)
#define TIMER_TCDR2_UMSK (~(((1U << TIMER_TCDR2_LEN) - 1) << TIMER_TCDR2_POS))
#define TIMER_TCDR3 TIMER_TCDR3
#define TIMER_TCDR3_POS (16U)
#define TIMER_TCDR3_LEN (8U)
#define TIMER_TCDR3_MSK (((1U << TIMER_TCDR3_LEN) - 1) << TIMER_TCDR3_POS)
#define TIMER_TCDR3_UMSK (~(((1U << TIMER_TCDR3_LEN) - 1) << TIMER_TCDR3_POS))
#define TIMER_WCDR TIMER_WCDR
#define TIMER_WCDR_POS (24U)
#define TIMER_WCDR_LEN (8U)
#define TIMER_WCDR_MSK (((1U << TIMER_WCDR_LEN) - 1) << TIMER_WCDR_POS)
#define TIMER_WCDR_UMSK (~(((1U << TIMER_WCDR_LEN) - 1) << TIMER_WCDR_POS))
/* TIMER channel type definition */
#define TIMER_CH0 0 /* TIMER channel 0 port define */
#define TIMER_CH1 1 /* TIMER channel 1 port define */
#define TIMER_CH_MAX 2
/* TIMER clock source type definition */
#define TIMER_CLKSRC_FCLK 0 /* TIMER clock source :System CLK */
#define TIMER_CLKSRC_32K 1 /* TIMER clock source :32K CLK */
#define TIMER_CLKSRC_1K 2 /* TIMER clock source :1K CLK,Only for
* Timer not for Watchdog */
#define TIMER_CLKSRC_XTAL 3 /* TIMER clock source :XTAL CLK */
/* TIMER match compare ID type definition */
#define TIMER_COMP_ID_0 0 /* TIMER match compare ID 0 define */
#define TIMER_COMP_ID_1 1 /* TIMER match compare ID 1 define */
#define TIMER_COMP_ID_2 2 /* TIMER match compare ID 2 define */
/* TIMER preload source type definition */
#define TIMER_PRELOAD_TRIG_NONE 0 /* TIMER no preload source, just free run \
*/
#define TIMER_PRELOAD_TRIG_COMP0 \
1 /* TIMER count register preload triggered by \
* comparator 0 */
#define TIMER_PRELOAD_TRIG_COMP1 \
2 /* TIMER count register preload triggered by \
* comparator 1 */
#define TIMER_PRELOAD_TRIG_COMP2 \
3 /* TIMER count register preload triggered by \
* comparator 2 */
/* TIMER count register run mode type definition */
#define TIMER_COUNT_PRELOAD \
0 /* TIMER count register preload from comparator \
* register */
#define TIMER_COUNT_FREERUN 1 /* TIMER count register free run */
/* TIMER interrupt type definition */
#define TIMER_INT_COMP_0 0 /* Comparator 0 match cause interrupt */
#define TIMER_INT_COMP_1 1 /* Comparator 1 match cause interrupt */
#define TIMER_INT_COMP_2 2 /* Comparator 2 match cause interrupt */
#define TIMER_INT_ALL 3
/* Watchdog timer interrupt type definition */
#define WDT_INT 0 /* Comparator 0 match cause interrupt */
#define WDT_INT_ALL 1
/****************************************************************************
* Public Types
****************************************************************************/
#ifndef __ASSEMBLY__
/* TIMER configuration structure type definition */
struct timer_cfg_s
{
uint32_t timer_ch; /* Timer channel */
uint32_t clk_src; /* Timer clock source */
/* Timer count register preload trigger source slelect */
uint32_t pl_trig_src;
uint32_t count_mode; /* Timer count mode */
uint8_t clock_division; /* Timer clock divison value */
uint32_t match_val0; /* Timer match 0 value 0 */
uint32_t match_val1; /* Timer match 1 value 0 */
uint32_t match_val2; /* Timer match 2 value 0 */
uint32_t pre_load_val; /* Timer preload value */
};
typedef struct timer_cfg_s timer_cfg_t;
#undef EXTERN
#if defined(__cplusplus)
#define EXTERN extern "C"
extern "C"
{
#else
#define EXTERN extern
#endif
/****************************************************************************
* Public Function Prototypes
****************************************************************************/
EXTERN uint32_t bl602_timer_getcompvalue(uint32_t timer_ch, uint32_t cmp_no);
EXTERN void bl602_timer_setcompvalue(uint32_t timer_ch, uint32_t cmp_no,
uint32_t val);
EXTERN uint32_t bl602_timer_getcountervalue(uint32_t timer_ch);
EXTERN uint32_t bl602_timer_getmatchstatus(uint32_t timer_ch,
uint32_t cmp_no);
EXTERN uint32_t bl602_timer_getpreloadvalue(uint32_t timer_ch);
EXTERN void bl602_timer_setpreloadvalue(uint32_t timer_ch, uint32_t val);
EXTERN void bl602_timer_setpreloadtrigsrc(uint32_t timer_ch,
uint32_t pl_src);
EXTERN void bl602_timer_setcountmode(uint32_t timer_ch, uint32_t count_mode);
EXTERN void bl602_timer_clearintstatus(uint32_t timer_ch, uint32_t cmp_no);
EXTERN void bl602_timer_init(timer_cfg_t *timer_cfg);
EXTERN void bl602_timer_enable(uint32_t timer_ch);
EXTERN void bl602_timer_disable(uint32_t timer_ch);
EXTERN void bl602_timer_intmask(uint32_t timer_ch, uint32_t int_type,
uint32_t int_mask);
EXTERN void bl602_wdt_set_clock(uint32_t clk_src, uint8_t div);
EXTERN uint32_t bl602_wdt_getmatchvalue(void);
EXTERN void bl602_wdt_setcompvalue(uint16_t val);
EXTERN uint16_t bl602_wdt_getcountervalue(void);
EXTERN void bl602_wdt_resetcountervalue(void);
EXTERN uint32_t bl602_wdt_getresetstatus(void);
EXTERN void bl602_wdt_clearresetstatus(void);
EXTERN void bl602_wdt_enable(void);
EXTERN void bl602_wdt_disable(void);
EXTERN void bl602_wdt_intmask(uint32_t int_type, uint32_t int_mask);
#undef EXTERN
#if defined(__cplusplus)
}
#endif
#endif /* __ASSEMBLY__ */
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_GPIO_H */
/* Register offsets *********************************************************/
#define BL602_TIMER_TCCR_OFFSET 0x000000 /* TCCR */
#define BL602_TIMER_TMR2_0_OFFSET 0x000010 /* TMR2_0 */
#define BL602_TIMER_TMR2_1_OFFSET 0x000014 /* TMR2_1 */
#define BL602_TIMER_TMR2_2_OFFSET 0x000018 /* TMR2_2 */
#define BL602_TIMER_TMR3_0_OFFSET 0x00001c /* TMR3_0 */
#define BL602_TIMER_TMR3_1_OFFSET 0x000020 /* TMR3_1 */
#define BL602_TIMER_TMR3_2_OFFSET 0x000024 /* TMR3_2 */
#define BL602_TIMER_TCR2_OFFSET 0x00002c /* TCR2 */
#define BL602_TIMER_TCR3_OFFSET 0x000030 /* TCR3 */
#define BL602_TIMER_TMSR2_OFFSET 0x000038 /* TMSR2 */
#define BL602_TIMER_TMSR3_OFFSET 0x00003c /* TMSR3 */
#define BL602_TIMER_TIER2_OFFSET 0x000044 /* TIER2 */
#define BL602_TIMER_TIER3_OFFSET 0x000048 /* TIER3 */
#define BL602_TIMER_TPLVR2_OFFSET 0x000050 /* TPLVR2 */
#define BL602_TIMER_TPLVR3_OFFSET 0x000054 /* TPLVR3 */
#define BL602_TIMER_TPLCR2_OFFSET 0x00005c /* TPLCR2 */
#define BL602_TIMER_TPLCR3_OFFSET 0x000060 /* TPLCR3 */
#define BL602_TIMER_WMER_OFFSET 0x000064 /* WMER */
#define BL602_TIMER_WMR_OFFSET 0x000068 /* WMR */
#define BL602_TIMER_WVR_OFFSET 0x00006c /* WVR */
#define BL602_TIMER_WSR_OFFSET 0x000070 /* WSR */
#define BL602_TIMER_TICR2_OFFSET 0x000078 /* TICR2 */
#define BL602_TIMER_TICR3_OFFSET 0x00007c /* TICR3 */
#define BL602_TIMER_WICR_OFFSET 0x000080 /* WICR */
#define BL602_TIMER_TCER_OFFSET 0x000084 /* TCER */
#define BL602_TIMER_TCMR_OFFSET 0x000088 /* TCMR */
#define BL602_TIMER_TILR2_OFFSET 0x000090 /* TILR2 */
#define BL602_TIMER_TILR3_OFFSET 0x000094 /* TILR3 */
#define BL602_TIMER_WCR_OFFSET 0x000098 /* WCR */
#define BL602_TIMER_WFAR_OFFSET 0x00009c /* WFAR */
#define BL602_TIMER_WSAR_OFFSET 0x0000a0 /* WSAR */
#define BL602_TIMER_TCVWR2_OFFSET 0x0000a8 /* TCVWR2 */
#define BL602_TIMER_TCVWR3_OFFSET 0x0000ac /* TCVWR3 */
#define BL602_TIMER_TCVSYN2_OFFSET 0x0000b4 /* TCVSYN2 */
#define BL602_TIMER_TCVSYN3_OFFSET 0x0000b8 /* TCVSYN3 */
#define BL602_TIMER_TCDR_OFFSET 0x0000bc /* TCDR */
/* Register definitions *****************************************************/
#define BL602_TIMER_TCCR (BL602_TIMER_BASE + BL602_TIMER_TCCR_OFFSET)
#define BL602_TIMER_TMR2_0 (BL602_TIMER_BASE + BL602_TIMER_TMR2_0_OFFSET)
#define BL602_TIMER_TMR2_1 (BL602_TIMER_BASE + BL602_TIMER_TMR2_1_OFFSET)
#define BL602_TIMER_TMR2_2 (BL602_TIMER_BASE + BL602_TIMER_TMR2_2_OFFSET)
#define BL602_TIMER_TMR3_0 (BL602_TIMER_BASE + BL602_TIMER_TMR3_0_OFFSET)
#define BL602_TIMER_TMR3_1 (BL602_TIMER_BASE + BL602_TIMER_TMR3_1_OFFSET)
#define BL602_TIMER_TMR3_2 (BL602_TIMER_BASE + BL602_TIMER_TMR3_2_OFFSET)
#define BL602_TIMER_TCR2 (BL602_TIMER_BASE + BL602_TIMER_TCR2_OFFSET)
#define BL602_TIMER_TCR3 (BL602_TIMER_BASE + BL602_TIMER_TCR3_OFFSET)
#define BL602_TIMER_TMSR2 (BL602_TIMER_BASE + BL602_TIMER_TMSR2_OFFSET)
#define BL602_TIMER_TMSR3 (BL602_TIMER_BASE + BL602_TIMER_TMSR3_OFFSET)
#define BL602_TIMER_TIER2 (BL602_TIMER_BASE + BL602_TIMER_TIER2_OFFSET)
#define BL602_TIMER_TIER3 (BL602_TIMER_BASE + BL602_TIMER_TIER3_OFFSET)
#define BL602_TIMER_TPLVR2 (BL602_TIMER_BASE + BL602_TIMER_TPLVR2_OFFSET)
#define BL602_TIMER_TPLVR3 (BL602_TIMER_BASE + BL602_TIMER_TPLVR3_OFFSET)
#define BL602_TIMER_TPLCR2 (BL602_TIMER_BASE + BL602_TIMER_TPLCR2_OFFSET)
#define BL602_TIMER_TPLCR3 (BL602_TIMER_BASE + BL602_TIMER_TPLCR3_OFFSET)
#define BL602_TIMER_WMER (BL602_TIMER_BASE + BL602_TIMER_WMER_OFFSET)
#define BL602_TIMER_WMR (BL602_TIMER_BASE + BL602_TIMER_WMR_OFFSET)
#define BL602_TIMER_WVR (BL602_TIMER_BASE + BL602_TIMER_WVR_OFFSET)
#define BL602_TIMER_WSR (BL602_TIMER_BASE + BL602_TIMER_WSR_OFFSET)
#define BL602_TIMER_TICR2 (BL602_TIMER_BASE + BL602_TIMER_TICR2_OFFSET)
#define BL602_TIMER_TICR3 (BL602_TIMER_BASE + BL602_TIMER_TICR3_OFFSET)
#define BL602_TIMER_WICR (BL602_TIMER_BASE + BL602_TIMER_WICR_OFFSET)
#define BL602_TIMER_TCER (BL602_TIMER_BASE + BL602_TIMER_TCER_OFFSET)
#define BL602_TIMER_TCMR (BL602_TIMER_BASE + BL602_TIMER_TCMR_OFFSET)
#define BL602_TIMER_TILR2 (BL602_TIMER_BASE + BL602_TIMER_TILR2_OFFSET)
#define BL602_TIMER_TILR3 (BL602_TIMER_BASE + BL602_TIMER_TILR3_OFFSET)
#define BL602_TIMER_WCR (BL602_TIMER_BASE + BL602_TIMER_WCR_OFFSET)
#define BL602_TIMER_WFAR (BL602_TIMER_BASE + BL602_TIMER_WFAR_OFFSET)
#define BL602_TIMER_WSAR (BL602_TIMER_BASE + BL602_TIMER_WSAR_OFFSET)
#define BL602_TIMER_TCVWR2 (BL602_TIMER_BASE + BL602_TIMER_TCVWR2_OFFSET)
#define BL602_TIMER_TCVWR3 (BL602_TIMER_BASE + BL602_TIMER_TCVWR3_OFFSET)
#define BL602_TIMER_TCVSYN2 (BL602_TIMER_BASE + BL602_TIMER_TCVSYN2_OFFSET)
#define BL602_TIMER_TCVSYN3 (BL602_TIMER_BASE + BL602_TIMER_TCVSYN3_OFFSET)
#define BL602_TIMER_TCDR (BL602_TIMER_BASE + BL602_TIMER_TCDR_OFFSET)
/* Register bit definitions *************************************************/
#define TIMER_TCCR_CS_WDT_SHIFT (8)
#define TIMER_TCCR_CS_WDT_MASK (0x03 << TIMER_TCCR_CS_WDT_SHIFT)
#define TIMER_TCCR_CS_2_SHIFT (5)
#define TIMER_TCCR_CS_2_MASK (0x03 << TIMER_TCCR_CS_2_SHIFT)
#define TIMER_TCCR_CS_1_SHIFT (2)
#define TIMER_TCCR_CS_1_MASK (0x03 << TIMER_TCCR_CS_1_SHIFT)
#define TIMER_TMSR2_TMSR_2 (1 << 2)
#define TIMER_TMSR2_TMSR_1 (1 << 1)
#define TIMER_TMSR2_TMSR_0 (1 << 0)
#define TIMER_TMSR3_TMSR_2 (1 << 2)
#define TIMER_TMSR3_TMSR_1 (1 << 1)
#define TIMER_TMSR3_TMSR_0 (1 << 0)
#define TIMER_TIER2_TIER_2 (1 << 2)
#define TIMER_TIER2_TIER_1 (1 << 1)
#define TIMER_TIER2_TIER_0 (1 << 0)
#define TIMER_TIER3_TIER_2 (1 << 2)
#define TIMER_TIER3_TIER_1 (1 << 1)
#define TIMER_TIER3_TIER_0 (1 << 0)
#define TIMER_TPLCR2_TPLCR_MASK (0x03)
#define TIMER_TPLCR3_TPLCR_MASK (0x03)
#define TIMER_WMER_WRIE (1 << 1)
#define TIMER_WMER_WE (1 << 0)
#define TIMER_WMR_WMR_MASK (0xffff)
#define TIMER_WVR_WVR_MASK (0xffff)
#define TIMER_WSR_WTS (1 << 0)
#define TIMER_TICR2_TCLR_2 (1 << 2)
#define TIMER_TICR2_TCLR_1 (1 << 1)
#define TIMER_TICR2_TCLR_0 (1 << 0)
#define TIMER_TICR3_TCLR_2 (1 << 2)
#define TIMER_TICR3_TCLR_1 (1 << 1)
#define TIMER_TICR3_TCLR_0 (1 << 0)
#define TIMER_WICR_WICLR (1 << 0)
#define TIMER_TCER_TIMER3_EN (1 << 2)
#define TIMER_TCER_TIMER2_EN (1 << 1)
#define TIMER_TCMR_TIMER3_MODE (1 << 2)
#define TIMER_TCMR_TIMER2_MODE (1 << 1)
#define TIMER_TILR2_TILR_2 (1 << 2)
#define TIMER_TILR2_TILR_1 (1 << 1)
#define TIMER_TILR2_TILR_0 (1 << 0)
#define TIMER_TILR3_TILR_2 (1 << 2)
#define TIMER_TILR3_TILR_1 (1 << 1)
#define TIMER_TILR3_TILR_0 (1 << 0)
#define TIMER_WCR_WCR (1 << 0)
#define TIMER_WFAR_MASK (0xffff)
#define TIMER_WSAR_MASK (0xffff)
#define TIMER_TCDR_WCDR_SHIFT (24)
#define TIMER_TCDR_WCDR_MASK (0xff << TIMER_TCDR_WCDR_SHIFT)
#define TIMER_TCDR_TCDR3_SHIFT (16)
#define TIMER_TCDR_TCDR3_MASK (0xff << TIMER_TCDR_TCDR3_SHIFT)
#define TIMER_TCDR_TCDR2_SHIFT (8)
#define TIMER_TCDR_TCDR2_MASK (0xff << TIMER_TCDR_TCDR2_SHIFT)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_TIMER_H */

View File

@ -0,0 +1,135 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/bl602_tzc.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_TZC_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_TZC_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* Register offsets *********************************************************/
#define BL602_SEC_ROM_CTRL_OFFSET 0x000040 /* tzc_rom_ctrl */
#define BL602_SEC_ROM0_R0_OFFSET 0x000044 /* tzc_rom0_r0 */
#define BL602_SEC_ROM0_R1_OFFSET 0x000048 /* tzc_rom0_r1 */
#define BL602_SEC_ROM1_R0_OFFSET 0x00004c /* tzc_rom1_r0 */
#define BL602_SEC_ROM1_R1_OFFSET 0x000050 /* tzc_rom1_r1 */
#define BL602_NSEC_ROM_CTRL_OFFSET 0x000040 /* tzc_rom_ctrl */
#define BL602_NSEC_ROM0_R0_OFFSET 0x000044 /* tzc_rom0_r0 */
#define BL602_NSEC_ROM0_R1_OFFSET 0x000048 /* tzc_rom0_r1 */
#define BL602_NSEC_ROM1_R0_OFFSET 0x00004c /* tzc_rom1_r0 */
#define BL602_NSEC_ROM1_R1_OFFSET 0x000050 /* tzc_rom1_r1 */
/* Register definitions *****************************************************/
#define BL602_SEC_ROM_CTRL (BL602_SEC_BASE + BL602_SEC_ROM_CTRL_OFFSET)
#define BL602_SEC_ROM0_R0 (BL602_SEC_BASE + BL602_SEC_ROM0_R0_OFFSET)
#define BL602_SEC_ROM0_R1 (BL602_SEC_BASE + BL602_SEC_ROM0_R1_OFFSET)
#define BL602_SEC_ROM1_R0 (BL602_SEC_BASE + BL602_SEC_ROM1_R0_OFFSET)
#define BL602_SEC_ROM1_R1 (BL602_SEC_BASE + BL602_SEC_ROM1_R1_OFFSET)
#define BL602_NSEC_ROM_CTRL (BL602_NSEC_BASE + BL602_NSEC_ROM_CTRL_OFFSET)
#define BL602_NSEC_ROM0_R0 (BL602_NSEC_BASE + BL602_NSEC_ROM0_R0_OFFSET)
#define BL602_NSEC_ROM0_R1 (BL602_NSEC_BASE + BL602_NSEC_ROM0_R1_OFFSET)
#define BL602_NSEC_ROM1_R0 (BL602_NSEC_BASE + BL602_NSEC_ROM1_R0_OFFSET)
#define BL602_NSEC_ROM1_R1 (BL602_NSEC_BASE + BL602_NSEC_ROM1_R1_OFFSET)
/* Register bit definitions *************************************************/
#define TZC_SEC_ROM_CTRL_SBOOT_DONE_SHIFT (28)
#define TZC_SEC_ROM_CTRL_SBOOT_DONE_MASK (0x0f << TZC_SEC_ROM_CTRL_SBOOT_DONE_SHIFT)
#define TZC_SEC_ROM_CTRL_ROM1_R1_LOCK (1 << 27)
#define TZC_SEC_ROM_CTRL_ROM1_R0_LOCK (1 << 26)
#define TZC_SEC_ROM_CTRL_ROM0_R1_LOCK (1 << 25)
#define TZC_SEC_ROM_CTRL_ROM0_R0_LOCK (1 << 24)
#define TZC_SEC_ROM_CTRL_ROM1_R1_EN (1 << 19)
#define TZC_SEC_ROM_CTRL_ROM1_R0_EN (1 << 18)
#define TZC_SEC_ROM_CTRL_ROM0_R1_EN (1 << 17)
#define TZC_SEC_ROM_CTRL_ROM0_R0_EN (1 << 16)
#define TZC_SEC_ROM_CTRL_ROM1_R1_ID1_EN (1 << 11)
#define TZC_SEC_ROM_CTRL_ROM1_R0_ID1_EN (1 << 10)
#define TZC_SEC_ROM_CTRL_ROM0_R1_ID1_EN (1 << 9)
#define TZC_SEC_ROM_CTRL_ROM0_R0_ID1_EN (1 << 8)
#define TZC_SEC_ROM_CTRL_ROM1_R1_ID0_EN (1 << 3)
#define TZC_SEC_ROM_CTRL_ROM1_R0_ID0_EN (1 << 2)
#define TZC_SEC_ROM_CTRL_ROM0_R1_ID0_EN (1 << 1)
#define TZC_SEC_ROM_CTRL_ROM0_R0_ID0_EN (1 << 0)
#define TZC_SEC_ROM0_R0_START_SHIFT (16)
#define TZC_SEC_ROM0_R0_START_MASK (0xffff << TZC_SEC_ROM0_R0_START_SHIFT)
#define TZC_SEC_ROM0_R0_END_MASK (0xffff)
#define TZC_SEC_ROM0_R01_START_SHIFT (16)
#define TZC_SEC_ROM0_R01_START_MASK (0xffff << TZC_SEC_ROM0_R01_START_SHIFT)
#define TZC_SEC_ROM0_R01_END_MASK (0xffff)
#define TZC_SEC_ROM1_R0_START_SHIFT (16)
#define TZC_SEC_ROM1_R0_START_MASK (0xffff << TZC_SEC_ROM1_R0_START_SHIFT)
#define TZC_SEC_ROM1_R0_END_MASK (0xffff)
#define TZC_SEC_ROM1_R1_START_SHIFT (16)
#define TZC_SEC_ROM1_R1_START_MASK (0xffff << TZC_SEC_ROM1_R1_START_SHIFT)
#define TZC_SEC_ROM1_R1_END_MASK (0xffff)
#define TZC_NSEC_ROM_CTRL_SBOOT_DONE_SHIFT (28)
#define TZC_NSEC_ROM_CTRL_SBOOT_DONE_MASK (0x0f << TZC_NSEC_ROM_CTRL_SBOOT_DONE_SHIFT)
#define TZC_NSEC_ROM_CTRL_ROM1_R1_LOCK (1 << 27)
#define TZC_NSEC_ROM_CTRL_ROM1_R0_LOCK (1 << 26)
#define TZC_NSEC_ROM_CTRL_ROM0_R1_LOCK (1 << 25)
#define TZC_NSEC_ROM_CTRL_ROM0_R0_LOCK (1 << 24)
#define TZC_NSEC_ROM_CTRL_ROM1_R1_EN (1 << 19)
#define TZC_NSEC_ROM_CTRL_ROM1_R0_EN (1 << 18)
#define TZC_NSEC_ROM_CTRL_ROM0_R1_EN (1 << 17)
#define TZC_NSEC_ROM_CTRL_ROM0_R0_EN (1 << 16)
#define TZC_NSEC_ROM_CTRL_ROM1_R1_ID1_EN (1 << 11)
#define TZC_NSEC_ROM_CTRL_ROM1_R0_ID1_EN (1 << 10)
#define TZC_NSEC_ROM_CTRL_ROM0_R1_ID1_EN (1 << 9)
#define TZC_NSEC_ROM_CTRL_ROM0_R0_ID1_EN (1 << 8)
#define TZC_NSEC_ROM_CTRL_ROM1_R1_ID0_EN (1 << 3)
#define TZC_NSEC_ROM_CTRL_ROM1_R0_ID0_EN (1 << 2)
#define TZC_NSEC_ROM_CTRL_ROM0_R1_ID0_EN (1 << 1)
#define TZC_NSEC_ROM_CTRL_ROM0_R0_ID0_EN (1 << 0)
#define TZC_NSEC_ROM0_R0_START_SHIFT (16)
#define TZC_NSEC_ROM0_R0_START_MASK (0xffff << TZC_NSEC_ROM0_R0_START_SHIFT)
#define TZC_NSEC_ROM0_R0_END_MASK (0xffff)
#define TZC_NSEC_ROM0_R01_START_SHIFT (16)
#define TZC_NSEC_ROM0_R01_START_MASK (0xffff << TZC_NSEC_ROM0_R01_START_SHIFT)
#define TZC_NSEC_ROM0_R01_END_MASK (0xffff)
#define TZC_NSEC_ROM1_R0_START_SHIFT (16)
#define TZC_NSEC_ROM1_R0_START_MASK (0xffff << TZC_NSEC_ROM1_R0_START_SHIFT)
#define TZC_NSEC_ROM1_R0_END_MASK (0xffff)
#define TZC_NSEC_ROM1_R1_START_SHIFT (16)
#define TZC_NSEC_ROM1_R1_START_MASK (0xffff << TZC_NSEC_ROM1_R1_START_SHIFT)
#define TZC_NSEC_ROM1_R1_END_MASK (0xffff)
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_TZC_H */

View File

@ -25,677 +25,201 @@
* Included Files
****************************************************************************/
#include "hardware/bl602_common.h"
#include <nuttx/config.h>
#include "bl602_memorymap.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* 0x0 : utx_config */
/* UART0 and 1 are the same so create this helper for register offsets */
#define UART_UTX_CONFIG_OFFSET (0x0)
#define UART_CR_UTX_EN UART_CR_UTX_EN
#define UART_CR_UTX_EN_POS (0)
#define UART_CR_UTX_EN_LEN (1)
#define UART_CR_UTX_EN_MSK \
(((1 << UART_CR_UTX_EN_LEN) - 1) << UART_CR_UTX_EN_POS)
#define UART_CR_UTX_EN_UMSK \
(~(((1 << UART_CR_UTX_EN_LEN) - 1) << UART_CR_UTX_EN_POS))
#define UART_CR_UTX_CTS_EN UART_CR_UTX_CTS_EN
#define UART_CR_UTX_CTS_EN_POS (1)
#define UART_CR_UTX_CTS_EN_LEN (1)
#define UART_CR_UTX_CTS_EN_MSK \
(((1 << UART_CR_UTX_CTS_EN_LEN) - 1) << UART_CR_UTX_CTS_EN_POS)
#define UART_CR_UTX_CTS_EN_UMSK \
(~(((1 << UART_CR_UTX_CTS_EN_LEN) - 1) << UART_CR_UTX_CTS_EN_POS))
#define UART_CR_UTX_FRM_EN UART_CR_UTX_FRM_EN
#define UART_CR_UTX_FRM_EN_POS (2)
#define UART_CR_UTX_FRM_EN_LEN (1)
#define UART_CR_UTX_FRM_EN_MSK \
(((1 << UART_CR_UTX_FRM_EN_LEN) - 1) << UART_CR_UTX_FRM_EN_POS)
#define UART_CR_UTX_FRM_EN_UMSK \
(~(((1 << UART_CR_UTX_FRM_EN_LEN) - 1) << UART_CR_UTX_FRM_EN_POS))
#define UART_CR_UTX_PRT_EN UART_CR_UTX_PRT_EN
#define UART_CR_UTX_PRT_EN_POS (4)
#define UART_CR_UTX_PRT_EN_LEN (1)
#define UART_CR_UTX_PRT_EN_MSK \
(((1 << UART_CR_UTX_PRT_EN_LEN) - 1) << UART_CR_UTX_PRT_EN_POS)
#define UART_CR_UTX_PRT_EN_UMSK \
(~(((1 << UART_CR_UTX_PRT_EN_LEN) - 1) << UART_CR_UTX_PRT_EN_POS))
#define UART_CR_UTX_PRT_SEL UART_CR_UTX_PRT_SEL
#define UART_CR_UTX_PRT_SEL_POS (5)
#define UART_CR_UTX_PRT_SEL_LEN (1)
#define UART_CR_UTX_PRT_SEL_MSK \
(((1 << UART_CR_UTX_PRT_SEL_LEN) - 1) << UART_CR_UTX_PRT_SEL_POS)
#define UART_CR_UTX_PRT_SEL_UMSK \
(~(((1 << UART_CR_UTX_PRT_SEL_LEN) - 1) << UART_CR_UTX_PRT_SEL_POS))
#define UART_CR_UTX_IR_EN UART_CR_UTX_IR_EN
#define UART_CR_UTX_IR_EN_POS (6)
#define UART_CR_UTX_IR_EN_LEN (1)
#define UART_CR_UTX_IR_EN_MSK \
(((1 << UART_CR_UTX_IR_EN_LEN) - 1) << UART_CR_UTX_IR_EN_POS)
#define UART_CR_UTX_IR_EN_UMSK \
(~(((1 << UART_CR_UTX_IR_EN_LEN) - 1) << UART_CR_UTX_IR_EN_POS))
#define UART_CR_UTX_IR_INV UART_CR_UTX_IR_INV
#define UART_CR_UTX_IR_INV_POS (7)
#define UART_CR_UTX_IR_INV_LEN (1)
#define UART_CR_UTX_IR_INV_MSK \
(((1 << UART_CR_UTX_IR_INV_LEN) - 1) << UART_CR_UTX_IR_INV_POS)
#define UART_CR_UTX_IR_INV_UMSK \
(~(((1 << UART_CR_UTX_IR_INV_LEN) - 1) << UART_CR_UTX_IR_INV_POS))
#define UART_CR_UTX_BIT_CNT_D UART_CR_UTX_BIT_CNT_D
#define UART_CR_UTX_BIT_CNT_D_POS (8)
#define UART_CR_UTX_BIT_CNT_D_LEN (3)
#define UART_CR_UTX_BIT_CNT_D_MSK \
(((1 << UART_CR_UTX_BIT_CNT_D_LEN) - 1) << UART_CR_UTX_BIT_CNT_D_POS)
#define UART_CR_UTX_BIT_CNT_D_UMSK \
(~(((1 << UART_CR_UTX_BIT_CNT_D_LEN) - 1) << UART_CR_UTX_BIT_CNT_D_POS))
#define UART_CR_UTX_BIT_CNT_P UART_CR_UTX_BIT_CNT_P
#define UART_CR_UTX_BIT_CNT_P_POS (12)
#define UART_CR_UTX_BIT_CNT_P_LEN (2)
#define UART_CR_UTX_BIT_CNT_P_MSK \
(((1 << UART_CR_UTX_BIT_CNT_P_LEN) - 1) << UART_CR_UTX_BIT_CNT_P_POS)
#define UART_CR_UTX_BIT_CNT_P_UMSK \
(~(((1 << UART_CR_UTX_BIT_CNT_P_LEN) - 1) << UART_CR_UTX_BIT_CNT_P_POS))
#define UART_CR_UTX_LEN UART_CR_UTX_LEN
#define UART_CR_UTX_LEN_POS (16)
#define UART_CR_UTX_LEN_LEN (16)
#define UART_CR_UTX_LEN_MSK \
(((1 << UART_CR_UTX_LEN_LEN) - 1) << UART_CR_UTX_LEN_POS)
#define UART_CR_UTX_LEN_UMSK \
(~(((1 << UART_CR_UTX_LEN_LEN) - 1) << UART_CR_UTX_LEN_POS))
#define BL602_UART_BASE(n) (BL602_UART0_BASE + (n * (BL602_UART1_BASE - BL602_UART0_BASE)))
/* 0x4 : urx_config */
/* Register offsets *********************************************************/
#define UART_URX_CONFIG_OFFSET (0x4)
#define UART_CR_URX_EN UART_CR_URX_EN
#define UART_CR_URX_EN_POS (0)
#define UART_CR_URX_EN_LEN (1)
#define UART_CR_URX_EN_MSK \
(((1 << UART_CR_URX_EN_LEN) - 1) << UART_CR_URX_EN_POS)
#define UART_CR_URX_EN_UMSK \
(~(((1 << UART_CR_URX_EN_LEN) - 1) << UART_CR_URX_EN_POS))
#define UART_CR_URX_RTS_SW_MODE UART_CR_URX_RTS_SW_MODE
#define UART_CR_URX_RTS_SW_MODE_POS (1)
#define UART_CR_URX_RTS_SW_MODE_LEN (1)
#define UART_CR_URX_RTS_SW_MODE_MSK \
(((1 << UART_CR_URX_RTS_SW_MODE_LEN) - 1) << UART_CR_URX_RTS_SW_MODE_POS)
#define UART_CR_URX_RTS_SW_MODE_UMSK \
(~(((1 << UART_CR_URX_RTS_SW_MODE_LEN) - 1) << UART_CR_URX_RTS_SW_MODE_POS))
#define UART_CR_URX_RTS_SW_VAL UART_CR_URX_RTS_SW_VAL
#define UART_CR_URX_RTS_SW_VAL_POS (2)
#define UART_CR_URX_RTS_SW_VAL_LEN (1)
#define UART_CR_URX_RTS_SW_VAL_MSK \
(((1 << UART_CR_URX_RTS_SW_VAL_LEN) - 1) << UART_CR_URX_RTS_SW_VAL_POS)
#define UART_CR_URX_RTS_SW_VAL_UMSK \
(~(((1 << UART_CR_URX_RTS_SW_VAL_LEN) - 1) << UART_CR_URX_RTS_SW_VAL_POS))
#define UART_CR_URX_ABR_EN UART_CR_URX_ABR_EN
#define UART_CR_URX_ABR_EN_POS (3)
#define UART_CR_URX_ABR_EN_LEN (1)
#define UART_CR_URX_ABR_EN_MSK \
(((1 << UART_CR_URX_ABR_EN_LEN) - 1) << UART_CR_URX_ABR_EN_POS)
#define UART_CR_URX_ABR_EN_UMSK \
(~(((1 << UART_CR_URX_ABR_EN_LEN) - 1) << UART_CR_URX_ABR_EN_POS))
#define UART_CR_URX_PRT_EN UART_CR_URX_PRT_EN
#define UART_CR_URX_PRT_EN_POS (4)
#define UART_CR_URX_PRT_EN_LEN (1)
#define UART_CR_URX_PRT_EN_MSK \
(((1 << UART_CR_URX_PRT_EN_LEN) - 1) << UART_CR_URX_PRT_EN_POS)
#define UART_CR_URX_PRT_EN_UMSK \
(~(((1 << UART_CR_URX_PRT_EN_LEN) - 1) << UART_CR_URX_PRT_EN_POS))
#define UART_CR_URX_PRT_SEL UART_CR_URX_PRT_SEL
#define UART_CR_URX_PRT_SEL_POS (5)
#define UART_CR_URX_PRT_SEL_LEN (1)
#define UART_CR_URX_PRT_SEL_MSK \
(((1 << UART_CR_URX_PRT_SEL_LEN) - 1) << UART_CR_URX_PRT_SEL_POS)
#define UART_CR_URX_PRT_SEL_UMSK \
(~(((1 << UART_CR_URX_PRT_SEL_LEN) - 1) << UART_CR_URX_PRT_SEL_POS))
#define UART_CR_URX_IR_EN UART_CR_URX_IR_EN
#define UART_CR_URX_IR_EN_POS (6)
#define UART_CR_URX_IR_EN_LEN (1)
#define UART_CR_URX_IR_EN_MSK \
(((1 << UART_CR_URX_IR_EN_LEN) - 1) << UART_CR_URX_IR_EN_POS)
#define UART_CR_URX_IR_EN_UMSK \
(~(((1 << UART_CR_URX_IR_EN_LEN) - 1) << UART_CR_URX_IR_EN_POS))
#define UART_CR_URX_IR_INV UART_CR_URX_IR_INV
#define UART_CR_URX_IR_INV_POS (7)
#define UART_CR_URX_IR_INV_LEN (1)
#define UART_CR_URX_IR_INV_MSK \
(((1 << UART_CR_URX_IR_INV_LEN) - 1) << UART_CR_URX_IR_INV_POS)
#define UART_CR_URX_IR_INV_UMSK \
(~(((1 << UART_CR_URX_IR_INV_LEN) - 1) << UART_CR_URX_IR_INV_POS))
#define UART_CR_URX_BIT_CNT_D UART_CR_URX_BIT_CNT_D
#define UART_CR_URX_BIT_CNT_D_POS (8)
#define UART_CR_URX_BIT_CNT_D_LEN (3)
#define UART_CR_URX_BIT_CNT_D_MSK \
(((1 << UART_CR_URX_BIT_CNT_D_LEN) - 1) << UART_CR_URX_BIT_CNT_D_POS)
#define UART_CR_URX_BIT_CNT_D_UMSK \
(~(((1 << UART_CR_URX_BIT_CNT_D_LEN) - 1) << UART_CR_URX_BIT_CNT_D_POS))
#define UART_CR_URX_DEG_EN UART_CR_URX_DEG_EN
#define UART_CR_URX_DEG_EN_POS (11)
#define UART_CR_URX_DEG_EN_LEN (1)
#define UART_CR_URX_DEG_EN_MSK \
(((1 << UART_CR_URX_DEG_EN_LEN) - 1) << UART_CR_URX_DEG_EN_POS)
#define UART_CR_URX_DEG_EN_UMSK \
(~(((1 << UART_CR_URX_DEG_EN_LEN) - 1) << UART_CR_URX_DEG_EN_POS))
#define UART_CR_URX_DEG_CNT UART_CR_URX_DEG_CNT
#define UART_CR_URX_DEG_CNT_POS (12)
#define UART_CR_URX_DEG_CNT_LEN (4)
#define UART_CR_URX_DEG_CNT_MSK \
(((1 << UART_CR_URX_DEG_CNT_LEN) - 1) << UART_CR_URX_DEG_CNT_POS)
#define UART_CR_URX_DEG_CNT_UMSK \
(~(((1 << UART_CR_URX_DEG_CNT_LEN) - 1) << UART_CR_URX_DEG_CNT_POS))
#define UART_CR_URX_LEN UART_CR_URX_LEN
#define UART_CR_URX_LEN_POS (16)
#define UART_CR_URX_LEN_LEN (16)
#define UART_CR_URX_LEN_MSK \
(((1 << UART_CR_URX_LEN_LEN) - 1) << UART_CR_URX_LEN_POS)
#define UART_CR_URX_LEN_UMSK \
(~(((1 << UART_CR_URX_LEN_LEN) - 1) << UART_CR_URX_LEN_POS))
#define BL602_UART_UTX_CONFIG_OFFSET 0x000000 /* utx_config */
#define BL602_UART_URX_CONFIG_OFFSET 0x000004 /* urx_config */
#define BL602_UART_BIT_PRD_OFFSET 0x000008 /* uart_bit_prd */
#define BL602_UART_DATA_CONFIG_OFFSET 0x00000c /* data_config */
#define BL602_UART_UTX_IR_POSITION_OFFSET 0x000010 /* utx_ir_position */
#define BL602_UART_URX_IR_POSITION_OFFSET 0x000014 /* urx_ir_position */
#define BL602_UART_URX_RTO_TIMER_OFFSET 0x000018 /* urx_rto_timer */
#define BL602_UART_INT_STS_OFFSET 0x000020 /* UART interrupt status */
#define BL602_UART_INT_MASK_OFFSET 0x000024 /* UART interrupt mask */
#define BL602_UART_INT_CLEAR_OFFSET 0x000028 /* UART interrupt clear */
#define BL602_UART_INT_EN_OFFSET 0x00002c /* UART interrupt enable */
#define BL602_UART_STATUS_OFFSET 0x000030 /* uart_status */
#define BL602_UART_STS_URX_ABR_PRD_OFFSET 0x000034 /* sts_urx_abr_prd */
#define BL602_UART_FIFO_CONFIG_0_OFFSET 0x000080 /* uart_fifo_config_0 */
#define BL602_UART_FIFO_CONFIG_1_OFFSET 0x000084 /* uart_fifo_config_1 */
#define BL602_UART_FIFO_WDATA_OFFSET 0x000088 /* uart_fifo_wdata */
#define BL602_UART_FIFO_RDATA_OFFSET 0x00008c /* uart_fifo_rdata */
/* 0x8 : uart_bit_prd */
/* Register definitions *****************************************************/
#define UART_BIT_PRD_OFFSET (0x8)
#define UART_CR_UTX_BIT_PRD UART_CR_UTX_BIT_PRD
#define UART_CR_UTX_BIT_PRD_POS (0)
#define UART_CR_UTX_BIT_PRD_LEN (16)
#define UART_CR_UTX_BIT_PRD_MSK \
(((1 << UART_CR_UTX_BIT_PRD_LEN) - 1) << UART_CR_UTX_BIT_PRD_POS)
#define UART_CR_UTX_BIT_PRD_UMSK \
(~(((1 << UART_CR_UTX_BIT_PRD_LEN) - 1) << UART_CR_UTX_BIT_PRD_POS))
#define UART_CR_URX_BIT_PRD UART_CR_URX_BIT_PRD
#define UART_CR_URX_BIT_PRD_POS (16)
#define UART_CR_URX_BIT_PRD_LEN (16)
#define UART_CR_URX_BIT_PRD_MSK \
(((1 << UART_CR_URX_BIT_PRD_LEN) - 1) << UART_CR_URX_BIT_PRD_POS)
#define UART_CR_URX_BIT_PRD_UMSK \
(~(((1 << UART_CR_URX_BIT_PRD_LEN) - 1) << UART_CR_URX_BIT_PRD_POS))
#define BL602_UART_UTX_CONFIG(n) (BL602_UART_BASE(n) + BL602_UART_UTX_CONFIG_OFFSET)
#define BL602_UART_URX_CONFIG(n) (BL602_UART_BASE(n) + BL602_UART_URX_CONFIG_OFFSET)
#define BL602_UART_BIT_PRD(n) (BL602_UART_BASE(n) + BL602_UART_BIT_PRD_OFFSET)
#define BL602_UART_DATA_CONFIG(n) (BL602_UART_BASE(n) + BL602_UART_DATA_CONFIG_OFFSET)
#define BL602_UART_UTX_IR_POSITION(n) (BL602_UART_BASE(n) + BL602_UART_UTX_IR_POSITION_OFFSET)
#define BL602_UART_URX_IR_POSITION(n) (BL602_UART_BASE(n) + BL602_UART_URX_IR_POSITION_OFFSET)
#define BL602_UART_URX_RTO_TIMER(n) (BL602_UART_BASE(n) + BL602_UART_URX_RTO_TIMER_OFFSET)
#define BL602_UART_INT_STS(n) (BL602_UART_BASE(n) + BL602_UART_INT_STS_OFFSET)
#define BL602_UART_INT_MASK(n) (BL602_UART_BASE(n) + BL602_UART_INT_MASK_OFFSET)
#define BL602_UART_INT_CLEAR(n) (BL602_UART_BASE(n) + BL602_UART_INT_CLEAR_OFFSET)
#define BL602_UART_INT_EN(n) (BL602_UART_BASE(n) + BL602_UART_INT_EN_OFFSET)
#define BL602_UART_STATUS(n) (BL602_UART_BASE(n) + BL602_UART_STATUS_OFFSET)
#define BL602_UART_STS_URX_ABR_PRD(n) (BL602_UART_BASE(n) + BL602_UART_STS_URX_ABR_PRD_OFFSET)
#define BL602_UART_FIFO_CONFIG_0(n) (BL602_UART_BASE(n) + BL602_UART_FIFO_CONFIG_0_OFFSET)
#define BL602_UART_FIFO_CONFIG_1(n) (BL602_UART_BASE(n) + BL602_UART_FIFO_CONFIG_1_OFFSET)
#define BL602_UART_FIFO_WDATA(n) (BL602_UART_BASE(n) + BL602_UART_FIFO_WDATA_OFFSET)
#define BL602_UART_FIFO_RDATA(n) (BL602_UART_BASE(n) + BL602_UART_FIFO_RDATA_OFFSET)
/* 0xC : data_config */
#define BL602_UART0_UTX_CONFIG (BL602_UART_UTX_CONFIG(0))
#define BL602_UART0_URX_CONFIG (BL602_UART_URX_CONFIG(0))
#define BL602_UART0_UART_BIT_PRD (BL602_UART_BIT_PRD(0))
#define BL602_UART0_DATA_CONFIG (BL602_UART_DATA_CONFIG(0))
#define BL602_UART0_UTX_IR_POSITION (BL602_UART_UTX_IR_POSITION(0))
#define BL602_UART0_URX_IR_POSITION (BL602_UART_URX_IR_POSITION(0))
#define BL602_UART0_URX_RTO_TIMER (BL602_UART_URX_RTO_TIMER(0))
#define BL602_UART0_UART_INT_STS (BL602_UART_INT_STS(0))
#define BL602_UART0_UART_INT_MASK (BL602_UART_INT_MASK(0))
#define BL602_UART0_UART_INT_CLEAR (BL602_UART_INT_CLEAR(0))
#define BL602_UART0_UART_INT_EN (BL602_UART_INT_EN(0))
#define BL602_UART0_UART_STATUS (BL602_UART_STATUS(0))
#define BL602_UART0_STS_URX_ABR_PRD (BL602_UART_STS_URX_ABR_PRD(0))
#define BL602_UART0_UART_FIFO_CONFIG_0 (BL602_UART_FIFO_CONFIG_0(0))
#define BL602_UART0_UART_FIFO_CONFIG_1 (BL602_UART_FIFO_CONFIG_1(0))
#define BL602_UART0_UART_FIFO_WDATA (BL602_UART_FIFO_WDATA(0))
#define BL602_UART0_UART_FIFO_RDATA (BL602_UART_FIFO_RDATA(0))
#define UART_DATA_CONFIG_OFFSET (0xC)
#define UART_CR_UART_BIT_INV UART_CR_UART_BIT_INV
#define UART_CR_UART_BIT_INV_POS (0)
#define UART_CR_UART_BIT_INV_LEN (1)
#define UART_CR_UART_BIT_INV_MSK \
(((1 << UART_CR_UART_BIT_INV_LEN) - 1) << UART_CR_UART_BIT_INV_POS)
#define UART_CR_UART_BIT_INV_UMSK \
(~(((1 << UART_CR_UART_BIT_INV_LEN) - 1) << UART_CR_UART_BIT_INV_POS))
#define BL602_UART1_UTX_CONFIG (BL602_UART_UTX_CONFIG(1))
#define BL602_UART1_URX_CONFIG (BL602_UART_URX_CONFIG(1))
#define BL602_UART1_UART_BIT_PRD (BL602_UART_BIT_PRD(1))
#define BL602_UART1_DATA_CONFIG (BL602_UART_DATA_CONFIG(1))
#define BL602_UART1_UTX_IR_POSITION (BL602_UART_UTX_IR_POSITION(1))
#define BL602_UART1_URX_IR_POSITION (BL602_UART_URX_IR_POSITION(1))
#define BL602_UART1_URX_RTO_TIMER (BL602_UART_URX_RTO_TIMER(1))
#define BL602_UART1_UART_INT_STS (BL602_UART_INT_STS(1))
#define BL602_UART1_UART_INT_MASK (BL602_UART_INT_MASK(1))
#define BL602_UART1_UART_INT_CLEAR (BL602_UART_INT_CLEAR(1))
#define BL602_UART1_UART_INT_EN (BL602_UART_INT_EN(1))
#define BL602_UART1_UART_STATUS (BL602_UART_STATUS(1))
#define BL602_UART1_STS_URX_ABR_PRD (BL602_UART_STS_URX_ABR_PRD(1))
#define BL602_UART1_UART_FIFO_CONFIG_0 (BL602_UART_FIFO_CONFIG_0(1))
#define BL602_UART1_UART_FIFO_CONFIG_1 (BL602_UART_FIFO_CONFIG_1(1))
#define BL602_UART1_UART_FIFO_WDATA (BL602_UART_FIFO_WDATA(1))
#define BL602_UART1_UART_FIFO_RDATA (BL602_UART_FIFO_RDATA(1))
/* 0x10 : utx_ir_position */
/* Register bit definitions *************************************************/
#define UART_UTX_IR_POSITION_OFFSET (0x10)
#define UART_CR_UTX_IR_POS_S UART_CR_UTX_IR_POS_S
#define UART_CR_UTX_IR_POS_S_POS (0)
#define UART_CR_UTX_IR_POS_S_LEN (16)
#define UART_CR_UTX_IR_POS_S_MSK \
(((1 << UART_CR_UTX_IR_POS_S_LEN) - 1) << UART_CR_UTX_IR_POS_S_POS)
#define UART_CR_UTX_IR_POS_S_UMSK \
(~(((1 << UART_CR_UTX_IR_POS_S_LEN) - 1) << UART_CR_UTX_IR_POS_S_POS))
#define UART_CR_UTX_IR_POS_P UART_CR_UTX_IR_POS_P
#define UART_CR_UTX_IR_POS_P_POS (16)
#define UART_CR_UTX_IR_POS_P_LEN (16)
#define UART_CR_UTX_IR_POS_P_MSK \
(((1 << UART_CR_UTX_IR_POS_P_LEN) - 1) << UART_CR_UTX_IR_POS_P_POS)
#define UART_CR_UTX_IR_POS_P_UMSK \
(~(((1 << UART_CR_UTX_IR_POS_P_LEN) - 1) << UART_CR_UTX_IR_POS_P_POS))
#define UART_UTX_CONFIG_CR_LEN_SHIFT (16)
#define UART_UTX_CONFIG_CR_LEN_MASK (0xffff << UART_UTX_CONFIG_CR_LEN_SHIFT)
#define UART_UTX_CONFIG_CR_BIT_CNT_P_SHIFT (12)
#define UART_UTX_CONFIG_CR_BIT_CNT_P_MASK (0x03 << UART_UTX_CONFIG_CR_BIT_CNT_P_SHIFT)
#define UART_UTX_CONFIG_CR_BIT_CNT_D_SHIFT (8)
#define UART_UTX_CONFIG_CR_BIT_CNT_D_MASK (0x07 << UART_UTX_CONFIG_CR_BIT_CNT_D_SHIFT)
#define UART_UTX_CONFIG_CR_IR_INV (1 << 7)
#define UART_UTX_CONFIG_CR_IR_EN (1 << 6)
#define UART_UTX_CONFIG_CR_PRT_SEL (1 << 5)
#define UART_UTX_CONFIG_CR_PRT_EN (1 << 4)
#define UART_UTX_CONFIG_CR_FRM_EN (1 << 2)
#define UART_UTX_CONFIG_CR_CTS_EN (1 << 1)
#define UART_UTX_CONFIG_CR_EN (1 << 0)
/* 0x14 : urx_ir_position */
#define UART_URX_CONFIG_CR_LEN_SHIFT (16)
#define UART_URX_CONFIG_CR_LEN_MASK (0xffff << UART_URX_CONFIG_CR_LEN_SHIFT)
#define UART_URX_CONFIG_CR_DEG_CNT_SHIFT (12)
#define UART_URX_CONFIG_CR_DEG_CNT_MASK (0x0f << UART_URX_CONFIG_CR_DEG_CNT_SHIFT)
#define UART_URX_CONFIG_CR_DEG_EN (1 << 11)
#define UART_URX_CONFIG_CR_BIT_CNT_D_SHIFT (8)
#define UART_URX_CONFIG_CR_BIT_CNT_D_MASK (0x07 << UART_URX_CONFIG_CR_BIT_CNT_D_SHIFT)
#define UART_URX_CONFIG_CR_IR_INV (1 << 7)
#define UART_URX_CONFIG_CR_IR_EN (1 << 6)
#define UART_URX_CONFIG_CR_PRT_SEL (1 << 5)
#define UART_URX_CONFIG_CR_PRT_EN (1 << 4)
#define UART_URX_CONFIG_CR_ABR_EN (1 << 3)
#define UART_URX_CONFIG_CR_RTS_SW_VAL (1 << 2)
#define UART_URX_CONFIG_CR_RTS_SW_MODE (1 << 1)
#define UART_URX_CONFIG_CR_EN (1 << 0)
#define UART_URX_IR_POSITION_OFFSET (0x14)
#define UART_CR_URX_IR_POS_S UART_CR_URX_IR_POS_S
#define UART_CR_URX_IR_POS_S_POS (0)
#define UART_CR_URX_IR_POS_S_LEN (16)
#define UART_CR_URX_IR_POS_S_MSK \
(((1 << UART_CR_URX_IR_POS_S_LEN) - 1) << UART_CR_URX_IR_POS_S_POS)
#define UART_CR_URX_IR_POS_S_UMSK \
(~(((1 << UART_CR_URX_IR_POS_S_LEN) - 1) << UART_CR_URX_IR_POS_S_POS))
#define UART_BIT_PRD_CR_URX_BIT_SHIFT (16)
#define UART_BIT_PRD_CR_URX_BIT_MASK (0xffff << UART_BIT_PRD_CR_URX_BIT_SHIFT)
#define UART_BIT_PRD_CR_UTX_BIT_MASK (0xffff)
/* 0x18 : urx_rto_timer */
#define UART_DATA_CONFIG_CR_UART_BIT_INV (1 << 0)
#define UART_URX_RTO_TIMER_OFFSET (0x18)
#define UART_CR_URX_RTO_VALUE UART_CR_URX_RTO_VALUE
#define UART_CR_URX_RTO_VALUE_POS (0)
#define UART_CR_URX_RTO_VALUE_LEN (8)
#define UART_CR_URX_RTO_VALUE_MSK \
(((1 << UART_CR_URX_RTO_VALUE_LEN) - 1) << UART_CR_URX_RTO_VALUE_POS)
#define UART_CR_URX_RTO_VALUE_UMSK \
(~(((1 << UART_CR_URX_RTO_VALUE_LEN) - 1) << UART_CR_URX_RTO_VALUE_POS))
#define UART_UTX_IR_POSITION_CR_IR_POS_P_SHIFT (16)
#define UART_UTX_IR_POSITION_CR_IR_POS_P_MASK (0xffff << UART_UTX_IR_POSITION_CR_IR_POS_P_SHIFT)
#define UART_UTX_IR_POSITION_CR_IR_POS_S_MASK (0xffff)
/* 0x20 : UART interrupt status */
#define UART_URX_IR_POSITION_CR_IR_POS_S_MASK (0xffff)
#define UART_INT_STS_OFFSET (0x20)
#define UART_UTX_END_INT UART_UTX_END_INT
#define UART_UTX_END_INT_POS (0)
#define UART_UTX_END_INT_LEN (1)
#define UART_UTX_END_INT_MSK \
(((1 << UART_UTX_END_INT_LEN) - 1) << UART_UTX_END_INT_POS)
#define UART_UTX_END_INT_UMSK \
(~(((1 << UART_UTX_END_INT_LEN) - 1) << UART_UTX_END_INT_POS))
#define UART_URX_END_INT UART_URX_END_INT
#define UART_URX_END_INT_POS (1)
#define UART_URX_END_INT_LEN (1)
#define UART_URX_END_INT_MSK \
(((1 << UART_URX_END_INT_LEN) - 1) << UART_URX_END_INT_POS)
#define UART_URX_END_INT_UMSK \
(~(((1 << UART_URX_END_INT_LEN) - 1) << UART_URX_END_INT_POS))
#define UART_UTX_FIFO_INT UART_UTX_FIFO_INT
#define UART_UTX_FIFO_INT_POS (2)
#define UART_UTX_FIFO_INT_LEN (1)
#define UART_UTX_FIFO_INT_MSK \
(((1 << UART_UTX_FIFO_INT_LEN) - 1) << UART_UTX_FIFO_INT_POS)
#define UART_UTX_FIFO_INT_UMSK \
(~(((1 << UART_UTX_FIFO_INT_LEN) - 1) << UART_UTX_FIFO_INT_POS))
#define UART_URX_FIFO_INT UART_URX_FIFO_INT
#define UART_URX_FIFO_INT_POS (3)
#define UART_URX_FIFO_INT_LEN (1)
#define UART_URX_FIFO_INT_MSK \
(((1 << UART_URX_FIFO_INT_LEN) - 1) << UART_URX_FIFO_INT_POS)
#define UART_URX_FIFO_INT_UMSK \
(~(((1 << UART_URX_FIFO_INT_LEN) - 1) << UART_URX_FIFO_INT_POS))
#define UART_URX_RTO_INT UART_URX_RTO_INT
#define UART_URX_RTO_INT_POS (4)
#define UART_URX_RTO_INT_LEN (1)
#define UART_URX_RTO_INT_MSK \
(((1 << UART_URX_RTO_INT_LEN) - 1) << UART_URX_RTO_INT_POS)
#define UART_URX_RTO_INT_UMSK \
(~(((1 << UART_URX_RTO_INT_LEN) - 1) << UART_URX_RTO_INT_POS))
#define UART_URX_PCE_INT UART_URX_PCE_INT
#define UART_URX_PCE_INT_POS (5)
#define UART_URX_PCE_INT_LEN (1)
#define UART_URX_PCE_INT_MSK \
(((1 << UART_URX_PCE_INT_LEN) - 1) << UART_URX_PCE_INT_POS)
#define UART_URX_PCE_INT_UMSK \
(~(((1 << UART_URX_PCE_INT_LEN) - 1) << UART_URX_PCE_INT_POS))
#define UART_UTX_FER_INT UART_UTX_FER_INT
#define UART_UTX_FER_INT_POS (6)
#define UART_UTX_FER_INT_LEN (1)
#define UART_UTX_FER_INT_MSK \
(((1 << UART_UTX_FER_INT_LEN) - 1) << UART_UTX_FER_INT_POS)
#define UART_UTX_FER_INT_UMSK \
(~(((1 << UART_UTX_FER_INT_LEN) - 1) << UART_UTX_FER_INT_POS))
#define UART_URX_FER_INT UART_URX_FER_INT
#define UART_URX_FER_INT_POS (7)
#define UART_URX_FER_INT_LEN (1)
#define UART_URX_FER_INT_MSK \
(((1 << UART_URX_FER_INT_LEN) - 1) << UART_URX_FER_INT_POS)
#define UART_URX_FER_INT_UMSK \
(~(((1 << UART_URX_FER_INT_LEN) - 1) << UART_URX_FER_INT_POS))
#define UART_URX_RTO_TIMER_CR_RTO_VALUE_MASK (0xff)
/* 0x24 : UART interrupt mask */
#define UART_INT_STS_URX_FER_INT (1 << 7)
#define UART_INT_STS_UTX_FER_INT (1 << 6)
#define UART_INT_STS_URX_PCE_INT (1 << 5)
#define UART_INT_STS_URX_RTO_INT (1 << 4)
#define UART_INT_STS_URX_FIFO_INT (1 << 3)
#define UART_INT_STS_UTX_FIFO_INT (1 << 2)
#define UART_INT_STS_URX_END_INT (1 << 1)
#define UART_INT_STS_UTX_END_INT (1 << 0)
#define UART_INT_MASK_OFFSET (0x24)
#define UART_CR_UTX_END_MASK UART_CR_UTX_END_MASK
#define UART_CR_UTX_END_MASK_POS (0)
#define UART_CR_UTX_END_MASK_LEN (1)
#define UART_CR_UTX_END_MASK_MSK \
(((1 << UART_CR_UTX_END_MASK_LEN) - 1) << UART_CR_UTX_END_MASK_POS)
#define UART_CR_UTX_END_MASK_UMSK \
(~(((1 << UART_CR_UTX_END_MASK_LEN) - 1) << UART_CR_UTX_END_MASK_POS))
#define UART_CR_URX_END_MASK UART_CR_URX_END_MASK
#define UART_CR_URX_END_MASK_POS (1)
#define UART_CR_URX_END_MASK_LEN (1)
#define UART_CR_URX_END_MASK_MSK \
(((1 << UART_CR_URX_END_MASK_LEN) - 1) << UART_CR_URX_END_MASK_POS)
#define UART_CR_URX_END_MASK_UMSK \
(~(((1 << UART_CR_URX_END_MASK_LEN) - 1) << UART_CR_URX_END_MASK_POS))
#define UART_CR_UTX_FIFO_MASK UART_CR_UTX_FIFO_MASK
#define UART_CR_UTX_FIFO_MASK_POS (2)
#define UART_CR_UTX_FIFO_MASK_LEN (1)
#define UART_CR_UTX_FIFO_MASK_MSK \
(((1 << UART_CR_UTX_FIFO_MASK_LEN) - 1) << UART_CR_UTX_FIFO_MASK_POS)
#define UART_CR_UTX_FIFO_MASK_UMSK \
(~(((1 << UART_CR_UTX_FIFO_MASK_LEN) - 1) << UART_CR_UTX_FIFO_MASK_POS))
#define UART_CR_URX_FIFO_MASK UART_CR_URX_FIFO_MASK
#define UART_CR_URX_FIFO_MASK_POS (3)
#define UART_CR_URX_FIFO_MASK_LEN (1)
#define UART_CR_URX_FIFO_MASK_MSK \
(((1 << UART_CR_URX_FIFO_MASK_LEN) - 1) << UART_CR_URX_FIFO_MASK_POS)
#define UART_CR_URX_FIFO_MASK_UMSK \
(~(((1 << UART_CR_URX_FIFO_MASK_LEN) - 1) << UART_CR_URX_FIFO_MASK_POS))
#define UART_CR_URX_RTO_MASK UART_CR_URX_RTO_MASK
#define UART_CR_URX_RTO_MASK_POS (4)
#define UART_CR_URX_RTO_MASK_LEN (1)
#define UART_CR_URX_RTO_MASK_MSK \
(((1 << UART_CR_URX_RTO_MASK_LEN) - 1) << UART_CR_URX_RTO_MASK_POS)
#define UART_CR_URX_RTO_MASK_UMSK \
(~(((1 << UART_CR_URX_RTO_MASK_LEN) - 1) << UART_CR_URX_RTO_MASK_POS))
#define UART_CR_URX_PCE_MASK UART_CR_URX_PCE_MASK
#define UART_CR_URX_PCE_MASK_POS (5)
#define UART_CR_URX_PCE_MASK_LEN (1)
#define UART_CR_URX_PCE_MASK_MSK \
(((1 << UART_CR_URX_PCE_MASK_LEN) - 1) << UART_CR_URX_PCE_MASK_POS)
#define UART_CR_URX_PCE_MASK_UMSK \
(~(((1 << UART_CR_URX_PCE_MASK_LEN) - 1) << UART_CR_URX_PCE_MASK_POS))
#define UART_CR_UTX_FER_MASK UART_CR_UTX_FER_MASK
#define UART_CR_UTX_FER_MASK_POS (6)
#define UART_CR_UTX_FER_MASK_LEN (1)
#define UART_CR_UTX_FER_MASK_MSK \
(((1 << UART_CR_UTX_FER_MASK_LEN) - 1) << UART_CR_UTX_FER_MASK_POS)
#define UART_CR_UTX_FER_MASK_UMSK \
(~(((1 << UART_CR_UTX_FER_MASK_LEN) - 1) << UART_CR_UTX_FER_MASK_POS))
#define UART_CR_URX_FER_MASK UART_CR_URX_FER_MASK
#define UART_CR_URX_FER_MASK_POS (7)
#define UART_CR_URX_FER_MASK_LEN (1)
#define UART_CR_URX_FER_MASK_MSK \
(((1 << UART_CR_URX_FER_MASK_LEN) - 1) << UART_CR_URX_FER_MASK_POS)
#define UART_CR_URX_FER_MASK_UMSK \
(~(((1 << UART_CR_URX_FER_MASK_LEN) - 1) << UART_CR_URX_FER_MASK_POS))
#define UART_INT_MASK_CR_URX_FER_MASK (1 << 7)
#define UART_INT_MASK_CR_UTX_FER_MASK (1 << 6)
#define UART_INT_MASK_CR_URX_PCE_MASK (1 << 5)
#define UART_INT_MASK_CR_URX_RTO_MASK (1 << 4)
#define UART_INT_MASK_CR_URX_FIFO_MASK (1 << 3)
#define UART_INT_MASK_CR_UTX_FIFO_MASK (1 << 2)
#define UART_INT_MASK_CR_URX_END_MASK (1 << 1)
#define UART_INT_MASK_CR_UTX_END_MASK (1 << 0)
/* 0x28 : UART interrupt clear */
#define UART_INT_CLEAR_RSVD_7 (1 << 7)
#define UART_INT_CLEAR_RSVD_6 (1 << 6)
#define UART_INT_CLEAR_CR_URX_PCE_CLR (1 << 5)
#define UART_INT_CLEAR_CR_URX_RTO_CLR (1 << 4)
#define UART_INT_CLEAR_RSVD_3 (1 << 3)
#define UART_INT_CLEAR_RSVD_2 (1 << 2)
#define UART_INT_CLEAR_CR_URX_END_CLR (1 << 1)
#define UART_INT_CLEAR_CR_UTX_END_CLR (1 << 0)
#define UART_INT_CLEAR_OFFSET (0x28)
#define UART_CR_UTX_END_CLR UART_CR_UTX_END_CLR
#define UART_CR_UTX_END_CLR_POS (0)
#define UART_CR_UTX_END_CLR_LEN (1)
#define UART_CR_UTX_END_CLR_MSK \
(((1 << UART_CR_UTX_END_CLR_LEN) - 1) << UART_CR_UTX_END_CLR_POS)
#define UART_CR_UTX_END_CLR_UMSK \
(~(((1 << UART_CR_UTX_END_CLR_LEN) - 1) << UART_CR_UTX_END_CLR_POS))
#define UART_CR_URX_END_CLR UART_CR_URX_END_CLR
#define UART_CR_URX_END_CLR_POS (1)
#define UART_CR_URX_END_CLR_LEN (1)
#define UART_CR_URX_END_CLR_MSK \
(((1 << UART_CR_URX_END_CLR_LEN) - 1) << UART_CR_URX_END_CLR_POS)
#define UART_CR_URX_END_CLR_UMSK \
(~(((1 << UART_CR_URX_END_CLR_LEN) - 1) << UART_CR_URX_END_CLR_POS))
#define UART_CR_URX_RTO_CLR UART_CR_URX_RTO_CLR
#define UART_CR_URX_RTO_CLR_POS (4)
#define UART_CR_URX_RTO_CLR_LEN (1)
#define UART_CR_URX_RTO_CLR_MSK \
(((1 << UART_CR_URX_RTO_CLR_LEN) - 1) << UART_CR_URX_RTO_CLR_POS)
#define UART_CR_URX_RTO_CLR_UMSK \
(~(((1 << UART_CR_URX_RTO_CLR_LEN) - 1) << UART_CR_URX_RTO_CLR_POS))
#define UART_CR_URX_PCE_CLR UART_CR_URX_PCE_CLR
#define UART_CR_URX_PCE_CLR_POS (5)
#define UART_CR_URX_PCE_CLR_LEN (1)
#define UART_CR_URX_PCE_CLR_MSK \
(((1 << UART_CR_URX_PCE_CLR_LEN) - 1) << UART_CR_URX_PCE_CLR_POS)
#define UART_CR_URX_PCE_CLR_UMSK \
(~(((1 << UART_CR_URX_PCE_CLR_LEN) - 1) << UART_CR_URX_PCE_CLR_POS))
#define UART_INT_EN_CR_URX_FER_EN (1 << 7)
#define UART_INT_EN_CR_UTX_FER_EN (1 << 6)
#define UART_INT_EN_CR_URX_PCE_EN (1 << 5)
#define UART_INT_EN_CR_URX_RTO_EN (1 << 4)
#define UART_INT_EN_CR_URX_FIFO_EN (1 << 3)
#define UART_INT_EN_CR_UTX_FIFO_EN (1 << 2)
#define UART_INT_EN_CR_URX_END_EN (1 << 1)
#define UART_INT_EN_CR_UTX_END_EN (1 << 0)
/* 0x2C : UART interrupt enable */
#define UART_STATUS_STS_URX_BUS_BUSY (1 << 1)
#define UART_STATUS_STS_UTX_BUS_BUSY (1 << 0)
#define UART_INT_EN_OFFSET (0x2C)
#define UART_CR_UTX_END_EN UART_CR_UTX_END_EN
#define UART_CR_UTX_END_EN_POS (0)
#define UART_CR_UTX_END_EN_LEN (1)
#define UART_CR_UTX_END_EN_MSK \
(((1 << UART_CR_UTX_END_EN_LEN) - 1) << UART_CR_UTX_END_EN_POS)
#define UART_CR_UTX_END_EN_UMSK \
(~(((1 << UART_CR_UTX_END_EN_LEN) - 1) << UART_CR_UTX_END_EN_POS))
#define UART_CR_URX_END_EN UART_CR_URX_END_EN
#define UART_CR_URX_END_EN_POS (1)
#define UART_CR_URX_END_EN_LEN (1)
#define UART_CR_URX_END_EN_MSK \
(((1 << UART_CR_URX_END_EN_LEN) - 1) << UART_CR_URX_END_EN_POS)
#define UART_CR_URX_END_EN_UMSK \
(~(((1 << UART_CR_URX_END_EN_LEN) - 1) << UART_CR_URX_END_EN_POS))
#define UART_CR_UTX_FIFO_EN UART_CR_UTX_FIFO_EN
#define UART_CR_UTX_FIFO_EN_POS (2)
#define UART_CR_UTX_FIFO_EN_LEN (1)
#define UART_CR_UTX_FIFO_EN_MSK \
(((1 << UART_CR_UTX_FIFO_EN_LEN) - 1) << UART_CR_UTX_FIFO_EN_POS)
#define UART_CR_UTX_FIFO_EN_UMSK \
(~(((1 << UART_CR_UTX_FIFO_EN_LEN) - 1) << UART_CR_UTX_FIFO_EN_POS))
#define UART_CR_URX_FIFO_EN UART_CR_URX_FIFO_EN
#define UART_CR_URX_FIFO_EN_POS (3)
#define UART_CR_URX_FIFO_EN_LEN (1)
#define UART_CR_URX_FIFO_EN_MSK \
(((1 << UART_CR_URX_FIFO_EN_LEN) - 1) << UART_CR_URX_FIFO_EN_POS)
#define UART_CR_URX_FIFO_EN_UMSK \
(~(((1 << UART_CR_URX_FIFO_EN_LEN) - 1) << UART_CR_URX_FIFO_EN_POS))
#define UART_CR_URX_RTO_EN UART_CR_URX_RTO_EN
#define UART_CR_URX_RTO_EN_POS (4)
#define UART_CR_URX_RTO_EN_LEN (1)
#define UART_CR_URX_RTO_EN_MSK \
(((1 << UART_CR_URX_RTO_EN_LEN) - 1) << UART_CR_URX_RTO_EN_POS)
#define UART_CR_URX_RTO_EN_UMSK \
(~(((1 << UART_CR_URX_RTO_EN_LEN) - 1) << UART_CR_URX_RTO_EN_POS))
#define UART_CR_URX_PCE_EN UART_CR_URX_PCE_EN
#define UART_CR_URX_PCE_EN_POS (5)
#define UART_CR_URX_PCE_EN_LEN (1)
#define UART_CR_URX_PCE_EN_MSK \
(((1 << UART_CR_URX_PCE_EN_LEN) - 1) << UART_CR_URX_PCE_EN_POS)
#define UART_CR_URX_PCE_EN_UMSK \
(~(((1 << UART_CR_URX_PCE_EN_LEN) - 1) << UART_CR_URX_PCE_EN_POS))
#define UART_CR_UTX_FER_EN UART_CR_UTX_FER_EN
#define UART_CR_UTX_FER_EN_POS (6)
#define UART_CR_UTX_FER_EN_LEN (1)
#define UART_CR_UTX_FER_EN_MSK \
(((1 << UART_CR_UTX_FER_EN_LEN) - 1) << UART_CR_UTX_FER_EN_POS)
#define UART_CR_UTX_FER_EN_UMSK \
(~(((1 << UART_CR_UTX_FER_EN_LEN) - 1) << UART_CR_UTX_FER_EN_POS))
#define UART_CR_URX_FER_EN UART_CR_URX_FER_EN
#define UART_CR_URX_FER_EN_POS (7)
#define UART_CR_URX_FER_EN_LEN (1)
#define UART_CR_URX_FER_EN_MSK \
(((1 << UART_CR_URX_FER_EN_LEN) - 1) << UART_CR_URX_FER_EN_POS)
#define UART_CR_URX_FER_EN_UMSK \
(~(((1 << UART_CR_URX_FER_EN_LEN) - 1) << UART_CR_URX_FER_EN_POS))
#define UART_STS_URX_ABR_PRD_0X55_SHIFT (16)
#define UART_STS_URX_ABR_PRD_0X55_MASK (0xffff << UART_STS_URX_ABR_PRD_0X55_SHIFT)
#define UART_STS_URX_ABR_PRD_START_MASK (0xffff)
/* 0x30 : uart_status */
#define UART_FIFO_CONFIG_0_RX_UNDERFLOW (1 << 7)
#define UART_FIFO_CONFIG_0_RX_OVERFLOW (1 << 6)
#define UART_FIFO_CONFIG_0_TX_UNDERFLOW (1 << 5)
#define UART_FIFO_CONFIG_0_TX_OVERFLOW (1 << 4)
#define UART_FIFO_CONFIG_0_RX_CLR (1 << 3)
#define UART_FIFO_CONFIG_0_TX_CLR (1 << 2)
#define UART_FIFO_CONFIG_0_DMA_RX_EN (1 << 1)
#define UART_FIFO_CONFIG_0_DMA_TX_EN (1 << 0)
#define UART_STATUS_OFFSET (0x30)
#define UART_STS_UTX_BUS_BUSY UART_STS_UTX_BUS_BUSY
#define UART_STS_UTX_BUS_BUSY_POS (0)
#define UART_STS_UTX_BUS_BUSY_LEN (1)
#define UART_STS_UTX_BUS_BUSY_MSK \
(((1 << UART_STS_UTX_BUS_BUSY_LEN) - 1) << UART_STS_UTX_BUS_BUSY_POS)
#define UART_STS_UTX_BUS_BUSY_UMSK \
(~(((1 << UART_STS_UTX_BUS_BUSY_LEN) - 1) << UART_STS_UTX_BUS_BUSY_POS))
#define UART_STS_URX_BUS_BUSY UART_STS_URX_BUS_BUSY
#define UART_STS_URX_BUS_BUSY_POS (1)
#define UART_STS_URX_BUS_BUSY_LEN (1)
#define UART_STS_URX_BUS_BUSY_MSK \
(((1 << UART_STS_URX_BUS_BUSY_LEN) - 1) << UART_STS_URX_BUS_BUSY_POS)
#define UART_STS_URX_BUS_BUSY_UMSK \
(~(((1 << UART_STS_URX_BUS_BUSY_LEN) - 1) << UART_STS_URX_BUS_BUSY_POS))
#define UART_FIFO_CONFIG_1_RX_TH_SHIFT (24)
#define UART_FIFO_CONFIG_1_RX_TH_MASK (0x1f << UART_FIFO_CONFIG_1_RX_TH_SHIFT)
#define UART_FIFO_CONFIG_1_TX_TH_SHIFT (16)
#define UART_FIFO_CONFIG_1_TX_TH_MASK (0x1f << UART_FIFO_CONFIG_1_TX_TH_SHIFT)
#define UART_FIFO_CONFIG_1_RX_CNT_SHIFT (8)
#define UART_FIFO_CONFIG_1_RX_CNT_MASK (0x3f << UART_FIFO_CONFIG_1_RX_CNT_SHIFT)
#define UART_FIFO_CONFIG_1_TX_CNT_MASK (0x3f)
/* 0x34 : sts_urx_abr_prd */
#define UART_FIFO_WDATA_MASK (0xff)
#define UART_STS_URX_ABR_PRD_OFFSET (0x34)
#define UART_STS_URX_ABR_PRD_START UART_STS_URX_ABR_PRD_START
#define UART_STS_URX_ABR_PRD_START_POS (0)
#define UART_STS_URX_ABR_PRD_START_LEN (16)
#define UART_STS_URX_ABR_PRD_START_MSK \
(((1 << UART_STS_URX_ABR_PRD_START_LEN) - 1) \
<< UART_STS_URX_ABR_PRD_START_POS)
#define UART_STS_URX_ABR_PRD_START_UMSK \
(~(((1 << UART_STS_URX_ABR_PRD_START_LEN) - 1) \
<< UART_STS_URX_ABR_PRD_START_POS))
#define UART_STS_URX_ABR_PRD_0X55 UART_STS_URX_ABR_PRD_0X55
#define UART_STS_URX_ABR_PRD_0X55_POS (16)
#define UART_STS_URX_ABR_PRD_0X55_LEN (16)
#define UART_STS_URX_ABR_PRD_0X55_MSK \
(((1 << UART_STS_URX_ABR_PRD_0X55_LEN) - 1) \
<< UART_STS_URX_ABR_PRD_0X55_POS)
#define UART_STS_URX_ABR_PRD_0X55_UMSK \
(~(((1 << UART_STS_URX_ABR_PRD_0X55_LEN) - 1) \
<< UART_STS_URX_ABR_PRD_0X55_POS))
#define UART_FIFO_RDATA_MASK (0xff)
/* 0x80 : uart_fifo_config_0 */
#define UART_FIFO_CONFIG_0_OFFSET (0x80)
#define UART_DMA_TX_EN UART_DMA_TX_EN
#define UART_DMA_TX_EN_POS (0)
#define UART_DMA_TX_EN_LEN (1)
#define UART_DMA_TX_EN_MSK \
(((1 << UART_DMA_TX_EN_LEN) - 1) << UART_DMA_TX_EN_POS)
#define UART_DMA_TX_EN_UMSK \
(~(((1 << UART_DMA_TX_EN_LEN) - 1) << UART_DMA_TX_EN_POS))
#define UART_DMA_RX_EN UART_DMA_RX_EN
#define UART_DMA_RX_EN_POS (1)
#define UART_DMA_RX_EN_LEN (1)
#define UART_DMA_RX_EN_MSK \
(((1 << UART_DMA_RX_EN_LEN) - 1) << UART_DMA_RX_EN_POS)
#define UART_DMA_RX_EN_UMSK \
(~(((1 << UART_DMA_RX_EN_LEN) - 1) << UART_DMA_RX_EN_POS))
#define UART_TX_FIFO_CLR UART_TX_FIFO_CLR
#define UART_TX_FIFO_CLR_POS (2)
#define UART_TX_FIFO_CLR_LEN (1)
#define UART_TX_FIFO_CLR_MSK \
(((1 << UART_TX_FIFO_CLR_LEN) - 1) << UART_TX_FIFO_CLR_POS)
#define UART_TX_FIFO_CLR_UMSK \
(~(((1 << UART_TX_FIFO_CLR_LEN) - 1) << UART_TX_FIFO_CLR_POS))
#define UART_RX_FIFO_CLR UART_RX_FIFO_CLR
#define UART_RX_FIFO_CLR_POS (3)
#define UART_RX_FIFO_CLR_LEN (1)
#define UART_RX_FIFO_CLR_MSK \
(((1 << UART_RX_FIFO_CLR_LEN) - 1) << UART_RX_FIFO_CLR_POS)
#define UART_RX_FIFO_CLR_UMSK \
(~(((1 << UART_RX_FIFO_CLR_LEN) - 1) << UART_RX_FIFO_CLR_POS))
#define UART_TX_FIFO_OVERFLOW UART_TX_FIFO_OVERFLOW
#define UART_TX_FIFO_OVERFLOW_POS (4)
#define UART_TX_FIFO_OVERFLOW_LEN (1)
#define UART_TX_FIFO_OVERFLOW_MSK \
(((1 << UART_TX_FIFO_OVERFLOW_LEN) - 1) << UART_TX_FIFO_OVERFLOW_POS)
#define UART_TX_FIFO_OVERFLOW_UMSK \
(~(((1 << UART_TX_FIFO_OVERFLOW_LEN) - 1) << UART_TX_FIFO_OVERFLOW_POS))
#define UART_TX_FIFO_UNDERFLOW UART_TX_FIFO_UNDERFLOW
#define UART_TX_FIFO_UNDERFLOW_POS (5)
#define UART_TX_FIFO_UNDERFLOW_LEN (1)
#define UART_TX_FIFO_UNDERFLOW_MSK \
(((1 << UART_TX_FIFO_UNDERFLOW_LEN) - 1) << UART_TX_FIFO_UNDERFLOW_POS)
#define UART_TX_FIFO_UNDERFLOW_UMSK \
(~(((1 << UART_TX_FIFO_UNDERFLOW_LEN) - 1) << UART_TX_FIFO_UNDERFLOW_POS))
#define UART_RX_FIFO_OVERFLOW UART_RX_FIFO_OVERFLOW
#define UART_RX_FIFO_OVERFLOW_POS (6)
#define UART_RX_FIFO_OVERFLOW_LEN (1)
#define UART_RX_FIFO_OVERFLOW_MSK \
(((1 << UART_RX_FIFO_OVERFLOW_LEN) - 1) << UART_RX_FIFO_OVERFLOW_POS)
#define UART_RX_FIFO_OVERFLOW_UMSK \
(~(((1 << UART_RX_FIFO_OVERFLOW_LEN) - 1) << UART_RX_FIFO_OVERFLOW_POS))
#define UART_RX_FIFO_UNDERFLOW UART_RX_FIFO_UNDERFLOW
#define UART_RX_FIFO_UNDERFLOW_POS (7)
#define UART_RX_FIFO_UNDERFLOW_LEN (1)
#define UART_RX_FIFO_UNDERFLOW_MSK \
(((1 << UART_RX_FIFO_UNDERFLOW_LEN) - 1) << UART_RX_FIFO_UNDERFLOW_POS)
#define UART_RX_FIFO_UNDERFLOW_UMSK \
(~(((1 << UART_RX_FIFO_UNDERFLOW_LEN) - 1) << UART_RX_FIFO_UNDERFLOW_POS))
/* 0x84 : uart_fifo_config_1 */
#define UART_FIFO_CONFIG_1_OFFSET (0x84)
#define UART_TX_FIFO_CNT UART_TX_FIFO_CNT
#define UART_TX_FIFO_CNT_POS (0)
#define UART_TX_FIFO_CNT_LEN (6)
#define UART_TX_FIFO_CNT_MSK \
(((1 << UART_TX_FIFO_CNT_LEN) - 1) << UART_TX_FIFO_CNT_POS)
#define UART_TX_FIFO_CNT_UMSK \
(~(((1 << UART_TX_FIFO_CNT_LEN) - 1) << UART_TX_FIFO_CNT_POS))
#define UART_RX_FIFO_CNT UART_RX_FIFO_CNT
#define UART_RX_FIFO_CNT_POS (8)
#define UART_RX_FIFO_CNT_LEN (6)
#define UART_RX_FIFO_CNT_MSK \
(((1 << UART_RX_FIFO_CNT_LEN) - 1) << UART_RX_FIFO_CNT_POS)
#define UART_RX_FIFO_CNT_UMSK \
(~(((1 << UART_RX_FIFO_CNT_LEN) - 1) << UART_RX_FIFO_CNT_POS))
#define UART_TX_FIFO_TH UART_TX_FIFO_TH
#define UART_TX_FIFO_TH_POS (16)
#define UART_TX_FIFO_TH_LEN (5)
#define UART_TX_FIFO_TH_MSK \
(((1 << UART_TX_FIFO_TH_LEN) - 1) << UART_TX_FIFO_TH_POS)
#define UART_TX_FIFO_TH_UMSK \
(~(((1 << UART_TX_FIFO_TH_LEN) - 1) << UART_TX_FIFO_TH_POS))
#define UART_RX_FIFO_TH UART_RX_FIFO_TH
#define UART_RX_FIFO_TH_POS (24)
#define UART_RX_FIFO_TH_LEN (5)
#define UART_RX_FIFO_TH_MSK \
(((1 << UART_RX_FIFO_TH_LEN) - 1) << UART_RX_FIFO_TH_POS)
#define UART_RX_FIFO_TH_UMSK \
(~(((1 << UART_RX_FIFO_TH_LEN) - 1) << UART_RX_FIFO_TH_POS))
/* 0x88 : uart_fifo_wdata */
#define UART_FIFO_WDATA_OFFSET (0x88)
#define UART_FIFO_WDATA UART_FIFO_WDATA
#define UART_FIFO_WDATA_POS (0)
#define UART_FIFO_WDATA_LEN (8)
#define UART_FIFO_WDATA_MSK \
(((1 << UART_FIFO_WDATA_LEN) - 1) << UART_FIFO_WDATA_POS)
#define UART_FIFO_WDATA_UMSK \
(~(((1 << UART_FIFO_WDATA_LEN) - 1) << UART_FIFO_WDATA_POS))
/* 0x8C : uart_fifo_rdata */
#define UART_FIFO_RDATA_OFFSET (0x8C)
#define UART_FIFO_RDATA UART_FIFO_RDATA
#define UART_FIFO_RDATA_POS (0)
#define UART_FIFO_RDATA_LEN (8)
#define UART_FIFO_RDATA_MSK \
(((1 << UART_FIFO_RDATA_LEN) - 1) << UART_FIFO_RDATA_POS)
#define UART_FIFO_RDATA_UMSK \
(~(((1 << UART_FIFO_RDATA_LEN) - 1) << UART_FIFO_RDATA_POS))
/* UART port type definition */
#define UART0_ID 0 /* UART0 port define */
#define UART1_ID 1 /* UART1 port define */
#define UART_ID_MAX 2 /* UART MAX ID define */
/* UART parity type definition */
#define UART_PARITY_NONE 0 /* UART parity none define */
#define UART_PARITY_ODD 1 /* UART parity odd define */
#define UART_PARITY_EVEN 2 /* UART parity even define */
/* UART data bits type definiton */
#define UART_DATABITS_5 0 /* UART data bits length:5 bits */
#define UART_DATABITS_6 1 /* UART data bits length:6 bits */
#define UART_DATABITS_7 2 /* UART data bits length:7 bits */
#define UART_DATABITS_8 3 /* UART data bits length:8 bits */
/* UART stop bits type definiton */
#define UART_STOPBITS_1 0 /* UART data stop bits length:1 bits */
#define UART_STOPBITS_1_5 1 /* UART data stop bits length:1.5 bits */
#define UART_STOPBITS_2 2 /* UART data stop bits length:2 bits */
/* UART each data byte is send out LSB-first or MSB-first type definiton */
#define UART_LSB_FIRST 0 /* UART each byte is send out LSB-first */
#define UART_MSB_FIRST 1 /* UART each byte is send out MSB-first */
/* UART auto baudrate detection using codeword 0x55 */
#define UART_AUTOBAUD_0X55 0
/* UART auto baudrate detection using start bit */
#define UART_AUTOBAUD_STARTBIT 1
/* UART interrupt type definition */
#define UART_INT_TX_END 0 /* UART tx transfer end interrupt */
#define UART_INT_RX_END 1 /* UART rx transfer end interrupt */
#define UART_INT_TX_FIFO_REQ \
2 /* UART tx fifo interrupt when tx fifo count \
* reaches,auto clear */
#define UART_INT_RX_FIFO_REQ \
3 /* UART rx fifo interrupt when rx fifo count \
* reaches,auto clear */
#define UART_INT_RTO 4 /* UART rx time-out interrupt */
#define UART_INT_PCE 5 /* UART rx parity check error interrupt */
#define UART_INT_TX_FER \
6 /* UART tx fifo overflow/underflow error interrupt */
#define UART_INT_RX_FER \
7 /* UART rx fifo overflow/underflow error interrupt */
#define UART_INT_ALL 8 /* All the interrupt */
/* UART overflow or underflow type definition */
#define UART_TX_OVERFLOW 0 /* UART tx fifo overflow */
#define UART_TX_UNDERFLOW 1 /* UART tx fifo underflow */
#define UART_RX_OVERFLOW 2 /* UART rx fifo overflow */
#define UART_RX_UNDERFLOW 3 /* UART rx fifo underflow */
/****************************************************************************
* Public Types
****************************************************************************/
#ifndef __ASSEMBLY__
#endif /* __ASSEMBLY__ */
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_BL602_UART_H */

View File

@ -1,43 +0,0 @@
/****************************************************************************
* arch/risc-v/src/bl602/hardware/clic.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
#ifndef __ARCH_RISCV_SRC_BL602_HARDWARE_CLIC_H
#define __ARCH_RISCV_SRC_BL602_HARDWARE_CLIC_H
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
#define CLIC_CTRL_ADDR 0x02000000
#define CLIC_HART0_ADDR 0x02800000
#define CLIC_MSIP 0x0000
#define CLIC_MSIP_size 0x4
#define CLIC_MTIMECMP 0x4000
#define CLIC_MTIMECMP_size 0x8
#define CLIC_MTIME 0xBFF8
#define CLIC_MTIME_size 0x8
#define CLIC_INTIP 0x000
#define CLIC_INTIE 0x400
#define CLIC_INTCFG 0x800
#define CLIC_CFG 0xc00
#endif /* __ARCH_RISCV_SRC_BL602_HARDWARE_CLIC_H */

View File

@ -27,10 +27,19 @@
#include <nuttx/config.h>
/* Do not include BL602 header files here. */
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* UART Configuration */
#define BOARD_UART_0_RX_PIN (GPIO_INPUT | GPIO_PULLUP | GPIO_FUNC_UART | GPIO_PIN7)
#define BOARD_UART_0_TX_PIN (GPIO_INPUT | GPIO_PULLUP | GPIO_FUNC_UART | GPIO_PIN16)
#define BOARD_UART_1_RX_PIN (GPIO_INPUT | GPIO_PULLUP | GPIO_FUNC_UART | GPIO_PIN3)
#define BOARD_UART_1_TX_PIN (GPIO_INPUT | GPIO_PULLUP | GPIO_FUNC_UART | GPIO_PIN4)
/****************************************************************************
* Public Types
****************************************************************************/