mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2026-06-12 20:24:15 +08:00
add yichip/yc3121-pos bsp
This commit is contained in:
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,44 @@
|
||||
./.vscode/*
|
||||
./build/*
|
||||
*.pyc
|
||||
*.map
|
||||
*.dblite
|
||||
*.elf
|
||||
*.bin
|
||||
*.hex
|
||||
*.axf
|
||||
*.exe
|
||||
*.pdb
|
||||
*.idb
|
||||
*.ilk
|
||||
*.old
|
||||
build
|
||||
Debug
|
||||
documentation/html
|
||||
packages/
|
||||
*~
|
||||
*.o
|
||||
*.obj
|
||||
*.out
|
||||
*.bak
|
||||
*.dep
|
||||
*.lib
|
||||
*.i
|
||||
*.d
|
||||
.DS_Stor*
|
||||
.config 3
|
||||
.config 4
|
||||
.config 5
|
||||
Midea-X1
|
||||
*.uimg
|
||||
GPATH
|
||||
GRTAGS
|
||||
GTAGS
|
||||
.vscode
|
||||
JLinkLog.txt
|
||||
JLinkSettings.ini
|
||||
DebugConfig/
|
||||
RTE/
|
||||
settings/
|
||||
*.uvguix*
|
||||
cconfig.h
|
||||
@@ -0,0 +1,25 @@
|
||||
# files format check exclude path, please follow the instructions below to modify;
|
||||
# If you need to exclude an entire folder, add the folder path in dir_path;
|
||||
# If you need to exclude a file, add the path to the file in file_path.
|
||||
|
||||
file_path:
|
||||
- Libraries/core/board_config.h
|
||||
- Libraries/core/misc.c
|
||||
- Libraries/core/misc.h
|
||||
- Libraries/core/rom_api.h
|
||||
- Libraries/core/system.c
|
||||
- Libraries/core/system.h
|
||||
- Libraries/core/type.h
|
||||
- Libraries/core/yc3121.h
|
||||
- Libraries/sdk/yc_dma.c
|
||||
- Libraries/sdk/yc_dma.h
|
||||
- Libraries/sdk/yc_gpio.c
|
||||
- Libraries/sdk/yc_gpio.h
|
||||
- Libraries/sdk/yc_systick.c
|
||||
- Libraries/sdk/yc_uart.c
|
||||
- Libraries/sdk/yc_uart.h
|
||||
|
||||
dir_path:
|
||||
- Libraries/core
|
||||
- Libraries/sdk
|
||||
- Libraries/startup
|
||||
@@ -0,0 +1,27 @@
|
||||
mainmenu "RT-Thread Configuration"
|
||||
|
||||
config BSP_DIR
|
||||
string
|
||||
option env="BSP_ROOT"
|
||||
default "."
|
||||
|
||||
config RTT_DIR
|
||||
string
|
||||
option env="RTT_ROOT"
|
||||
default "../.."
|
||||
|
||||
config PKGS_DIR
|
||||
string
|
||||
option env="PKGS_ROOT"
|
||||
default "packages"
|
||||
|
||||
source "$RTT_DIR/Kconfig"
|
||||
source "$PKGS_DIR/Kconfig"
|
||||
|
||||
config SOC_SWM320VET7
|
||||
bool
|
||||
select RT_USING_COMPONENTS_INIT
|
||||
select RT_USING_USER_MAIN
|
||||
default y
|
||||
|
||||
source "drivers/Kconfig"
|
||||
@@ -0,0 +1,17 @@
|
||||
from building import *
|
||||
import rtconfig
|
||||
cwd = GetCurrentDir()
|
||||
src = Glob('sdk/*.c')
|
||||
CPPPATH = [cwd + '/sdk', cwd + '/core', cwd]
|
||||
|
||||
src += Glob('core/*.c')
|
||||
|
||||
if rtconfig.CROSS_TOOL == 'gcc':
|
||||
src += ['startup/flash_start_gcc.s']
|
||||
elif rtconfig.CROSS_TOOL == 'keil':
|
||||
src += ['startup/startup.s', 'startup/flash_start.s']
|
||||
elif rtconfig.CROSS_TOOL == 'iar':
|
||||
src += ['startup/flash_start_iar.s']
|
||||
group = DefineGroup('Libraries', src, depend = [''], CPPPATH = CPPPATH)
|
||||
|
||||
Return('group')
|
||||
@@ -0,0 +1,275 @@
|
||||
/*
|
||||
File Name : board_config.h
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2020/07/17
|
||||
Description : board I/O config file.
|
||||
*/
|
||||
|
||||
#ifndef __BOARD_CONFIG_H__
|
||||
#define __BOARD_CONFIG_H__
|
||||
|
||||
#include "yc3121.h"
|
||||
#include "yc_gpio.h"
|
||||
#include "yc_exti.h"
|
||||
#include "yc_spi.h"
|
||||
|
||||
//开发板选择
|
||||
#define MPOS_BOARD_V2_1 0
|
||||
#define EPOS_BOARD_V1_0 1
|
||||
#define BOARD_VER EPOS_BOARD_V1_0
|
||||
|
||||
//ADC管脚配置
|
||||
#define ADC_IO_PORT GPIOC
|
||||
#define ADC2_IO_PIN GPIO_Pin_7
|
||||
#define ADC3_IO_PIN GPIO_Pin_8
|
||||
|
||||
//外部中断管脚配置
|
||||
#define EXTI_PORT EXTI_Line0
|
||||
#define EXTI_PIN EXTI_PinSource14
|
||||
|
||||
#if (BOARD_VER == MPOS_BOARD_V2_1)
|
||||
//DEBUG串口配置
|
||||
#define UARTBAUD 921600
|
||||
#define UART0_TX_PORT GPIOA
|
||||
#define UART0_TX_PIN GPIO_Pin_1
|
||||
#define UART0_RX_PORT GPIOA
|
||||
#define UART0_RX_PIN GPIO_Pin_0
|
||||
|
||||
//串口1配置
|
||||
#define UART1_TX_PORT GPIOA
|
||||
#define UART1_TX_PIN GPIO_Pin_14
|
||||
#define UART1_RX_PORT GPIOA
|
||||
#define UART1_RX_PIN GPIO_Pin_15
|
||||
|
||||
//BEEP驱动IO
|
||||
#define BEEP_PWM 0
|
||||
#define BEEP_PORT GPIOA
|
||||
#define BEEP_PIN GPIO_Pin_11
|
||||
|
||||
//IC卡在位检测IO
|
||||
#define DET_PORT GPIOC
|
||||
#define DET_PIN GPIO_Pin_12
|
||||
|
||||
//NFC IO
|
||||
#define NFC_SPI SPI1
|
||||
#define NFC_12M_CLK_PORT GPIOA
|
||||
#define NFC_12M_CLK_PIN GPIO_Pin_3
|
||||
|
||||
#define NFC_RST_PORT GPIOA
|
||||
#define NFC_RST_PIN GPIO_Pin_4
|
||||
|
||||
#define NFC_SPI_MISO_PORT GPIOB
|
||||
#define NFC_SPI_MISO_PIN GPIO_Pin_2
|
||||
|
||||
#define NFC_SPI_MOSI_PORT GPIOB
|
||||
#define NFC_SPI_MOSI_PIN GPIO_Pin_1
|
||||
|
||||
#define NFC_SPI_SCL_PORT GPIOB
|
||||
#define NFC_SPI_SCL_PIN GPIO_Pin_0
|
||||
|
||||
#define NFC_SPI_CS_PORT GPIOB
|
||||
#define NFC_SPI_CS_PIN GPIO_Pin_6
|
||||
|
||||
//EEPROM写保护控制IO
|
||||
#define IIC_WP2_PORT GPIOB
|
||||
#define IIC_WP2_PIN GPIO_Pin_0
|
||||
#define IIC_WP128_PORT GPIOC
|
||||
#define IIC_WP128_PIN GPIO_Pin_10
|
||||
|
||||
//IIC驱动IO
|
||||
#define IIC_SDA_PORT GPIOB
|
||||
#define IIC_SDA_PIN GPIO_Pin_2
|
||||
#define IIC_SCL_PORT GPIOA
|
||||
#define IIC_SCL_PIN GPIO_Pin_11
|
||||
|
||||
//KEYBOARD配置
|
||||
#define GPIO_GROUP_Line_1 GPIOC
|
||||
#define Line_1 GPIO_Pin_7
|
||||
|
||||
#define GPIO_GROUP_Line_2 GPIOC
|
||||
#define Line_2 GPIO_Pin_9
|
||||
|
||||
#define GPIO_GROUP_Line_3 GPIOC
|
||||
#define Line_3 GPIO_Pin_8
|
||||
|
||||
#define GPIO_GROUP_Line_4 GPIOC
|
||||
#define Line_4 GPIO_Pin_10
|
||||
|
||||
#define GPIO_GROUP_Line_5 GPIOC
|
||||
#define Line_5 GPIO_Pin_11
|
||||
|
||||
//LCD屏幕驱动配置
|
||||
#define LCD_SPI SPI0
|
||||
#define LCDSDA_PIN GPIO_Pin_1
|
||||
#define LCDSDA_PORT GPIOB
|
||||
#define LCDSCL_PIN GPIO_Pin_0
|
||||
#define LCDSCL_PORT GPIOB
|
||||
#define LCDCS_PIN GPIO_Pin_6
|
||||
#define LCDCS_PORT GPIOC
|
||||
#define LCDRST_PIN GPIO_Pin_5
|
||||
#define LCDRST_PORT GPIOA
|
||||
#define LCDA0_PIN GPIO_Pin_10
|
||||
#define LCDA0_PORT GPIOA
|
||||
#define LCDBL_PIN GPIO_Pin_2
|
||||
#define LCDBL_PORT GPIOA
|
||||
|
||||
#elif (BOARD_VER == EPOS_BOARD_V1_0)
|
||||
//DEBUG串口配置
|
||||
#define UARTBAUD 921600
|
||||
#define UART0_TX_PORT GPIOA
|
||||
#define UART0_TX_PIN GPIO_Pin_1
|
||||
#define UART0_RX_PORT GPIOA
|
||||
#define UART0_RX_PIN GPIO_Pin_0
|
||||
|
||||
//串口1配置
|
||||
#define UART1_TX_PORT GPIOA
|
||||
#define UART1_TX_PIN GPIO_Pin_14
|
||||
#define UART1_RX_PORT GPIOA
|
||||
#define UART1_RX_PIN GPIO_Pin_15
|
||||
|
||||
//BEEP驱动IO
|
||||
#define BEEP_PWM 0
|
||||
#define BEEP_PORT GPIOC
|
||||
#define BEEP_PIN GPIO_Pin_1
|
||||
|
||||
//IC卡在位检测IO
|
||||
#define DET_PORT GPIOA
|
||||
#define DET_PIN GPIO_Pin_4
|
||||
|
||||
//NFC IO
|
||||
#define NFC_SPI SPI1
|
||||
#define NFC_12M_CLK_PORT GPIOC
|
||||
#define NFC_12M_CLK_PIN GPIO_Pin_10
|
||||
|
||||
#define NFC_RST_PORT GPIOC
|
||||
#define NFC_RST_PIN GPIO_Pin_5
|
||||
|
||||
#define NFC_TVDD_PORT GPIOC
|
||||
#define NFC_TVDD_PIN GPIO_Pin_4
|
||||
|
||||
#define NFC_SPI_MISO_PORT GPIOC
|
||||
#define NFC_SPI_MISO_PIN GPIO_Pin_6
|
||||
|
||||
#define NFC_SPI_MOSI_PORT GPIOC
|
||||
#define NFC_SPI_MOSI_PIN GPIO_Pin_7
|
||||
|
||||
#define NFC_SPI_SCL_PORT GPIOC
|
||||
#define NFC_SPI_SCL_PIN GPIO_Pin_8
|
||||
|
||||
#define NFC_SPI_CS_PORT GPIOC
|
||||
#define NFC_SPI_CS_PIN GPIO_Pin_9
|
||||
|
||||
//IIC驱动IO
|
||||
|
||||
//KEYBOARD配置
|
||||
#define KEY_PORT_1 GPIOA
|
||||
#define KEY_PIN_1 GPIO_Pin_9
|
||||
|
||||
#define KEY_PORT_2 GPIOA
|
||||
#define KEY_PIN_2 GPIO_Pin_15
|
||||
|
||||
#define KEY_PORT_3 GPIOA
|
||||
#define KEY_PIN_3 GPIO_Pin_14
|
||||
|
||||
#define KEY_PORT_4 GPIOA
|
||||
#define KEY_PIN_4 GPIO_Pin_8
|
||||
|
||||
#define KEY_PORT_5 GPIOA
|
||||
#define KEY_PIN_5 GPIO_Pin_7
|
||||
|
||||
#define KEY_PORT_6 GPIOA
|
||||
#define KEY_PIN_6 GPIO_Pin_6
|
||||
|
||||
//TFT屏幕驱动配置
|
||||
#define ST7789VTFTSPI SPI1
|
||||
#define ST7789_TFT_SDA_PIN GPIO_Pin_7
|
||||
#define ST7789_TFT_SDA_PORT GPIOC
|
||||
|
||||
#define ST7789_TFT_A0_PIN GPIO_Pin_10
|
||||
#define ST7789_TFT_A0_PORT GPIOA
|
||||
|
||||
#define ST7789_TFT_SCL_PIN GPIO_Pin_8
|
||||
#define ST7789_TFT_SCL_PORT GPIOC
|
||||
|
||||
#define ST7789_TFT_RST_PIN GPIO_Pin_11
|
||||
#define ST7789_TFT_RST_PORT GPIOA
|
||||
|
||||
#define ST7789_TFT_CS_PIN GPIO_Pin_5
|
||||
#define ST7789_TFT_CS_PORT GPIOA
|
||||
|
||||
#define ST7789_TFT_BL_PIN GPIO_Pin_12
|
||||
#define ST7789_TFT_BL_PORT GPIOA
|
||||
#define ST7789_TFT_BL_HIGH_LIGHT 1
|
||||
|
||||
/*QRdecode tft */
|
||||
//tft camera io
|
||||
#define QR_CAMERA_FREQ 24
|
||||
#define QR_CAMERA_SDA 28
|
||||
#define QR_CAMERA_SCL 29
|
||||
#define QR_CAMERA_RST 32
|
||||
#define QR_CAMERA_PD 31//power down
|
||||
#define QR_CAMERA_MCLK 35
|
||||
#define QR_CAMERA_PCLK 34
|
||||
#define QR_CAMERA_DATA 30
|
||||
#define QR_CAMERA_CS 42
|
||||
|
||||
//tft io
|
||||
#define QR_TFT_RST (11) /*rst pin*/
|
||||
#define QR_TFT_CS ( 5) /*cs pin*/
|
||||
#define QR_TFT_CLK (40) /*clk pin*/
|
||||
#define QR_TFT_MOSI (39) /*mosi pin*/
|
||||
#define QR_TFT_A0 (10) /*a0 pin*/
|
||||
#define QR_TFT_BL (12 | (1 << 7)) /*bl pin*/
|
||||
#define QR_TFT_START_COLUMN ( (320 - 236) / 2 ) /*display center*/
|
||||
|
||||
//key io
|
||||
#define QR_KEY_T_MATRIX ( 0) /*key mode :0: T matrix key,1:matrix key*/
|
||||
#define QR_KEY_LINE_NUM ( 6) /*Value range 0~10*/
|
||||
#define QR_KEY_COL_NUM ( 0) /*Value range (T matrix key: 0)*/
|
||||
#define QR_KEY_CANCEL_POSTION ( (5 << 4) | 6 ) /*Exit key*/
|
||||
#define QR_KEY_LINE_1 ( 9) /*GPIO pin*/
|
||||
#define QR_KEY_LINE_2 (15) /*GPIO pin*/
|
||||
#define QR_KEY_LINE_3 (14) /*GPIO pin*/
|
||||
#define QR_KEY_LINE_4 ( 8) /*GPIO pin*/
|
||||
#define QR_KEY_LINE_5 ( 7) /*GPIO pin*/
|
||||
#define QR_KEY_LINE_6 ( 6) /*GPIO pin*/
|
||||
|
||||
/*QRdecode lcd */
|
||||
//lcd io
|
||||
#define QR_LCD_RST (14)
|
||||
#define QR_LCD_CS (15)
|
||||
#define QR_LCD_CLK (10)
|
||||
#define QR_LCD_MOSI ( 3)
|
||||
#define QR_LCD_A0 (11)
|
||||
#define QR_LCD_BL (39 | (1 << 7))
|
||||
#define QR_LCD_SPI_BOUDSPEED (0xFF)
|
||||
#define QR_LCD_BLANK_LINE_NUM ( 0) /*Value range 0~7*/
|
||||
#define QR_LCD_COLUMN_NUM (64) /*Value range 0~7*/
|
||||
#define QR_LCD_START_COLUMN ((128 - 64)/2)
|
||||
|
||||
//lcd camera io
|
||||
|
||||
#define QR_LCD_CAMERA_FREQ (24)
|
||||
#define QR_LCD_CAMERA_SDA (17)
|
||||
#define QR_LCD_CAMERA_SCL (16)
|
||||
#define QR_LCD_CAMERA_RST (41)
|
||||
#define QR_LCD_CAMERA_PD ( 5)//power down
|
||||
#define QR_LCD_CAMERA_MCLK (40)
|
||||
#define QR_LCD_CAMERA_PCLK (38)
|
||||
#define QR_LCD_CAMERA_DATA ( 2)
|
||||
#define QR_LCD_CAMERA_CS (42)
|
||||
|
||||
/*touch*/
|
||||
#define TP_Y_HIGH_PORT GPIOA
|
||||
#define TP_Y_HIGH_IO_PIN GPIO_Pin_4
|
||||
#define TP_Y_LOW_PORT GPIOC
|
||||
#define TP_Y_LOW_IO_PIN GPIO_Pin_12
|
||||
#define TP_X_HIGH_PORT GPIOA
|
||||
#define TP_X_HIGH_IO_PIN GPIO_Pin_13
|
||||
#define TP_X_LOW_PORT GPIOC
|
||||
#define TP_X_LOW_IO_PIN GPIO_Pin_11
|
||||
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,102 @@
|
||||
/*
|
||||
File Name : board_config.h
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2020/07/17
|
||||
Description : misc file.
|
||||
*/
|
||||
|
||||
#include "misc.h"
|
||||
|
||||
/* following defines should be used for structure members */
|
||||
#define __IM volatile const /*! Defines 'read only' structure member permissions */
|
||||
#define __OM volatile /*! Defines 'write only' structure member permissions */
|
||||
#define __IOM volatile /*! Defines 'read / write' structure member permissions */
|
||||
|
||||
/* Memory mapping of Cortex-M0 Hardware */
|
||||
#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */
|
||||
#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */
|
||||
#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */
|
||||
|
||||
typedef struct
|
||||
{
|
||||
__IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */
|
||||
__IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */
|
||||
uint32_t RESERVED0;
|
||||
__IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */
|
||||
__IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */
|
||||
__IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */
|
||||
uint32_t RESERVED1;
|
||||
__IOM uint32_t SHP[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */
|
||||
__IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */
|
||||
} SCB_Type;
|
||||
|
||||
/**
|
||||
\brief Structure type to access the Nested Vectored Interrupt Controller (NVIC).
|
||||
*/
|
||||
typedef struct
|
||||
{
|
||||
__IOM uint32_t ISER[1U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */
|
||||
uint32_t RESERVED0[31U];
|
||||
__IOM uint32_t ICER[1U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */
|
||||
uint32_t RSERVED1[31U];
|
||||
__IOM uint32_t ISPR[1U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */
|
||||
uint32_t RESERVED2[31U];
|
||||
__IOM uint32_t ICPR[1U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */
|
||||
uint32_t RESERVED3[31U];
|
||||
uint32_t RESERVED4[64U];
|
||||
__IOM uint32_t IP[8U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */
|
||||
} NVIC_Type;
|
||||
|
||||
#define SCB ((SCB_Type *)SCB_BASE) /*!< SCB configuration struct */
|
||||
#define NVIC ((NVIC_Type *)NVIC_BASE) /*!< NVIC configuration struct */
|
||||
|
||||
/* The following MACROS handle generation of the register offset and byte masks */
|
||||
#define _BIT_SHIFT(IRQn) (((((uint32_t)(int32_t)(IRQn))) & 0x03UL) * 8UL)
|
||||
#define _SHP_IDX(IRQn) ((((((uint32_t)(int32_t)(IRQn)) & 0x0FUL) - 8UL) >> 2UL))
|
||||
#define _IP_IDX(IRQn) ((((uint32_t)(int32_t)(IRQn)) >> 2UL))
|
||||
|
||||
/* ----------------Configuration of the Cortex-M0 Processor and Core Peripherals---------------- */
|
||||
#define __CM0_REV 0x0000 /*!< Cortex-M0 Core Revision */
|
||||
#define __MPU_PRESENT 0 /*!< MPU present or not */
|
||||
#define __NVIC_PRIO_BITS 2 /*!< Number of Bits used for Priority Levels */
|
||||
#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */
|
||||
/* End of group Configuration_of_CMSIS */
|
||||
|
||||
uint32_t NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)
|
||||
{
|
||||
if ((int32_t)(IRQn) < 0)
|
||||
{
|
||||
SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
|
||||
(((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn)));
|
||||
}
|
||||
else
|
||||
{
|
||||
NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
|
||||
(((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn)));
|
||||
}
|
||||
return SUCCESS;
|
||||
}
|
||||
|
||||
#define SBC_ICSR_PENDSV_IRQ 28
|
||||
void trigger_PendSV(void)
|
||||
{
|
||||
SCB->ICSR |= (1 << SBC_ICSR_PENDSV_IRQ);
|
||||
}
|
||||
|
||||
void NVIC_EnableIRQ(IRQn_Type IRQnx)
|
||||
{
|
||||
enable_intr((int)IRQnx);
|
||||
}
|
||||
|
||||
void NVIC_DisableIRQ(IRQn_Type IRQnx)
|
||||
{
|
||||
disable_intr((int)IRQnx);
|
||||
}
|
||||
|
||||
void soft_reset(void)
|
||||
{
|
||||
SYSCTRL_RST_EN |= 0x01;
|
||||
SYSCTRL_RESET = 0x55;
|
||||
while (1);
|
||||
}
|
||||
@@ -0,0 +1,93 @@
|
||||
/*
|
||||
File Name : board_config.h
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2020/07/17
|
||||
Description : misc file.
|
||||
*/
|
||||
|
||||
#ifndef __MISC_H
|
||||
#define __MISC_H
|
||||
#include "yc3121.h"
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
typedef enum
|
||||
{
|
||||
SVCall_IRQn = -5, //SVC_IRQHandler
|
||||
PendSV_IRQn = -2, //PENDSV_IRQHandler
|
||||
SysTick_IRQn = -1, //SYSTICK_IRQHandler
|
||||
USB_IRQn = 0,
|
||||
IIC_IRQn = 1,
|
||||
QSPI_IRQn = 2,
|
||||
SPI0_IRQn = 3,
|
||||
SPI1_IRQn = 4,
|
||||
UART0_IRQn = 5,
|
||||
UART1_IRQn = 6,
|
||||
MEMCP_IRQn = 7,//DMA MEM_TO_MEM
|
||||
RSA_IRQn = 8,
|
||||
SCI0_IRQn = 9,
|
||||
SCI1_IRQn = 10,
|
||||
BT_IRQn = 11,
|
||||
GPIO_IRQn = 12,
|
||||
TIM0_IRQn = 13,
|
||||
TIM1_IRQn = 14,
|
||||
TIM2_IRQn = 15,
|
||||
TIM3_IRQn = 16,
|
||||
TIM4_IRQn = 17,
|
||||
TIM5_IRQn = 18,
|
||||
TIM6_IRQn = 19,
|
||||
TIM7_IRQn = 20,
|
||||
TIM8_IRQn = 21,
|
||||
SM4_IRQn = 22,
|
||||
SEC_IRQn = 23,
|
||||
MSR_IRQn = 24,
|
||||
TRNG_IRQn = 25,
|
||||
WDT_IRQn = 26
|
||||
} IRQn_Type;
|
||||
|
||||
/**
|
||||
* @brief Enable External Interrupt
|
||||
* @param IRQnx IRQn External interrupt number. Value cannot be negative.
|
||||
* @retval none
|
||||
*/
|
||||
void NVIC_EnableIRQ(IRQn_Type IRQnx);
|
||||
|
||||
/**
|
||||
* @brief Disable External Interrupt
|
||||
* @param IRQnx IRQn External interrupt number. Value cannot be negative.
|
||||
* @retval none
|
||||
*/
|
||||
void NVIC_DisableIRQ(IRQn_Type IRQnx);
|
||||
|
||||
/**
|
||||
* @brief Set Interrupt Priority
|
||||
* @param IRQn Interrupt number.
|
||||
* @retval SUCCESS or ERROR
|
||||
*/
|
||||
uint32_t NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority);
|
||||
|
||||
|
||||
/**
|
||||
* @brief trigger PendSV Interrupt
|
||||
* @param none
|
||||
* @retval none
|
||||
*/
|
||||
void trigger_PendSV(void);
|
||||
|
||||
/**
|
||||
* @brief System Reset
|
||||
* @param none
|
||||
* @retval none
|
||||
*/
|
||||
void soft_reset(void);
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* __MISC_H */
|
||||
|
||||
@@ -0,0 +1,42 @@
|
||||
/*
|
||||
File Name : rom_api.h
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2020/02/11
|
||||
Description : rom fun information.
|
||||
*/
|
||||
|
||||
#ifndef __ROM_API_H__
|
||||
#define __ROM_API_H__
|
||||
|
||||
/* TIMER */
|
||||
#define FUNC_DELAY_US_ADDR (0x4238 + 1)
|
||||
#define FUNC_DELAY_MS_ADDR (0x425c + 1)
|
||||
|
||||
/* OTP */
|
||||
#define FUNC_INIT_OTP_ADDR (0x442c + 1)
|
||||
#define FUNC_DEINIT_OTP_ADDR (0x4480 + 1)
|
||||
#define FUNC_READ_OTP_ADDR (0x449c + 1)
|
||||
#define FUNC_WRITE_OTP_ADDR (0x4594 + 1)
|
||||
#define FUNC_READ_CHIPID_ADDR (0x45d8 + 1)
|
||||
#define FUNC_READ_CHIPLF_ADDR (0x45e6 + 1)
|
||||
|
||||
/* LPM */
|
||||
#define FUNC_LPM_READ_ADDR (0x4c80 + 1)
|
||||
#define FUNC_LPM_WRITE_ADDR (0x4c9c + 1)
|
||||
#define FUNC_LPM_BT_WRITE_ADDR (0x4cb0 + 1)
|
||||
#define FUNC_LPM_BT_READ_ADDR (0x4d24 + 1)
|
||||
#define FUNC_LPM_SLEEP_ADDR (0x4d68 + 1)
|
||||
#define FUNC_SETLPMVAL_ADDR (0x4280 + 1)
|
||||
|
||||
/* QSPI */
|
||||
#define FUNC_ENC_WRITE_FLASH_ADDR (0x51f0 + 1)
|
||||
#define FUNC_QSPI_FLASH_SECTORERASE_ADDR (0x48b4 + 1)
|
||||
#define FUNC_QSPI_FLASH_BLOCKERASE_ADDR (0x48c0 + 1)
|
||||
#define FUNC_QSPI_FLASH_WRITE_ADDR (0x47f4 + 1)
|
||||
#define FUNC_QSPI_FLASH_READ_ADDR (0x48f6 + 1)
|
||||
#define FUNC_FLASH_BLANK_CHECK (0x513c + 1)
|
||||
#define FUNC_PREFETCH (0x4404 + 1)
|
||||
#define FUNC_READ_FLASH_ID (0x4960 + 1)
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,254 @@
|
||||
/*
|
||||
File Name : system.c
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2019/12/4
|
||||
Description : none.
|
||||
*/
|
||||
|
||||
#include <stdarg.h>
|
||||
#include "system.h"
|
||||
|
||||
//*****************************************************************************
|
||||
//
|
||||
//! A simple MyPrintf function supporting \%c, \%d, \%p, \%s, \%u,\%x, and \%X.
|
||||
//!
|
||||
//! \param format is the format string.
|
||||
//! \param ... are the optional arguments, which depend on the contents of the
|
||||
//! \return None.
|
||||
//
|
||||
//*****************************************************************************
|
||||
|
||||
static const int8_t *const g_pcHex1 = "0123456789abcdef";
|
||||
static const int8_t *const g_pcHex2 = "0123456789ABCDEF";
|
||||
|
||||
|
||||
void printfsend(UART_TypeDef UARTx, uint8_t *buf, int len)
|
||||
{
|
||||
uint8_t printbuf[256];
|
||||
for (int i = 0; i < len; i++)
|
||||
{
|
||||
printbuf[i] = buf[i];
|
||||
}
|
||||
|
||||
UART_SendBuf(UARTx, printbuf, len);
|
||||
}
|
||||
|
||||
void MyPrintf(char *format, ...)
|
||||
{
|
||||
uint32_t ulIdx, ulValue, ulPos, ulCount, ulBase, ulNeg;
|
||||
int8_t *pcStr, pcBuf[16], cFill;
|
||||
char HexFormat;
|
||||
va_list vaArgP;
|
||||
|
||||
va_start(vaArgP, format);
|
||||
|
||||
while (*format)
|
||||
{
|
||||
// Find the first non-% character, or the end of the string.
|
||||
for (ulIdx = 0; (format[ulIdx] != '%') && (format[ulIdx] != '\0'); ulIdx++)
|
||||
{
|
||||
}
|
||||
|
||||
// Write this portion of the string.
|
||||
if (ulIdx > 0)
|
||||
{
|
||||
printfsend(UART0, (uint8_t *)format, ulIdx);
|
||||
}
|
||||
|
||||
format += ulIdx;
|
||||
|
||||
if (*format == '%')
|
||||
{
|
||||
format++;
|
||||
|
||||
// Set the digit count to zero, and the fill character to space
|
||||
// (i.e. to the defaults).
|
||||
ulCount = 0;
|
||||
cFill = ' ';
|
||||
|
||||
again:
|
||||
switch (*format++)
|
||||
{
|
||||
case '0':
|
||||
case '1':
|
||||
case '2':
|
||||
case '3':
|
||||
case '4':
|
||||
case '5':
|
||||
case '6':
|
||||
case '7':
|
||||
case '8':
|
||||
case '9':
|
||||
{
|
||||
if ((format[-1] == '0') && (ulCount == 0))
|
||||
{
|
||||
cFill = '0';
|
||||
}
|
||||
|
||||
ulCount *= 10;
|
||||
ulCount += format[-1] - '0';
|
||||
|
||||
goto again;
|
||||
}
|
||||
|
||||
case 'c':
|
||||
{
|
||||
ulValue = va_arg(vaArgP, unsigned long);
|
||||
printfsend(UART0, (uint8_t *)&ulValue, 1);
|
||||
break;
|
||||
}
|
||||
|
||||
case 'd':
|
||||
{
|
||||
ulValue = va_arg(vaArgP, unsigned long);
|
||||
ulPos = 0;
|
||||
|
||||
if ((long)ulValue < 0)
|
||||
{
|
||||
ulValue = -(long)ulValue;
|
||||
ulNeg = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
ulNeg = 0;
|
||||
}
|
||||
|
||||
ulBase = 10;
|
||||
goto convert;
|
||||
}
|
||||
|
||||
case 's':
|
||||
{
|
||||
pcStr = (int8_t *)va_arg(vaArgP, char *);
|
||||
|
||||
for (ulIdx = 0; pcStr[ulIdx] != '\0'; ulIdx++)
|
||||
{
|
||||
}
|
||||
|
||||
printfsend(UART0, (uint8_t *)pcStr, ulIdx);
|
||||
|
||||
if (ulCount > ulIdx)
|
||||
{
|
||||
ulCount -= ulIdx;
|
||||
while (ulCount--)
|
||||
{
|
||||
printfsend(UART0, (uint8_t *)" ", 1);
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
case 'u':
|
||||
{
|
||||
ulValue = va_arg(vaArgP, unsigned long);
|
||||
ulPos = 0;
|
||||
ulBase = 10;
|
||||
ulNeg = 0;
|
||||
goto convert;
|
||||
}
|
||||
|
||||
case 'X':
|
||||
{
|
||||
ulValue = va_arg(vaArgP, unsigned long);
|
||||
ulPos = 0;
|
||||
ulBase = 16;
|
||||
ulNeg = 0;
|
||||
HexFormat = 'X';
|
||||
goto convert;
|
||||
}
|
||||
|
||||
case 'x':
|
||||
|
||||
case 'p':
|
||||
{
|
||||
ulValue = va_arg(vaArgP, unsigned long);
|
||||
ulPos = 0;
|
||||
ulBase = 16;
|
||||
ulNeg = 0;
|
||||
HexFormat = 'x';
|
||||
|
||||
convert:
|
||||
for (ulIdx = 1;
|
||||
(((ulIdx * ulBase) <= ulValue) &&
|
||||
(((ulIdx * ulBase) / ulBase) == ulIdx));
|
||||
ulIdx *= ulBase, ulCount--)
|
||||
{
|
||||
}
|
||||
|
||||
if (ulNeg)
|
||||
{
|
||||
ulCount--;
|
||||
}
|
||||
|
||||
if (ulNeg && (cFill == '0'))
|
||||
{
|
||||
pcBuf[ulPos++] = '-';
|
||||
ulNeg = 0;
|
||||
}
|
||||
|
||||
if ((ulCount > 1) && (ulCount < 16))
|
||||
{
|
||||
for (ulCount--; ulCount; ulCount--)
|
||||
{
|
||||
pcBuf[ulPos++] = cFill;
|
||||
}
|
||||
}
|
||||
|
||||
if (ulNeg)
|
||||
{
|
||||
pcBuf[ulPos++] = '-';
|
||||
}
|
||||
|
||||
for (; ulIdx; ulIdx /= ulBase)
|
||||
{
|
||||
if (HexFormat == 'x')
|
||||
pcBuf[ulPos++] = g_pcHex1[(ulValue / ulIdx) % ulBase]; //x
|
||||
else
|
||||
pcBuf[ulPos++] = g_pcHex2[(ulValue / ulIdx) % ulBase]; //X
|
||||
}
|
||||
|
||||
printfsend(UART0, (uint8_t *)pcBuf, ulPos);
|
||||
break;
|
||||
}
|
||||
|
||||
case '%':
|
||||
{
|
||||
printfsend(UART0, (uint8_t *)format - 1, 1);
|
||||
break;
|
||||
}
|
||||
|
||||
default:
|
||||
{
|
||||
printfsend(UART0, (uint8_t *)"ERROR", 5);
|
||||
break;
|
||||
}
|
||||
} //switch
|
||||
} //if
|
||||
} //while
|
||||
va_end(vaArgP);
|
||||
}
|
||||
|
||||
void printv(uint8_t *buf, uint32_t len, uint8_t *s)
|
||||
{
|
||||
uint32_t i = 0;
|
||||
uint32_t n = 0;
|
||||
MyPrintf("\r\n %s:", s);
|
||||
for (i = 0; i < len; i++)
|
||||
{
|
||||
if (i % 16 == 0)
|
||||
{
|
||||
MyPrintf("\r\n%08x:", n);
|
||||
n += 16;
|
||||
}
|
||||
MyPrintf("%02x ", buf[i]);
|
||||
}
|
||||
}
|
||||
|
||||
void _assert_handler(const char *file, int line, const char *func)
|
||||
{
|
||||
#if defined(SDK_DEBUG)
|
||||
MyPrintf("Assert trigger at file: %s line:%d func: %s\n ", file, line, func);
|
||||
#endif
|
||||
while (1);
|
||||
}
|
||||
@@ -0,0 +1,43 @@
|
||||
/*
|
||||
File Name : system.h
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2018/05/22
|
||||
Description : none.
|
||||
*/
|
||||
|
||||
#ifndef __SYSTEM_H__
|
||||
#define __SYSTEM_H__
|
||||
|
||||
|
||||
#include <string.h>
|
||||
#include "yc_uart.h"
|
||||
|
||||
//#define SDK_DEBUG //Debug switch
|
||||
|
||||
#define BIT_SET(a,b) ((a) |= (1<<(b)))
|
||||
#define BIT_CLEAR(a,b) ((a) &= ~(1<<(b)))
|
||||
#define BIT_FLIP(a,b) ((a) ^= (1<<(b))) //bit Negation
|
||||
#define BIT_GET(a,b) (((a) & (1<<(b)))>>(b))
|
||||
|
||||
/**
|
||||
* @brief Print format string to serial port 0.You need to initialize the serial port 0 before you use MyPrintf.
|
||||
*
|
||||
* @param format : format string
|
||||
* @param ...: format parameter
|
||||
*/
|
||||
void MyPrintf(char *format, ...);
|
||||
|
||||
void _assert_handler(const char *file, int line, const char *func);
|
||||
|
||||
void printv(uint8_t *buf, uint32_t len, uint8_t *s);
|
||||
|
||||
#define _ASSERT(x) \
|
||||
if (!(x)) \
|
||||
{ \
|
||||
_assert_handler(__FILE__,__LINE__,__FUNCTION__);\
|
||||
}
|
||||
|
||||
|
||||
#endif /*__SYSTEM_H__*/
|
||||
|
||||
@@ -0,0 +1,67 @@
|
||||
/*
|
||||
File Name : type.h
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2018/05/25
|
||||
Description : Data type definition.
|
||||
*/
|
||||
|
||||
#ifndef __TYPE_H__
|
||||
#define __TYPE_H__
|
||||
|
||||
#if defined (__CC_ARM) || defined ( __ICCARM__ )
|
||||
typedef unsigned char uint8_t;
|
||||
typedef unsigned short uint16_t;
|
||||
typedef unsigned int uint32_t;
|
||||
typedef unsigned long long uint64_t;
|
||||
typedef unsigned char byte;
|
||||
typedef unsigned short word;
|
||||
|
||||
typedef signed char int8_t;
|
||||
typedef signed short int16_t;
|
||||
typedef signed int int32_t;
|
||||
typedef signed long long int64_t;
|
||||
#else
|
||||
#include "stdio.h"
|
||||
typedef unsigned char byte;
|
||||
typedef unsigned short word;
|
||||
#endif
|
||||
|
||||
/**
|
||||
* @brief __NOINLINE definition
|
||||
*/
|
||||
#if defined ( __CC_ARM ) || defined ( __GNUC__ )
|
||||
/* ARM & GNUCompiler
|
||||
----------------
|
||||
*/
|
||||
#define __NOINLINE noinline
|
||||
|
||||
#elif defined ( __ICCARM__ )
|
||||
/* ICCARM Compiler
|
||||
---------------
|
||||
*/
|
||||
#define __NOINLINE _Pragma("optimize = no_inline")
|
||||
|
||||
#endif
|
||||
|
||||
#ifndef Boolean
|
||||
typedef enum {FALSE = 0, TRUE =1} Boolean;
|
||||
#define IS_BOOLEAN(bool) ((bool == FALSE) || (bool == TRUE))
|
||||
#endif
|
||||
|
||||
#ifndef FunctionalState
|
||||
typedef enum {DISABLE = 0, ENABLE =1} FunctionalState;
|
||||
#define IS_FUNCTIONAL_STATE(state) ((state== DISABLE) || (state == ENABLE))
|
||||
#endif
|
||||
|
||||
#ifndef FunctionalState
|
||||
typedef enum {ERROR = 0, SUCCESS = 1} ErrorStatus;
|
||||
#define IS_ERROR_STATE(status) ((status== ERROR) || (status == SUCCESS))
|
||||
#endif
|
||||
|
||||
#ifndef FlagStatus
|
||||
typedef enum {RESET = 0, SET = !RESET} FlagStatus, ITStatus;
|
||||
#endif
|
||||
|
||||
#endif /*__TYPE_H__*/
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,72 @@
|
||||
/*
|
||||
File Name : yc_dma.c
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2018/03/27
|
||||
Description : DMA Mem_TO_Mem Mode encapsulation.
|
||||
If enable DMA interrupt ,enter interrupt after sending data by default,and just one DMA IT Mode.
|
||||
*/
|
||||
|
||||
#include "yc_dma.h"
|
||||
|
||||
#define DMA_Channel DMACH_MEMCP
|
||||
#define DMA_CLEAR_IT_BIT_Pos 6
|
||||
#define DMA_ENTERIT_BIT_Pos 1
|
||||
#define DMA_DATA_COMPLETE_BIT_Pos 0
|
||||
|
||||
void DMA_Init(DMA_InitTypeDef *DMA_InitStruct)
|
||||
{
|
||||
DMA_SRC_ADDR(DMACH_MEMCP) = DMA_InitStruct->DMA_MemorySourceAddr;
|
||||
DMA_DEST_ADDR(DMACH_MEMCP) = DMA_InitStruct->DMA_MemoryDestAddr;
|
||||
DMA_LEN(DMACH_MEMCP) = (DMA_InitStruct->DMA_BlockSize << 16) | DMA_InitStruct->DMA_BlockSize;
|
||||
}
|
||||
|
||||
void DMA_ChannelCmd(FunctionalState NewState)
|
||||
{
|
||||
if (NewState != DISABLE)
|
||||
{
|
||||
DMA_START(DMACH_MEMCP) |= (DMA_ENABLE);
|
||||
}
|
||||
else
|
||||
{
|
||||
DMA_START(DMACH_MEMCP) &= ~(DMA_ENABLE);
|
||||
}
|
||||
}
|
||||
|
||||
void DMA_SetSRCAddress(uint32_t Address)
|
||||
{
|
||||
DMA_SRC_ADDR(DMACH_MEMCP) = Address;
|
||||
}
|
||||
|
||||
void DMA_SetDSRAddress(uint32_t Address)
|
||||
{
|
||||
DMA_DEST_ADDR(DMACH_MEMCP) = Address;
|
||||
}
|
||||
|
||||
FunctionalState DMA_IsChannelEnabled(void)
|
||||
{
|
||||
if (1 == (DMA_START(DMACH_MEMCP) & DMA_ENABLE))
|
||||
{
|
||||
return ENABLE;
|
||||
}
|
||||
else
|
||||
{
|
||||
return DISABLE;
|
||||
}
|
||||
}
|
||||
|
||||
FlagStatus DMA_GetFlagStatus(void)
|
||||
{
|
||||
return (FlagStatus)((DMA_STATUS(DMACH_MEMCP) & (1 << DMA_DATA_COMPLETE_BIT_Pos)));
|
||||
}
|
||||
|
||||
void DMA_ClearITPendingBit(void)
|
||||
{
|
||||
DMA_START(DMACH_MEMCP) |= (1 << DMA_CLEAR_IT_BIT_Pos);
|
||||
}
|
||||
|
||||
void DMA_ITConfig(FunctionalState NewState)
|
||||
{
|
||||
DMA_CONFIG(DMACH_MEMCP) &= ~(1 << DMA_ENTERIT_BIT_Pos);
|
||||
DMA_CONFIG(DMACH_MEMCP) |= (NewState << DMA_ENTERIT_BIT_Pos);
|
||||
}
|
||||
@@ -0,0 +1,91 @@
|
||||
/*
|
||||
File Name : yc_dma.h
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2018/03/27
|
||||
Description : DMA Mem_TO_Mem Mode encapsulation.
|
||||
If enable DMA interrupt ,enter interrupt after sending data by default,and just one DMA IT Mode.
|
||||
*/
|
||||
|
||||
#ifndef __YC_DMA_H_
|
||||
#define __YC_DMA_H_
|
||||
|
||||
#include "yc3121.h"
|
||||
#define DMACH_QSPI 0
|
||||
|
||||
#define DMA_ENABLE_BIT_Pos 7
|
||||
#define DMA_ENABLE ((uint8_t)1 << DMA_ENABLE_BIT_Pos)
|
||||
|
||||
#define DMA_IT_BIT_Pos 1
|
||||
#define DMA_IT_ENABLE ((uint32_t)1 << DMA_IT_BIT_Pos)
|
||||
/*Peripheral DMA Channel*/
|
||||
|
||||
typedef struct
|
||||
{
|
||||
uint32_t DMA_MemorySourceAddr; /*!< Specifies the memory Source address for Channel Mem_to_Mem. */
|
||||
|
||||
uint32_t DMA_MemoryDestAddr; /*!<Specifies the memory Destination address for Channel Mem_to_Mem. */
|
||||
|
||||
uint32_t DMA_BlockSize; /*!< Specifies the Total Number of data items during the transaction. */
|
||||
|
||||
} DMA_InitTypeDef;
|
||||
|
||||
/**
|
||||
* @brief Initializes the DMA Mem_to_Mem Channelx according to the specified
|
||||
* parameters in the DMA_InitStruct.
|
||||
* @param DMA_InitStruct: pointer to a DMA_InitTypeDef structure that
|
||||
* contains the configuration information for the specified DMA Channel.
|
||||
* @retval None
|
||||
*/
|
||||
void DMA_Init(DMA_InitTypeDef *DMA_InitStruct);
|
||||
|
||||
/**
|
||||
* @brief Enables or disables Channel DMACH_MEMCP.
|
||||
* @param NewState: new state of the DMAy Channelx.
|
||||
* This parameter can be: ENABLE or DISABLE.
|
||||
* @retval None
|
||||
*/
|
||||
void DMA_ChannelCmd(FunctionalState NewState);
|
||||
|
||||
/**
|
||||
* @brief Set DMA Source Address.
|
||||
* @param Address: DMA source address
|
||||
* @retval None
|
||||
*/
|
||||
void DMA_SetSRCAddress(uint32_t Address);
|
||||
|
||||
/**
|
||||
* @brief Set DMA destination Address.
|
||||
* @param Address: DMA source address
|
||||
* @retval None
|
||||
*/
|
||||
void DMA_SetDSRAddress(uint32_t Address);
|
||||
|
||||
/**
|
||||
* @brief Checks whether the DMACH_MEMCP Channelx flag is set or not.
|
||||
* @param None
|
||||
* @retval None
|
||||
*/
|
||||
FlagStatus DMA_GetFlagStatus(void);
|
||||
|
||||
/**
|
||||
* @brief Clears the DMACH_MEMCP Channelx's pending flags.
|
||||
* @param None
|
||||
* @retval Enable or Disable.
|
||||
*/
|
||||
FunctionalState DMA_IsChannelEnabled(void);
|
||||
|
||||
/**
|
||||
* @brief Clears the DMACH_MEMCP Channelx's interrupt pending bits.
|
||||
* @param None
|
||||
* @retval None
|
||||
*/
|
||||
void DMA_ClearITPendingBit(void);
|
||||
|
||||
/**
|
||||
* @brief ENABLE or DISABLE intterrupt
|
||||
* @param NewState
|
||||
* @retval None
|
||||
*/
|
||||
void DMA_ITConfig(FunctionalState NewState);
|
||||
#endif
|
||||
@@ -0,0 +1,211 @@
|
||||
/*
|
||||
File Name : yc_gpio.c
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2019/12/03
|
||||
Description : gpio encapsulation.
|
||||
*/
|
||||
|
||||
#include "yc_gpio.h"
|
||||
|
||||
void GPIO_Config(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin, GPIO_FunTypeDef function)
|
||||
{
|
||||
_ASSERT(ISGPIOGROUP(GPIOx));
|
||||
_ASSERT(IS_GET_GPIO_PIN(GPIO_Pin));
|
||||
|
||||
int i;
|
||||
|
||||
for (i = 0; i < GPIO_PIN_NUM; i++)
|
||||
{
|
||||
if (GPIO_Pin & 1 << i)
|
||||
GPIO_CONFIG(GPIOx * GPIO_PIN_NUM + i) = function;
|
||||
}
|
||||
}
|
||||
|
||||
void GPIO_Init(GPIO_TypeDef GPIOx, GPIO_InitTypeDef *GPIO_InitStruct)
|
||||
{
|
||||
_ASSERT(ISGPIOGROUP(GPIOx));
|
||||
_ASSERT(IS_GPIO_PIN(GPIO_InitStruct->GPIO_Pin));
|
||||
_ASSERT(IS_GPIO_MODE(GPIO_InitStruct->GPIO_Mode));
|
||||
|
||||
int i;
|
||||
|
||||
switch (GPIO_InitStruct->GPIO_Mode)
|
||||
{
|
||||
case GPIO_Mode_IN_FLOATING:
|
||||
for (i = 0; i < GPIO_PIN_NUM; i++)
|
||||
{
|
||||
if (GPIO_InitStruct->GPIO_Pin & 1 << i)
|
||||
GPIO_CONFIG(GPIOx * GPIO_PIN_NUM + i) = 0x00;
|
||||
}
|
||||
break;
|
||||
|
||||
case GPIO_Mode_IPU:
|
||||
for (i = 0; i < GPIO_PIN_NUM; i++)
|
||||
{
|
||||
if (GPIO_InitStruct->GPIO_Pin & 1 << i)
|
||||
GPIO_CONFIG(GPIOx * GPIO_PIN_NUM + i) = 0x40;
|
||||
}
|
||||
break;
|
||||
|
||||
case GPIO_Mode_IPD:
|
||||
for (i = 0; i < GPIO_PIN_NUM; i++)
|
||||
{
|
||||
if (GPIO_InitStruct->GPIO_Pin & 1 << i)
|
||||
GPIO_CONFIG(GPIOx * GPIO_PIN_NUM + i) = 0x80;
|
||||
}
|
||||
break;
|
||||
|
||||
case GPIO_Mode_AIN:
|
||||
for (i = 0; i < GPIO_PIN_NUM; i++)
|
||||
{
|
||||
if (GPIO_InitStruct->GPIO_Pin & 1 << i)
|
||||
GPIO_CONFIG(GPIOx * GPIO_PIN_NUM + i) = 0xC0;
|
||||
}
|
||||
break;
|
||||
|
||||
case GPIO_Mode_Out_PP:
|
||||
for (i = 0; i < GPIO_PIN_NUM; i++)
|
||||
{
|
||||
if (GPIO_InitStruct->GPIO_Pin & 1 << i)
|
||||
GPIO_CONFIG(GPIOx * GPIO_PIN_NUM + i) = 0x3E;
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void GPIO_PullUpCmd(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin, FunctionalState NewState)
|
||||
{
|
||||
_ASSERT(ISGPIOGROUP(GPIOx));
|
||||
_ASSERT(IS_GET_GPIO_PIN(GPIO_Pin));
|
||||
|
||||
int i;
|
||||
|
||||
for (i = 0; i < GPIO_PIN_NUM; i++)
|
||||
{
|
||||
if (GPIO_Pin & 1 << i)
|
||||
{
|
||||
if (NewState == ENABLE)
|
||||
{
|
||||
GPIO_CONFIG(GPIOx * GPIO_PIN_NUM + i) |= 1 << 6;
|
||||
}
|
||||
else if (NewState == DISABLE)
|
||||
{
|
||||
GPIO_CONFIG(GPIOx * GPIO_PIN_NUM + i) &= ~(1 << 6);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
uint16_t GPIO_ReadInputData(GPIO_TypeDef GPIOx)
|
||||
{
|
||||
_ASSERT(ISGPIOGROUP(GPIOx));
|
||||
|
||||
return GPIO_IN(GPIOx);
|
||||
}
|
||||
|
||||
uint8_t GPIO_ReadInputDataBit(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin)
|
||||
{
|
||||
_ASSERT(ISGPIOGROUP(GPIOx));
|
||||
_ASSERT(IS_GET_GPIO_PIN(GPIO_Pin));
|
||||
|
||||
if (GPIO_IN(GPIOx) & GPIO_Pin)
|
||||
{
|
||||
return (uint8_t)0x01;
|
||||
}
|
||||
else
|
||||
{
|
||||
return (uint8_t)0x00;
|
||||
}
|
||||
}
|
||||
|
||||
uint16_t GPIO_ReadOutputData(GPIO_TypeDef GPIOx)
|
||||
{
|
||||
_ASSERT(ISGPIOGROUP(GPIOx));
|
||||
|
||||
return GPIO_IN(GPIOx);
|
||||
}
|
||||
|
||||
uint8_t GPIO_ReadOutputDataBit(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin)
|
||||
{
|
||||
_ASSERT(ISGPIOGROUP(GPIOx));
|
||||
_ASSERT(IS_GET_GPIO_PIN(GPIO_Pin));
|
||||
|
||||
if (GPIO_IN(GPIOx) & GPIO_Pin)
|
||||
{
|
||||
return (uint8_t)0x01;
|
||||
}
|
||||
else
|
||||
{
|
||||
return (uint8_t)0x00;
|
||||
}
|
||||
}
|
||||
|
||||
void GPIO_ResetBits(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin)
|
||||
{
|
||||
_ASSERT(ISGPIOGROUP(GPIOx));
|
||||
_ASSERT(IS_GET_GPIO_PIN(GPIO_Pin));
|
||||
|
||||
int i;
|
||||
uint8_t Temp;
|
||||
|
||||
for (i = 0; i < GPIO_PIN_NUM; i++)
|
||||
{
|
||||
if (GPIO_Pin & 1 << i)
|
||||
{
|
||||
Temp = GPIO_CONFIG(GPIOx * GPIO_PIN_NUM + i);
|
||||
Temp |= 0x3F; //00111111
|
||||
Temp &= 0xFE; //11111110
|
||||
GPIO_CONFIG(GPIOx * GPIO_PIN_NUM + i) = Temp;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void GPIO_SetBits(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin)
|
||||
{
|
||||
_ASSERT(ISGPIOGROUP(GPIOx));
|
||||
_ASSERT(IS_GET_GPIO_PIN(GPIO_Pin));
|
||||
|
||||
int i;
|
||||
|
||||
for (i = 0; i < GPIO_PIN_NUM; i++)
|
||||
{
|
||||
if (GPIO_Pin & 1 << i)
|
||||
GPIO_CONFIG(GPIOx * GPIO_PIN_NUM + i) |= 0x3F; //00111111
|
||||
}
|
||||
}
|
||||
|
||||
void GPIO_StructInit(GPIO_InitTypeDef *GPIO_InitStruct)
|
||||
{
|
||||
GPIO_InitStruct->GPIO_Pin = GPIO_Pin_All;
|
||||
GPIO_InitStruct->GPIO_Mode = GPIO_Mode_IN_FLOATING;
|
||||
}
|
||||
|
||||
void GPIO_Write(GPIO_TypeDef GPIOx, uint16_t value)
|
||||
{
|
||||
_ASSERT(ISGPIOGROUP(GPIOx));
|
||||
|
||||
int i;
|
||||
|
||||
for (i = 0; i < GPIO_PIN_NUM; i++)
|
||||
{
|
||||
if (BIT_GET(value, i))
|
||||
GPIO_SetBits(GPIOx, 1 << i);
|
||||
else
|
||||
GPIO_ResetBits(GPIOx, 1 << i);
|
||||
}
|
||||
}
|
||||
|
||||
void GPIO_WriteBit(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin, BitAction BitVal)
|
||||
{
|
||||
_ASSERT(ISGPIOGROUP(GPIOx));
|
||||
_ASSERT(IS_GET_GPIO_PIN(GPIO_Pin));
|
||||
|
||||
if (BitVal == Bit_SET)
|
||||
GPIO_SetBits(GPIOx, GPIO_Pin);
|
||||
else if (BitVal == Bit_RESET)
|
||||
GPIO_ResetBits(GPIOx, GPIO_Pin);
|
||||
}
|
||||
@@ -0,0 +1,299 @@
|
||||
/*
|
||||
File Name : yc_gpio.c
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2019/12/03
|
||||
Description : gpio encapsulation.
|
||||
*/
|
||||
|
||||
#ifndef __YC_GPIO_H__
|
||||
#define __YC_GPIO_H__
|
||||
|
||||
#include "yc3121.h"
|
||||
|
||||
/**
|
||||
* @brief Configuration Mode enumeration
|
||||
*/
|
||||
typedef enum
|
||||
{
|
||||
GPIO_Mode_IN_FLOATING = 0x01,
|
||||
GPIO_Mode_IPU = 0x02,
|
||||
GPIO_Mode_IPD = 0x03,
|
||||
GPIO_Mode_AIN = 0x04,
|
||||
GPIO_Mode_Out_PP = 0x05 /*!< analog signal mode */
|
||||
} GPIO_ModeTypeDef;
|
||||
|
||||
#define IS_GPIO_MODE(mode) (((mode) == GPIO_Mode_IN_FLOATING) || \
|
||||
((mode) == GPIO_Mode_IPU) || \
|
||||
((mode) == GPIO_Mode_IPD) || \
|
||||
((mode) == GPIO_Mode_Out_PP) || \
|
||||
((mode) == GPIO_Mode_AIN))
|
||||
|
||||
/**
|
||||
* @brief Bit_SET and Bit_RESET enumeration
|
||||
*/
|
||||
typedef enum
|
||||
{
|
||||
Bit_RESET = 0,
|
||||
Bit_SET
|
||||
} BitAction;
|
||||
|
||||
/**
|
||||
* @brief gpio output enumeration
|
||||
*/
|
||||
typedef enum
|
||||
{
|
||||
OutputLow = 0,
|
||||
OutputHigh = 1
|
||||
} GPIO_OutputTypeDef;
|
||||
|
||||
#define IS_GPIO_WAKE_MODE(MODE) (((MODE) == GPIO_WakeMode_Now) || \
|
||||
((MODE) == GPIO_WakeMode_AfterGlitch))
|
||||
|
||||
/**
|
||||
* @brief GPIO function enumeration
|
||||
*/
|
||||
typedef enum
|
||||
{
|
||||
INPUT = GPCFG_INPUT,
|
||||
QSPI_NCS = GPCFG_QSPI_NCS,
|
||||
QSPI_SCK = GPCFG_QSPI_SCK,
|
||||
QSPI_IO0 = GPCFG_QSPI_IO0,
|
||||
QSPI_IO1 = GPCFG_QSPI_IO1,
|
||||
QSPI_IO2 = GPCFG_QSPI_IO2,
|
||||
QSPI_IO3 = GPCFG_QSPI_IO3,
|
||||
UART0_TXD = GPCFG_UART0_TXD,
|
||||
UART0_RXD = GPCFG_UART0_RXD,
|
||||
UART0_RTS = GPCFG_UART0_RTS,
|
||||
UART0_CTS = GPCFG_UART0_CTS,
|
||||
UART1_TXD = GPCFG_UART1_TXD,
|
||||
UART1_RXD = GPCFG_UART1_RXD,
|
||||
UART1_RTS = GPCFG_UART1_RTS,
|
||||
UART1_CTS = GPCFG_UART1_CTS,
|
||||
PWM_OUT0 = GPCFG_PWM_OUT0,
|
||||
PWM_OUT1 = GPCFG_PWM_OUT1,
|
||||
PWM_OUT2 = GPCFG_PWM_OUT2,
|
||||
PWM_OUT3 = GPCFG_PWM_OUT3,
|
||||
PWM_OUT4 = GPCFG_PWM_OUT4,
|
||||
PWM_OUT5 = GPCFG_PWM_OUT5,
|
||||
PWM_OUT6 = GPCFG_PWM_OUT6,
|
||||
PWM_OUT7 = GPCFG_PWM_OUT7,
|
||||
PWM_OUT8 = GPCFG_PWM_OUT8,
|
||||
SPID0_NCS = GPCFG_SPID0_NCS,
|
||||
SPID0_SCK = GPCFG_SPID0_SCK,
|
||||
SPID0_MOSI = GPCFG_SPID0_MOSI,
|
||||
SPID0_SDIO = GPCFG_SPID0_SDIO,
|
||||
SPID0_MISO = GPCFG_SPID0_MISO,
|
||||
SPID0_NCSIN = GPCFG_SPID0_NCSIN,
|
||||
SPID0_SCKIN = GPCFG_SPID0_SCKIN,
|
||||
SPID1_NCS = GPCFG_SPID1_NCS,
|
||||
SPID1_SCK = GPCFG_SPID1_SCK,
|
||||
SPID1_MOSI = GPCFG_SPID1_MOSI,
|
||||
SPID1_SDIO = GPCFG_SPID1_SDIO,
|
||||
SPID1_MISO = GPCFG_SPID1_MISO,
|
||||
SPID1_NCSIN = GPCFG_SPID1_NCSIN,
|
||||
SPID1_SCKIN = GPCFG_SPID1_SCKIN,
|
||||
NFC_CLK_OUT = GPCFG_NFC_CLK_OUT,
|
||||
SCI7816_IO = GPCFG_SCI7816_IO,
|
||||
IIC_SCL = GPCFG_IIC_SCL,
|
||||
IIC_SDA = GPCFG_IIC_SDA,
|
||||
JTAG_SWCLK = GPCFG_JTAG_SWCLK,
|
||||
JTAG_SWDAT = GPCFG_JTAG_SWDAT,
|
||||
OUTPUT_LOW = GPCFG_OUTPUT_LOW,
|
||||
OUTPUT_HIGH = GPCFG_OUTPUT_HIGH,
|
||||
PULL_UP = GPCFG_PU,
|
||||
PULL_DOWN = GPCFG_PD,
|
||||
ANALOG = GPCFG_ANALOG
|
||||
} GPIO_FunTypeDef;
|
||||
|
||||
#define GPIO_Pin_0 ((uint16_t)0x0001) /*!< Pin 0 selected */
|
||||
#define GPIO_Pin_1 ((uint16_t)0x0002) /*!< Pin 1 selected */
|
||||
#define GPIO_Pin_2 ((uint16_t)0x0004) /*!< Pin 2 selected */
|
||||
#define GPIO_Pin_3 ((uint16_t)0x0008) /*!< Pin 3 selected */
|
||||
#define GPIO_Pin_4 ((uint16_t)0x0010) /*!< Pin 4 selected */
|
||||
#define GPIO_Pin_5 ((uint16_t)0x0020) /*!< Pin 5 selected */
|
||||
#define GPIO_Pin_6 ((uint16_t)0x0040) /*!< Pin 6 selected */
|
||||
#define GPIO_Pin_7 ((uint16_t)0x0080) /*!< Pin 7 selected */
|
||||
#define GPIO_Pin_8 ((uint16_t)0x0100) /*!< Pin 8 selected */
|
||||
#define GPIO_Pin_9 ((uint16_t)0x0200) /*!< Pin 9 selected */
|
||||
#define GPIO_Pin_10 ((uint16_t)0x0400) /*!< Pin 10 selected */
|
||||
#define GPIO_Pin_11 ((uint16_t)0x0800) /*!< Pin 11 selected */
|
||||
#define GPIO_Pin_12 ((uint16_t)0x1000) /*!< Pin 12 selected */
|
||||
#define GPIO_Pin_13 ((uint16_t)0x2000) /*!< Pin 13 selected */
|
||||
#define GPIO_Pin_14 ((uint16_t)0x4000) /*!< Pin 14 selected */
|
||||
#define GPIO_Pin_15 ((uint16_t)0x8000) /*!< Pin 15 selected */
|
||||
#define GPIO_Pin_All ((uint16_t)0xffff) /*!< Pin All selected */
|
||||
|
||||
#define IS_GPIO_PIN(PIN) (((((PIN) & ~(uint16_t)0xFFFF)) == 0x00) && ((PIN) != (uint16_t)0x00))
|
||||
|
||||
#define IS_GET_GPIO_PIN(PIN) (((PIN) == GPIO_Pin_0) || \
|
||||
((PIN) == GPIO_Pin_1) || \
|
||||
((PIN) == GPIO_Pin_2) || \
|
||||
((PIN) == GPIO_Pin_3) || \
|
||||
((PIN) == GPIO_Pin_4) || \
|
||||
((PIN) == GPIO_Pin_5) || \
|
||||
((PIN) == GPIO_Pin_6) || \
|
||||
((PIN) == GPIO_Pin_7) || \
|
||||
((PIN) == GPIO_Pin_8) || \
|
||||
((PIN) == GPIO_Pin_9) || \
|
||||
((PIN) == GPIO_Pin_10) || \
|
||||
((PIN) == GPIO_Pin_11) || \
|
||||
((PIN) == GPIO_Pin_12) || \
|
||||
((PIN) == GPIO_Pin_13) || \
|
||||
((PIN) == GPIO_Pin_14) || \
|
||||
((PIN) == GPIO_Pin_15))
|
||||
|
||||
/**
|
||||
* @brief GPIO group enumeration
|
||||
*/
|
||||
typedef enum
|
||||
{
|
||||
GPIOA = 0,
|
||||
GPIOB,
|
||||
GPIOC
|
||||
} GPIO_TypeDef;
|
||||
|
||||
#define ISGPIOGROUP(groupx) (groupx < GPIO_GROUP_NUM)
|
||||
|
||||
/**
|
||||
* @brief GPIO Init structure definition
|
||||
*/
|
||||
typedef struct
|
||||
{
|
||||
uint16_t GPIO_Pin;
|
||||
GPIO_ModeTypeDef GPIO_Mode;
|
||||
} GPIO_InitTypeDef;
|
||||
|
||||
/**
|
||||
* @brief config gpio function(Only one can be configured at a time)
|
||||
*
|
||||
* @param GPIOx: where x can be (GPIOA...GPIOF) to select the GPIO group.
|
||||
*
|
||||
* @param GPIO_Pin: select the pin to read.(GPIO_Pin_0...GPIO_Pin_15)(Only one can be configured at a time)
|
||||
*
|
||||
* @param function:gpio function
|
||||
*
|
||||
* @retval none
|
||||
*/
|
||||
void GPIO_Config(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin, GPIO_FunTypeDef function);
|
||||
|
||||
/**
|
||||
* @brief gpio mode Init
|
||||
*
|
||||
* @param GPIOx: where x can be (GPIOA...GPIOF) to select the GPIO group.
|
||||
*
|
||||
* @param GPIO_InitStruct:GPIO_InitStruct
|
||||
*
|
||||
* @retval none
|
||||
*/
|
||||
void GPIO_Init(GPIO_TypeDef GPIOx, GPIO_InitTypeDef *GPIO_InitStruct);
|
||||
|
||||
/**
|
||||
* @brief
|
||||
*
|
||||
* @param GPIOx: where x can be (GPIOA...GPIOF) to select the GPIO group.
|
||||
*
|
||||
* @param GPIO_Pin: select the pin to read.(GPIO_Pin_0...GPIO_Pin_7)
|
||||
*
|
||||
* @param NewState: new state of the port pin Pull Up.(ENABLE or DISABLE)
|
||||
*
|
||||
* @retval
|
||||
*/
|
||||
void GPIO_PullUpCmd(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin, FunctionalState NewState);
|
||||
|
||||
/**
|
||||
* @brief Reads the GPIO input data(status) for byte.
|
||||
*
|
||||
* @param GPIOx: where x can be (GPIOA...GPIOF) to select the GPIO group.
|
||||
*
|
||||
* @retval GPIO input data(status).
|
||||
*/
|
||||
uint16_t GPIO_ReadInputData(GPIO_TypeDef GPIOx);
|
||||
|
||||
/**
|
||||
* @brief Reads the GPIO input data(status) for bit.
|
||||
*
|
||||
* @param GPIOx: where x can be (GPIOA...GPIOF) to select the GPIO group.
|
||||
*
|
||||
* @param GPIO_Pin: select the pin to read.(GPIO_Pin_0...GPIO_Pin_15)
|
||||
*
|
||||
* @retval The input status
|
||||
*/
|
||||
uint8_t GPIO_ReadInputDataBit(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin);
|
||||
|
||||
/**
|
||||
* @brief Reads the GPIO output data(status) for byte.
|
||||
*
|
||||
* @param GPIOx: where x can be (GPIOA...GPIOF) to select the GPIO group.
|
||||
*
|
||||
* @retval GPIO output data(status).
|
||||
*/
|
||||
uint16_t GPIO_ReadOutputData(GPIO_TypeDef GPIOx);
|
||||
|
||||
/**
|
||||
* @brief Reads the GPIO output data(status) for bit.
|
||||
*
|
||||
* @param GPIOx: where x can be (GPIOA...GPIOF) to select the GPIO group.
|
||||
*
|
||||
* @param GPIO_Pin: select the pin to read.(GPIO_Pin_0...GPIO_Pin_15)
|
||||
*
|
||||
* @retval The output status
|
||||
*/
|
||||
uint8_t GPIO_ReadOutputDataBit(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin);
|
||||
|
||||
/**
|
||||
* @brief Clears the selected pin(only output mode)
|
||||
*
|
||||
* @param GPIOx: where x can be (GPIOA...GPIOF) to select the GPIO group.
|
||||
*
|
||||
* @param GPIO_Pin: select the pin to read.(GPIO_Pin_0...GPIO_Pin_15)
|
||||
*
|
||||
* @retval None
|
||||
*/
|
||||
void GPIO_ResetBits(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin);
|
||||
|
||||
/**
|
||||
* @brief sets the selected pin(only output mode)
|
||||
*
|
||||
* @param GPIOx: where x can be (GPIOA...GPIOF) to select the GPIO group.
|
||||
*
|
||||
* @param GPIO_Pin: select the pin to read.(GPIO_Pin_0...GPIO_Pin_15)
|
||||
*
|
||||
* @retval None
|
||||
*/
|
||||
void GPIO_SetBits(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin);
|
||||
|
||||
/**
|
||||
* @brief init GPIO_InitStruct to default value.
|
||||
* @param GPIO_InitStruct : pointer to a GPIO_InitTypeDef structure which will be initialized.
|
||||
* @retval None
|
||||
*/
|
||||
void GPIO_StructInit(GPIO_InitTypeDef *GPIO_InitStruct);
|
||||
|
||||
/**
|
||||
* @brief Writes data to the GPIO group port(only output mode)
|
||||
*
|
||||
* @param GPIOx: where x can be (GPIOA...GPIOF) to select the GPIO group.
|
||||
*
|
||||
* @param value: specifies the value to be written to the port output data register.
|
||||
*
|
||||
* @retval None
|
||||
*/
|
||||
void GPIO_Write(GPIO_TypeDef GPIOx, uint16_t value);
|
||||
|
||||
/**
|
||||
* @brief Sets or clears the selected data port bit(only output mode)
|
||||
*
|
||||
* @param GPIOx: where x can be (GPIOA...GPIOF) to select the GPIO group.
|
||||
*
|
||||
* @param GPIO_Pin: select the pin to read.(GPIO_Pin_0...GPIO_Pin_7)
|
||||
*
|
||||
* @param BitVal: specifies the value to be written to the selected bit.
|
||||
* This parameter can be one of the BitAction enum values:
|
||||
* @arg Bit_RESET: to clear the port pin
|
||||
* @arg Bit_SET: to set the port pin
|
||||
* @retval None
|
||||
*/
|
||||
void GPIO_WriteBit(GPIO_TypeDef GPIOx, uint16_t GPIO_Pin, BitAction BitVal);
|
||||
|
||||
#endif /* __YC_GPIO_H__ */
|
||||
@@ -0,0 +1,72 @@
|
||||
/*
|
||||
File Name : yc_systick.c
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2018/03/27
|
||||
Description : systick encapsulation.
|
||||
*/
|
||||
|
||||
#include "yc_systick.h"
|
||||
|
||||
tick SystickCount;
|
||||
|
||||
void Systick_Dealy_Ms(uint32_t MS)
|
||||
{
|
||||
uint32_t ReloadValue;
|
||||
|
||||
ReloadValue = MS * 9600;
|
||||
|
||||
*SYSTICK_CSR &= ~(((uint32_t)1) << SYSTICK_CSR_ENABLE);
|
||||
*SYSTICK_RVR = ReloadValue; //Set the reload value
|
||||
*SYSTICK_CVR = 0; //clear the current value
|
||||
*SYSTICK_CSR |= ((SYSTICK_SYSCLOCK << SYSTICK_CSR_CLKSOURCE) | (1 << SYSTICK_CSR_ENABLE));
|
||||
|
||||
while (!(*SYSTICK_CVR == 0));
|
||||
*SYSTICK_RVR = 0;
|
||||
}
|
||||
|
||||
uint32_t SysTick_Config(uint32_t ReloadValue)
|
||||
{
|
||||
ReloadValue -= 1;
|
||||
if (!IS_RELOAD_VALUE(ReloadValue))
|
||||
return 1;
|
||||
|
||||
*SYSTICK_CSR &= ~(((uint32_t)1) << SYSTICK_CSR_ENABLE);
|
||||
|
||||
*SYSTICK_RVR = ReloadValue; //Set the reload value
|
||||
*SYSTICK_CVR = 0; //clear the current value
|
||||
SystickCount = 0; // Reset the overflow counter
|
||||
*SYSTICK_CSR |=
|
||||
((SYSTICK_SYSCLOCK << SYSTICK_CSR_CLKSOURCE) |
|
||||
(1 << SYSTICK_CSR_ENABLE) |
|
||||
(1 << SYSTICK_CSR_TICKINT));
|
||||
return 0;
|
||||
}
|
||||
|
||||
tick SysTick_GetTick()
|
||||
{
|
||||
return SystickCount;
|
||||
}
|
||||
|
||||
Boolean SysTick_IsTimeOut(tick start_tick, int interval)
|
||||
{
|
||||
start_tick = SysTick_GetTick() - start_tick;
|
||||
if (start_tick < 0)
|
||||
start_tick += TICK_MAX_VALUE;
|
||||
if (((start_tick * (*SYSTICK_RVR)) / (CPU_MHZ / 1000)) >= interval)
|
||||
{
|
||||
return TRUE;
|
||||
}
|
||||
else
|
||||
{
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
|
||||
uint32_t SysTick_GetRelativeTime(tick start_tick)
|
||||
{
|
||||
start_tick = SysTick_GetTick() - start_tick;
|
||||
if (start_tick < 0)
|
||||
start_tick += TICK_MAX_VALUE;
|
||||
return ((start_tick * (*SYSTICK_RVR)) / (CPU_MHZ / 1000));
|
||||
}
|
||||
@@ -0,0 +1,64 @@
|
||||
/*
|
||||
File Name : yc_systick.h
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2018/03/27
|
||||
Description : systick encapsulation.
|
||||
*/
|
||||
|
||||
#ifndef __YC_SYSTICK_H__
|
||||
#define __YC_SYSTICK_H__
|
||||
#include "..\core\yc3121.h"
|
||||
|
||||
#define SYSTICK_SYSCLOCK 1
|
||||
#define SYSTICK_HALF_SYSCLOCK 0
|
||||
|
||||
#define IS_RELOAD_VALUE(x) (x>0&&x<=0xffffff)
|
||||
|
||||
typedef int32_t tick;
|
||||
#define TICK_MAX_VALUE (int32_t)0x7FFFFFFF
|
||||
|
||||
|
||||
void Systick_Dealy_Ms(uint32_t MS);
|
||||
|
||||
/**
|
||||
* @brief Initialize systick and start systick
|
||||
*
|
||||
* @param ReloadValue : the systick reload value
|
||||
*
|
||||
* @retval 0:succeed 1:error
|
||||
*/
|
||||
uint32_t SysTick_Config(uint32_t ReloadValue);
|
||||
|
||||
|
||||
/**
|
||||
* @brief get the current value of SystickCount(SystickCount plus one for every overflow interrupt)
|
||||
*
|
||||
* @param none
|
||||
*
|
||||
* @retval current value of SystickCount
|
||||
*/
|
||||
tick SysTick_GetTick(void);
|
||||
|
||||
/**
|
||||
* @brief Determine whether the timeout that millisecond.
|
||||
*
|
||||
* @param start_tick:start tick
|
||||
*
|
||||
* @param interval:time interval(ms)
|
||||
*
|
||||
* @retval TRUE is timeout ,FALSE is not timeout
|
||||
*/
|
||||
Boolean SysTick_IsTimeOut(tick start_tick,int interval);
|
||||
|
||||
|
||||
/**
|
||||
* @brief get relative time .
|
||||
*
|
||||
* @param start_tick:start tick(start time)
|
||||
*
|
||||
* @retval the relative time(millisecond)
|
||||
*/
|
||||
uint32_t SysTick_GetRelativeTime(tick start_tick);
|
||||
|
||||
#endif /* __YC_SYSTICK_H__ */
|
||||
@@ -0,0 +1,429 @@
|
||||
/*
|
||||
File Name : yc_uart.c
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2019/12/4
|
||||
Description : UART encapsulation.
|
||||
*/
|
||||
#include "yc_uart.h"
|
||||
|
||||
#define uart_DMA_buf_len 1024
|
||||
uint8_t uart0_DMA_buf[uart_DMA_buf_len] = {0};
|
||||
uint8_t uart1_DMA_buf[uart_DMA_buf_len] = {0};
|
||||
|
||||
#define RX_ENABLE_BIT 0
|
||||
#define RX_ENABLE (1 << RX_ENABLE_BIT)
|
||||
|
||||
#define UART_DMA_ENABLE_BIT 31
|
||||
#define UART_DMA_ENABLE (1 << UART_DMA_ENABLE_BIT)
|
||||
|
||||
#define TX_INTR_ENABLE_BIT 31
|
||||
#define TX_INTR_ENABLE ((uint32_t)1 << TX_INTR_ENABLE_BIT)
|
||||
|
||||
#define Set_RxITNum_Mask 0xff00
|
||||
#define Statu_RxNum_Mask (uint32_t)0xffff0000
|
||||
|
||||
void UART_AutoFlowCtrlCmd(UART_TypeDef UARTx, FunctionalState NewState)
|
||||
{
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
|
||||
if (NewState == ENABLE)
|
||||
{
|
||||
switch (UARTx)
|
||||
{
|
||||
case UART0:
|
||||
UART0_CTRL |= FlowCtrl_Enable;
|
||||
break;
|
||||
case UART1:
|
||||
UART1_CTRL |= FlowCtrl_Enable;
|
||||
break;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
switch (UARTx)
|
||||
{
|
||||
case UART0:
|
||||
UART0_CTRL &= (~FlowCtrl_Enable);
|
||||
break;
|
||||
case UART1:
|
||||
UART1_CTRL &= (~FlowCtrl_Enable);
|
||||
break;
|
||||
}
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
void UART_ClearIT(UART_TypeDef UARTx)
|
||||
{
|
||||
uint8_t ITType = UART_GetITIdentity(UARTx);
|
||||
UART_ITConfig(UARTx, ITType, DISABLE);
|
||||
}
|
||||
|
||||
void UART_DeInit(UART_TypeDef UARTx)
|
||||
{
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
|
||||
switch (UARTx)
|
||||
{
|
||||
case UART0:
|
||||
UART0_CTRL = 0;
|
||||
break;
|
||||
case UART1:
|
||||
UART1_CTRL = 0;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void UART_DMASendBuf(UART_TypeDef UARTx, uint8_t *buf, int len)
|
||||
{
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
_ASSERT(NULL != buf);
|
||||
_ASSERT((len < 0xffff));
|
||||
|
||||
if (UARTx == UART0)
|
||||
{
|
||||
DMA_SRC_ADDR(DMACH_UART0) = (int)buf;
|
||||
DMA_LEN(DMACH_UART0) = (DMA_LEN(DMACH_UART0) & 0xffff) | len << 16;
|
||||
DMA_START(DMACH_UART0) = (1 << DMA_START_BIT);
|
||||
}
|
||||
else
|
||||
{
|
||||
DMA_SRC_ADDR(DMACH_UART1) = (int)buf;
|
||||
DMA_LEN(DMACH_UART1) = (DMA_LEN(DMACH_UART1) & 0xffff) | len << 16;
|
||||
DMA_START(DMACH_UART1) = (1 << DMA_START_BIT);
|
||||
}
|
||||
}
|
||||
|
||||
uint8_t UART_GetITIdentity(UART_TypeDef UARTx)
|
||||
{
|
||||
uint8_t IT_Mode = 0;
|
||||
switch (UARTx)
|
||||
{
|
||||
case UART0:
|
||||
{
|
||||
if (((UART0_CTRL & Set_RxITNum_Mask) > 0) && ((UART0_STATUS >> 16) > 0))
|
||||
{
|
||||
IT_Mode = UART_IT_RX;
|
||||
}
|
||||
else
|
||||
{
|
||||
if ((UART0_CTRL & (uint32_t)TX_INTR_ENABLE))
|
||||
{
|
||||
IT_Mode = UART_IT_TX;
|
||||
}
|
||||
else
|
||||
{
|
||||
IT_Mode = FALSE;
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
case UART1:
|
||||
{
|
||||
if (((UART1_CTRL & Set_RxITNum_Mask) > 0) && ((UART1_STATUS >> 16) > 0))
|
||||
{
|
||||
IT_Mode = UART_IT_RX;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (UART1_CTRL & TX_INTR_ENABLE)
|
||||
{
|
||||
IT_Mode = UART_IT_TX;
|
||||
}
|
||||
else
|
||||
{
|
||||
IT_Mode = FALSE;
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
return IT_Mode;
|
||||
}
|
||||
|
||||
void UART_Init(UART_TypeDef UARTx, UART_InitTypeDef *UART_InitStruct)
|
||||
{
|
||||
#define RESET_BAUD (1 << 7)
|
||||
#define AUTO_BAUD (0 << 7)
|
||||
uint32_t reg_value = 0;
|
||||
uint32_t temp_baudrate = 0;
|
||||
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
_ASSERT(IS_MODE(UART_InitStruct->Mode));
|
||||
_ASSERT(IS_BAUDRATE(UART_InitStruct->BaudRate));
|
||||
_ASSERT(IS_PARITY(UART_InitStruct->Parity));
|
||||
_ASSERT(IS_FlowCtrl(UART_InitStruct->FlowCtrl));
|
||||
_ASSERT(IS_USART_STOPBITS(UART_InitStruct->StopBits));
|
||||
|
||||
temp_baudrate = ((48000000 / UART_InitStruct->BaudRate) << 16);
|
||||
|
||||
reg_value = RX_ENABLE |
|
||||
UART_InitStruct->Parity |
|
||||
UART_InitStruct->DataBits |
|
||||
UART_InitStruct->StopBits |
|
||||
UART_InitStruct->FlowCtrl |
|
||||
UART_InitStruct->Mode |
|
||||
RESET_BAUD |
|
||||
temp_baudrate;
|
||||
|
||||
if (UARTx == UART0)
|
||||
{
|
||||
UART0_CTRL = 0;
|
||||
DMA_DEST_ADDR(DMACH_UART0) = (int)uart0_DMA_buf;
|
||||
DMA_LEN(DMACH_UART0) = uart_DMA_buf_len;
|
||||
DMA_CONFIG(DMACH_UART0) = 1;
|
||||
DMA_START(DMACH_UART0) |= (1 << (DMA_RESET_BIT));
|
||||
DMA_START(DMACH_UART0) &= ~(1 << (DMA_RESET_BIT));
|
||||
UART0_CTRL = 0;
|
||||
UART0_CTRL = reg_value;
|
||||
}
|
||||
else
|
||||
{
|
||||
UART1_CTRL = 0;
|
||||
DMA_DEST_ADDR(DMACH_UART1) = (int)uart1_DMA_buf;
|
||||
DMA_LEN(DMACH_UART1) = uart_DMA_buf_len;
|
||||
DMA_CONFIG(DMACH_UART1) = 1;
|
||||
DMA_START(DMACH_UART1) |= (1 << (DMA_RESET_BIT));
|
||||
DMA_START(DMACH_UART1) &= ~(1 << (DMA_RESET_BIT));
|
||||
UART1_CTRL = 0;
|
||||
UART1_CTRL = reg_value;
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
Boolean UART_IsRXFIFOFull(UART_TypeDef UARTx)
|
||||
{
|
||||
#define BITRXFULL 1
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
|
||||
if (UART0 == UARTx)
|
||||
{
|
||||
return (Boolean)(UART0_STATUS & (1 << BITRXFULL));
|
||||
}
|
||||
else
|
||||
{
|
||||
return (Boolean)(UART1_STATUS & (1 << BITRXFULL));
|
||||
}
|
||||
}
|
||||
|
||||
Boolean UART_IsRXFIFONotEmpty(UART_TypeDef UARTx)
|
||||
{
|
||||
#define BITRXEMPTY 0
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
|
||||
if (UART0 == UARTx)
|
||||
{
|
||||
return (Boolean)((UART0_STATUS >> 16) ? 1 : 0);
|
||||
}
|
||||
else
|
||||
{
|
||||
return (Boolean)((UART1_STATUS >> 16) ? 1 : 0);
|
||||
}
|
||||
}
|
||||
|
||||
Boolean UART_IsUARTBusy(UART_TypeDef UARTx)
|
||||
{
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
|
||||
if (UART0 == UARTx)
|
||||
{
|
||||
return (Boolean)(!(DMA_STATUS(DMACH_UART0) & 1));
|
||||
}
|
||||
else
|
||||
{
|
||||
return (Boolean)(!(DMA_STATUS(DMACH_UART1) & 1));
|
||||
}
|
||||
}
|
||||
|
||||
void UART_ITConfig(UART_TypeDef UARTx, uint32_t UART_IT, FunctionalState NewState)
|
||||
{
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
_ASSERT(IS_UART_IT(UART_IT));
|
||||
|
||||
switch (UARTx)
|
||||
{
|
||||
case UART0:
|
||||
{
|
||||
if (UART_IT == UART_IT_RX)
|
||||
{
|
||||
if (NewState)
|
||||
{
|
||||
UART0_CTRL |= ((ENABLE << 8));
|
||||
}
|
||||
else
|
||||
{
|
||||
UART0_CTRL &= ~Set_RxITNum_Mask;
|
||||
}
|
||||
}
|
||||
else if (UART_IT == UART_IT_TX)
|
||||
{
|
||||
UART0_CTRL &= (~TX_INTR_ENABLE);
|
||||
UART0_CTRL |= (NewState << TX_INTR_ENABLE_BIT);
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
case UART1:
|
||||
{
|
||||
if (UART_IT == UART_IT_RX)
|
||||
{
|
||||
if (NewState)
|
||||
{
|
||||
UART1_CTRL |= ((ENABLE << 8));
|
||||
}
|
||||
else
|
||||
{
|
||||
UART1_CTRL &= ~Set_RxITNum_Mask;
|
||||
}
|
||||
}
|
||||
else if (UART_IT == UART_IT_TX)
|
||||
{
|
||||
UART1_CTRL &= (uint32_t)~TX_INTR_ENABLE;
|
||||
UART1_CTRL |= (NewState << TX_INTR_ENABLE_BIT);
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
uint8_t UART_ReceiveData(UART_TypeDef UARTx)
|
||||
{
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
|
||||
if (UART0 == UARTx)
|
||||
{
|
||||
return UART0_RDATA;
|
||||
}
|
||||
else
|
||||
{
|
||||
return UART1_RDATA;
|
||||
}
|
||||
}
|
||||
|
||||
int UART_RecvBuf(UART_TypeDef UARTx, uint8_t *buf, int len)
|
||||
{
|
||||
uint32_t length = 0;
|
||||
volatile int *pstatus = NULL;
|
||||
volatile unsigned char *pdata = NULL;
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
_ASSERT(NULL != buf);
|
||||
|
||||
if (UART0 == UARTx)
|
||||
{
|
||||
pstatus = &UART0_STATUS;
|
||||
pdata = &UART0_RDATA;
|
||||
}
|
||||
else
|
||||
{
|
||||
pstatus = &UART1_STATUS;
|
||||
pdata = &UART1_RDATA;
|
||||
}
|
||||
|
||||
while ((*pstatus >> 16) > 0)
|
||||
{
|
||||
if (length < len)
|
||||
{
|
||||
buf[length++] = *pdata;
|
||||
}
|
||||
else
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return length;
|
||||
}
|
||||
|
||||
void UART_SendBuf(UART_TypeDef UARTx, uint8_t *buf, int len)
|
||||
{
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
_ASSERT(NULL != buf);
|
||||
_ASSERT((len < 0xffff));
|
||||
|
||||
if (UARTx == UART0)
|
||||
{
|
||||
DMA_SRC_ADDR(DMACH_UART0) = (int)buf;
|
||||
DMA_LEN(DMACH_UART0) = (DMA_LEN(DMACH_UART0) & 0xffff) | len << 16;
|
||||
DMA_START(DMACH_UART0) = (1 << DMA_START_BIT);
|
||||
while ((!(DMA_STATUS(DMACH_UART0) & 1)));
|
||||
}
|
||||
else
|
||||
{
|
||||
DMA_SRC_ADDR(DMACH_UART1) = (int)buf;
|
||||
DMA_LEN(DMACH_UART1) = (DMA_LEN(DMACH_UART1) & 0xffff) | len << 16;
|
||||
DMA_START(DMACH_UART1) = (1 << DMA_START_BIT);
|
||||
while ((!(DMA_STATUS(DMACH_UART1) & 1)));
|
||||
}
|
||||
}
|
||||
|
||||
void UART_SendData(UART_TypeDef UARTx, uint8_t Data)
|
||||
{
|
||||
uint8_t buf[1] = {Data};
|
||||
|
||||
if (UARTx == UART0)
|
||||
{
|
||||
DMA_SRC_ADDR(DMACH_UART0) = (int)buf;
|
||||
DMA_LEN(DMACH_UART0) = (DMA_LEN(DMACH_UART0) & 0xffff) | 1 << 16;
|
||||
DMA_START(DMACH_UART0) = (1 << DMA_START_BIT);
|
||||
while (!(DMA_STATUS(DMACH_UART0) & 1));
|
||||
}
|
||||
else
|
||||
{
|
||||
DMA_SRC_ADDR(DMACH_UART1) = (int)buf;
|
||||
DMA_LEN(DMACH_UART1) = (DMA_LEN(DMACH_UART1) & 0xffff) | 1 << 16;
|
||||
DMA_START(DMACH_UART1) = (1 << DMA_START_BIT);
|
||||
while (!(DMA_STATUS(DMACH_UART1) & 1));
|
||||
}
|
||||
}
|
||||
|
||||
void UART_SetITTimeout(UART_TypeDef UARTx, uint16_t timeout)
|
||||
{
|
||||
if (UART0 == UARTx)
|
||||
{
|
||||
UART0_INTR = timeout;
|
||||
}
|
||||
else
|
||||
{
|
||||
UART1_INTR = timeout;
|
||||
}
|
||||
}
|
||||
|
||||
void UART_SetRxITNum(UART_TypeDef UARTx, uint8_t Bcnt)
|
||||
{
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
|
||||
if (UART0 == UARTx)
|
||||
{
|
||||
UART0_CTRL = (UART0_CTRL & 0xffff00ff) | ((Bcnt & 0xff) << 8);
|
||||
}
|
||||
else
|
||||
{
|
||||
UART1_CTRL = (UART1_CTRL & 0xffff00ff) | ((Bcnt & 0xff) << 8);
|
||||
}
|
||||
}
|
||||
|
||||
void UART_StructInit(UART_InitTypeDef *UART_InitStruct)
|
||||
{
|
||||
UART_InitStruct->BaudRate = 9600;
|
||||
UART_InitStruct->DataBits = Databits_8b;
|
||||
UART_InitStruct->FlowCtrl = FlowCtrl_None;
|
||||
UART_InitStruct->Mode = Mode_duplex;
|
||||
UART_InitStruct->StopBits = StopBits_1;
|
||||
UART_InitStruct->Parity = 0;
|
||||
}
|
||||
|
||||
uint16_t UART_ReceiveDataLen(UART_TypeDef UARTx)
|
||||
{
|
||||
_ASSERT(IS_UART(UARTx));
|
||||
|
||||
if (UART0 == UARTx)
|
||||
{
|
||||
return (uint16_t)(UART0_STATUS >> 16);
|
||||
}
|
||||
else
|
||||
{
|
||||
return (uint16_t)(UART1_STATUS >> 16);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,304 @@
|
||||
/*
|
||||
File Name : yc_uart.h
|
||||
Author : Yichip
|
||||
Version : V1.0
|
||||
Date : 2019/12/4
|
||||
Description : UART encapsulation.
|
||||
*/
|
||||
#ifndef __YC_UART_H__
|
||||
#define __YC_UART_H__
|
||||
|
||||
#include "yc3121.h"
|
||||
|
||||
/** @def time of UART receive data time out intterrupt. real time = regvalue*48
|
||||
* @{
|
||||
*/
|
||||
#define TIME_IT_TIMEOUT (uint16_t)0x01
|
||||
|
||||
/** @defgroup USART_Mode
|
||||
* @{
|
||||
*/
|
||||
#define Mode_Single_Line (1<<6)
|
||||
#define Mode_duplex (0<<6)
|
||||
#define IS_MODE(MODE) (((MODE) == Mode_Single_Line) ||\
|
||||
((MODE) == Mode_duplex))
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/** @
|
||||
* @defgroup USART_DataBits
|
||||
*/
|
||||
#define Databits_8b (0<<2)
|
||||
#define Databits_9b (1<<2)
|
||||
|
||||
#define IS_USART_WORD_LENGTH(LENGTH) (((LENGTH) == Databits_8b) || \
|
||||
((LENGTH) == Databits_9b))
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/** @defgroup USART_Stop_Bits
|
||||
* @{
|
||||
*/
|
||||
#define StopBits_1 (0<<3)
|
||||
#define StopBits_2 (1<<3)
|
||||
#define IS_USART_STOPBITS(STOPBITS) (((STOPBITS) == StopBits_1) || \
|
||||
((STOPBITS) == StopBits_2) )
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/** @defgroup USART_Hardware_Flow_Control
|
||||
* @{
|
||||
*/
|
||||
#define FlowCtrl_None (0<<4)
|
||||
#define FlowCtrl_Enable (1<<4)
|
||||
|
||||
#define IS_FlowCtrl(CONTROL) (((CONTROL) == FlowCtrl_None) || \
|
||||
((CONTROL) == FlowCtrl_Enable))
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/** @defgroup UART_Interrupt_Type_definition
|
||||
* @{
|
||||
*/
|
||||
#define UART_IT_TX 0x01
|
||||
#define UART_IT_RX 0x02
|
||||
#define IS_UART_IT(x) (x == UART_IT_TX)||(x == UART_IT_RX)
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/** @defgroup USART_Parity
|
||||
* @{
|
||||
*/
|
||||
#define Parity_None (0<<1)
|
||||
#define Parity_Even (0<<1)
|
||||
#define Parity_Odd (1<<1)
|
||||
#define IS_PARITY(PARITY) (((PARITY) == Parity_Even) ||\
|
||||
((PARITY) == Parity_None) ||\
|
||||
((PARITY) == Parity_Odd))
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/** @defgroup USART_BaudRate
|
||||
* @{
|
||||
*/
|
||||
#define IS_BAUDRATE(BAUDRATE) (((BAUDRATE) > 0x5B8) && ((BAUDRATE) < 0x0044AA21))
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
typedef struct
|
||||
{
|
||||
uint8_t Mode; /*!< Specifies wether the Receive or Transmit mode is enabled or disabled.
|
||||
This parameter can be a value of @ref USART_Mode */
|
||||
|
||||
uint32_t BaudRate; /*!< This member configures the USART communication baud rate. */
|
||||
|
||||
uint8_t DataBits; /*!< Specifies the number of data bits transmitted or received in a frame.
|
||||
This parameter can be a value of @ref USART_DataBits */
|
||||
|
||||
uint8_t StopBits; /*!< Specifies the number of stop bits transmitted.
|
||||
This parameter can be a value of @ref USART_Stop_Bits */
|
||||
|
||||
uint8_t Parity; /*!< Specifies the parity mode.
|
||||
This parameter can be a value of @ref USART_Parity
|
||||
@note When parity is enabled, the computed parity is inserted
|
||||
at the MSB position of the transmitted data (9th bit when
|
||||
the word length is set to 9 data bits; 8th bit when the
|
||||
word length is set to 8 data bits). */
|
||||
|
||||
uint8_t FlowCtrl; /*!< Specifies wether the hardware flow control mode is enabled or disabled.
|
||||
This parameter can be a value of @ref USART_Hardware_Flow_Control */
|
||||
|
||||
int RxBufLen; /*!< Specifies uart DMA Rx buff length */
|
||||
|
||||
} UART_InitTypeDef;
|
||||
|
||||
/** @defgroup UART_TypeDef
|
||||
* @{
|
||||
*/
|
||||
typedef enum
|
||||
{
|
||||
UART0 = 0,
|
||||
UART1,
|
||||
} UART_TypeDef;
|
||||
|
||||
#define IS_UART(UARTx) (UARTx == UART0 ||UARTx == UART1)
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @brief ENABLE or DISABLE UARTx auto flow control
|
||||
* @param USARTx: Select the USART or the UART peripheral.
|
||||
* This parameter can be one of the following values:
|
||||
* UART0, UART1.
|
||||
* @param NewState:ENABLE or DISABLE auto flow control
|
||||
* @retval None
|
||||
*/
|
||||
void UART_AutoFlowCtrlCmd(UART_TypeDef UARTx, FunctionalState NewState);
|
||||
|
||||
/**
|
||||
* @brief Clear IT
|
||||
* @param USARTx: Select the USART or the UART peripheral.
|
||||
* This parameter can be one of the following values:
|
||||
* UART0, UART1.
|
||||
* @retval None
|
||||
*/
|
||||
void UART_ClearIT(UART_TypeDef UARTx);
|
||||
|
||||
/**
|
||||
* @brief DeInit UART
|
||||
* @param UARTx: Select the UART peripheral.
|
||||
* This parameter can be one of the following values:
|
||||
* UART0, UART1.
|
||||
* @retval None
|
||||
*/
|
||||
void UART_DeInit(UART_TypeDef UARTx);
|
||||
|
||||
/**
|
||||
* @brief Transmits datas via UART DMA .
|
||||
* @param USARTx: Select the USART or the UART peripheral.
|
||||
* This parameter can be one of the following values:
|
||||
* UART0, UART1.
|
||||
* @param buf: pointer to a buf that contains the data you want transmit.
|
||||
* @param len: the buf length
|
||||
* @retval None
|
||||
*/
|
||||
void UART_DMASendBuf(UART_TypeDef UARTx, uint8_t *buf, int len);
|
||||
|
||||
/**
|
||||
* @brief Get IT Identity
|
||||
* @param UARTx: Select the UART peripheral.
|
||||
* @retval IT Identity
|
||||
*/
|
||||
uint8_t UART_GetITIdentity(UART_TypeDef UARTx);
|
||||
|
||||
/**
|
||||
* @brief Initializes the USARTx peripheral according to the specified
|
||||
* parameters in the USART_InitStruct .
|
||||
* @param UARTx: Select the UART peripheral.
|
||||
* This parameter can be one of the following values:
|
||||
* UART0, UART1.
|
||||
* @param USART_InitStruct: pointer to a USART_InitTypeDef structure
|
||||
* that contains the configuration information for the specified USART
|
||||
* peripheral.
|
||||
* @retval None
|
||||
*/
|
||||
void UART_Init(UART_TypeDef UARTx, UART_InitTypeDef *UART_InitStruct);
|
||||
|
||||
/**
|
||||
* @brief Judge Rx fifo full is or not.
|
||||
* @param UARTx: Select the UART peripheral.
|
||||
* @retval TRUE:Rx fifo is full.
|
||||
* FALSE:Rx fifo is not full
|
||||
*/
|
||||
Boolean UART_IsRXFIFOFull(UART_TypeDef UARTx);
|
||||
|
||||
/**
|
||||
* @brief Judge Rx fifo empty is or not.
|
||||
* @param UARTx: Select the UART peripheral.
|
||||
* @retval TRUE:Rx fifo is not empty.
|
||||
* FALSE:Rx fifo is empty;
|
||||
*/
|
||||
Boolean UART_IsRXFIFONotEmpty(UART_TypeDef UARTx);
|
||||
|
||||
/**
|
||||
* @brief Judge UART is Busy or not
|
||||
* @param UARTx: Select the UART peripheral.
|
||||
* @retval None
|
||||
*/
|
||||
Boolean UART_IsUARTBusy(UART_TypeDef UARTx);
|
||||
|
||||
/**
|
||||
* @brief Config Interrupt trigger mode
|
||||
* @param USARTx: Select the USART or the UART peripheral.
|
||||
* This parameter can be one of the following values:
|
||||
* UART0, UART1.
|
||||
* @param UART_IT: Interrupt trigger mode ,this param will the following values,
|
||||
* UART_IT_TX:interrupt trigger after send data completed.
|
||||
* UART_IT_RX:interrupt trigger when received data.
|
||||
* @param NewState:
|
||||
* @retval None
|
||||
*/
|
||||
void UART_ITConfig(UART_TypeDef UARTx, uint32_t UART_IT, FunctionalState NewState);
|
||||
|
||||
/**
|
||||
* @brief Receive single data through the USARTx peripheral.
|
||||
* @param USARTx: Select the USART or the UART peripheral.
|
||||
* This parameter can be one of the following values:
|
||||
* UART0, UART1.
|
||||
* @retval None
|
||||
*/
|
||||
uint8_t UART_ReceiveData(UART_TypeDef UARTx);
|
||||
|
||||
/**
|
||||
* @brief Receives datas through the UART DMA.
|
||||
* @param USARTx: Select the USART or the UART peripheral.
|
||||
* This parameter can be one of the following values:
|
||||
* UART0, UART1.
|
||||
* @param buf: pointer to a buf that contains the data you want receive.
|
||||
* @param len: the buf length
|
||||
* @retval None
|
||||
*/
|
||||
int UART_RecvBuf(UART_TypeDef UARTx, uint8_t *buf, int len);
|
||||
|
||||
/**
|
||||
* @brief T ransmits datas via UART DMA,the function will return after datas is sent.
|
||||
* @param USARTx: Select the USART or the UART peripheral.
|
||||
* This parameter can be one of the following values:
|
||||
* UART0, UART1.
|
||||
* @param buf: pointer to a buf that contains the data you want transmit.
|
||||
* @param len: the buf length
|
||||
* @retval None
|
||||
*/
|
||||
void UART_SendBuf(UART_TypeDef UARTx, uint8_t *buf, int len);
|
||||
|
||||
/**
|
||||
* @brief UART Send One Data
|
||||
* @param UARTx: Select the UART peripheral.
|
||||
* @retval None
|
||||
*/
|
||||
void UART_SendData(UART_TypeDef UARTx, uint8_t Data);
|
||||
|
||||
/**
|
||||
* @brief UART_SetITTimeout
|
||||
* @param USARTx: Select the USART or the UART peripheral.
|
||||
* This parameter can be one of the following values:
|
||||
* UART0, UART1.
|
||||
* timeout: 0x0000~0xffff
|
||||
* @retval None
|
||||
*/
|
||||
void UART_SetITTimeout(UART_TypeDef UARTx, uint16_t timeout);
|
||||
|
||||
/**
|
||||
* @brief Set the number of uart receive data intterupt trigger
|
||||
* @param UARTx: Select the UART peripheral.
|
||||
* This parameter can be one of the following values:
|
||||
* UART0, UART1.
|
||||
* @param Bcnt: if the number of receive datas greater than Bcnt,interrupt trigger
|
||||
* @retval None
|
||||
*/
|
||||
void UART_SetRxITNum(UART_TypeDef UARTx, uint8_t Bcnt);
|
||||
|
||||
/**
|
||||
* @brief Fills each USART_InitStruct member with its default value.
|
||||
* @param USART_InitStruct: pointer to a USART_InitTypeDef structure
|
||||
* which will be initialized.
|
||||
* @retval None
|
||||
*/
|
||||
void UART_StructInit(UART_InitTypeDef *UART_InitStruct);
|
||||
|
||||
/**
|
||||
* @brief UART_ReceiveDataLen
|
||||
* @param UARTx: UART0 or UART1
|
||||
* @retval Data len
|
||||
*/
|
||||
uint16_t UART_ReceiveDataLen(UART_TypeDef UARTx);
|
||||
|
||||
#endif /*__YC_UART_H__*/
|
||||
@@ -0,0 +1,54 @@
|
||||
#include "yc_wdt.h"
|
||||
|
||||
#define WDT_ENABLE_BIT_Mask 6
|
||||
#define WDT_MODE_BIT_Mask 5
|
||||
#define SYSCTRL_WDT_EN_BIT_Mask 1
|
||||
|
||||
/**************the value of feed dog************/
|
||||
#define COUNTER_RELOAD_KEY 0x5937
|
||||
|
||||
void WDT_SetReload(uint32_t Reload)
|
||||
{
|
||||
uint32_t wdt_config = 0;
|
||||
|
||||
_ASSERT(ISWDTRELOAD(Reload));
|
||||
|
||||
wdt_config = WD_CONFIG;
|
||||
wdt_config &= 0xE0;
|
||||
wdt_config |= Reload;
|
||||
WD_CONFIG = wdt_config;
|
||||
}
|
||||
|
||||
void WDT_ReloadCounter(void)
|
||||
{
|
||||
WD_KICK = COUNTER_RELOAD_KEY;
|
||||
}
|
||||
|
||||
void WDT_Enable(void)
|
||||
{
|
||||
WD_CONFIG |= (1 << WDT_ENABLE_BIT_Mask);
|
||||
}
|
||||
|
||||
void WDT_ModeConfig(WDT_ModeTypeDef WDT_Mode)
|
||||
{
|
||||
WD_CONFIG &= ~(1 << WDT_MODE_BIT_Mask);
|
||||
WD_CONFIG |= (WDT_Mode << WDT_MODE_BIT_Mask);
|
||||
if (WDT_CPUReset == WDT_Mode)
|
||||
{
|
||||
SYSCTRL_RST_EN |= (1 << 1);
|
||||
}
|
||||
else
|
||||
{
|
||||
SYSCTRL_RST_EN &= ~(1 << 1);
|
||||
}
|
||||
}
|
||||
|
||||
ITStatus WDT_GetITStatus(void)
|
||||
{
|
||||
return (ITStatus)(WD_KICK & 1);
|
||||
}
|
||||
|
||||
void WDT_ClearITPendingBit(void)
|
||||
{
|
||||
WD_CLEAR = 1;
|
||||
}
|
||||
@@ -0,0 +1,74 @@
|
||||
/**
|
||||
******************************************************************************
|
||||
* @file yc_wdt.h
|
||||
* @author Yichip
|
||||
* @version V1.0
|
||||
* @date 7-Dec-2019
|
||||
* @brief watchdog encapsulation.
|
||||
*
|
||||
******************************************************************************
|
||||
*/
|
||||
|
||||
#ifndef __YC_WDT_H__
|
||||
#define __YC_WDT_H__
|
||||
|
||||
#include "yc3121.h"
|
||||
|
||||
/**
|
||||
* @brief timer number Structure definition
|
||||
*/
|
||||
typedef enum
|
||||
{
|
||||
WDT_CPUReset = 0,
|
||||
WDT_Interrupt,
|
||||
} WDT_ModeTypeDef;
|
||||
|
||||
#define ISWDTRELOAD(load) (load>0&&load<=0x1f)
|
||||
|
||||
/**
|
||||
* @brief Set reload counter
|
||||
* @param Reload: Reload counter equal to 2^reload.
|
||||
* @retval none
|
||||
*/
|
||||
void WDT_SetReload(uint32_t Reload);
|
||||
|
||||
/**
|
||||
* @brief Set WDT mode
|
||||
* @param WDT_Mode : Select the following values :
|
||||
* WDT_CPUReset
|
||||
* WDT_Interrupt.
|
||||
* @retval none
|
||||
* @description If Select WDT_CPUReset Mode,the bit for WDT RESET will be set;if
|
||||
* Select WDT_Interrupt the bit for WDT RESET will
|
||||
*/
|
||||
void WDT_ModeConfig(WDT_ModeTypeDef WDT_Mode);
|
||||
|
||||
/**
|
||||
* @brief Get interrupt Status
|
||||
* @param none
|
||||
* @retval SET:interrupt ocuured.
|
||||
*/
|
||||
ITStatus WDT_GetITStatus(void);
|
||||
|
||||
/**
|
||||
* @brief Clear interrupt
|
||||
* @param none
|
||||
* @retval none
|
||||
*/
|
||||
void WDT_ClearITPendingBit(void);
|
||||
|
||||
/**
|
||||
* @brief Enable WDT
|
||||
* @param none
|
||||
* @retval none
|
||||
*/
|
||||
void WDT_Enable(void);
|
||||
|
||||
/**
|
||||
* @brief Feed the watchdog function
|
||||
* @param none
|
||||
* @retval none
|
||||
*/
|
||||
void WDT_ReloadCounter(void);
|
||||
|
||||
#endif /*__YC_WDT_H__*/
|
||||
@@ -0,0 +1,396 @@
|
||||
AREA |.flash_start|, CODE, READONLY ,ALIGN=4
|
||||
|
||||
Reset_Handler PROC
|
||||
EXPORT Reset_Handler
|
||||
IMPORT __main
|
||||
LDR R0, =__main
|
||||
BX R0
|
||||
ENDP
|
||||
|
||||
|
||||
hard_fault_handler PROC
|
||||
EXPORT hard_fault_handler
|
||||
IMPORT HardFault_Handler
|
||||
ldr r0,=HardFault_Handler
|
||||
bx r0
|
||||
nop
|
||||
ENDP
|
||||
|
||||
svc_handler PROC
|
||||
EXPORT svc_handler
|
||||
ldr r0,=SVC_IRQHandler
|
||||
bx r0
|
||||
nop
|
||||
ENDP
|
||||
|
||||
pendsv_handler PROC
|
||||
EXPORT pendsv_handler
|
||||
IMPORT PendSV_Handler
|
||||
ldr r0,=PendSV_Handler
|
||||
bx r0
|
||||
nop
|
||||
ENDP
|
||||
|
||||
systick PROC
|
||||
EXPORT systick
|
||||
IMPORT SysTick_Handler
|
||||
ldr r0,=SysTick_Handler
|
||||
bx r0
|
||||
nop
|
||||
ENDP
|
||||
|
||||
irq0 PROC
|
||||
EXPORT irq0
|
||||
movs r0,#4*0
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq1 PROC
|
||||
EXPORT irq1
|
||||
movs r0,#4*1
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq2 PROC
|
||||
EXPORT irq2
|
||||
movs r0,#4*2
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq3 PROC
|
||||
EXPORT irq3
|
||||
movs r0,#4*3
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq4 PROC
|
||||
EXPORT irq4
|
||||
movs r0,#4*4
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq5 PROC
|
||||
EXPORT irq5
|
||||
movs r0,#4*5
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq6 PROC
|
||||
EXPORT irq6
|
||||
movs r0,#4*6
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq7 PROC
|
||||
EXPORT irq7
|
||||
movs r0,#4*7
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq8 PROC
|
||||
EXPORT irq8
|
||||
movs r0,#4*8
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq9 PROC
|
||||
EXPORT irq9
|
||||
movs r0,#4*9
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq10 PROC
|
||||
EXPORT irq10
|
||||
movs r0,#4*10
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq11 PROC
|
||||
EXPORT irq11
|
||||
movs r0,#4*11
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq12 PROC
|
||||
EXPORT irq12
|
||||
movs r0,#4*12
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq13 PROC
|
||||
EXPORT irq13
|
||||
movs r0,#4*13
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq14 PROC
|
||||
EXPORT irq14
|
||||
movs r0,#4*14
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq15 PROC
|
||||
EXPORT irq15
|
||||
movs r0,#4*15
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq16 PROC
|
||||
EXPORT irq16
|
||||
movs r0,#4*16
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq17 PROC
|
||||
EXPORT irq17
|
||||
movs r0,#4*17
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq18 PROC
|
||||
EXPORT irq18
|
||||
movs r0,#4*18
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq19 PROC
|
||||
EXPORT irq19
|
||||
movs r0,#4*19
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq20 PROC
|
||||
EXPORT irq20
|
||||
movs r0,#4*20
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq21 PROC
|
||||
EXPORT irq21
|
||||
movs r0,#4*21
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq22 PROC
|
||||
EXPORT irq22
|
||||
movs r0,#4*22
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq23 PROC
|
||||
EXPORT irq23
|
||||
movs r0,#4*23
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq24 PROC
|
||||
EXPORT irq24
|
||||
movs r0,#4*24
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq25 PROC
|
||||
EXPORT irq25
|
||||
movs r0,#4*25
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq26 PROC
|
||||
EXPORT irq26
|
||||
movs r0,#4*26
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq27 PROC
|
||||
EXPORT irq27
|
||||
movs r0,#4*27
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq28 PROC
|
||||
EXPORT irq28
|
||||
movs r0,#4*28
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq29 PROC
|
||||
EXPORT irq29
|
||||
movs r0,#4*29
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq30 PROC
|
||||
EXPORT irq30
|
||||
movs r0,#4*30
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
irq31 PROC
|
||||
EXPORT irq31
|
||||
movs r0,#4*31
|
||||
b isr
|
||||
ENDP
|
||||
|
||||
|
||||
isr PROC
|
||||
ldr r1,=isr_table
|
||||
ldr r0,[r0, r1]
|
||||
bx r0
|
||||
ENDP
|
||||
|
||||
ALIGN
|
||||
NMI_IRQHandler PROC
|
||||
EXPORT NMI_IRQHandler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
|
||||
HARD_FAULT_IRQHandler PROC
|
||||
EXPORT HARD_FAULT_IRQHandler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
|
||||
SVC_IRQHandler PROC
|
||||
EXPORT SVC_IRQHandler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
|
||||
PENDSV_IRQHandler PROC
|
||||
EXPORT PENDSV_IRQHandler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
|
||||
SYSTICK_IRQHandler PROC
|
||||
EXPORT SYSTICK_IRQHandler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
|
||||
EXTI0_IRQHandler PROC
|
||||
EXPORT EXTI0_IRQHandler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
|
||||
EXTI1_IRQHandler PROC
|
||||
EXPORT EXTI1_IRQHandler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
|
||||
EXTI2_IRQHandler PROC
|
||||
EXPORT EXTI2_IRQHandler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
|
||||
EXTI3_IRQHandler PROC
|
||||
EXPORT EXTI3_IRQHandler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
|
||||
EXTI4_IRQHandler PROC
|
||||
EXPORT EXTI4_IRQHandler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
|
||||
EXTI5_IRQHandler PROC
|
||||
EXPORT EXTI5_IRQHandler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
|
||||
Default_Handler PROC
|
||||
; ToDo: Add here the export definition for the device specific external interrupts handler
|
||||
EXPORT USB_IRQHandler [WEAK]
|
||||
EXPORT IIC_IRQHandler [WEAK]
|
||||
EXPORT QSPI_IRQHandler [WEAK]
|
||||
EXPORT SPI0_IRQHandler [WEAK]
|
||||
EXPORT SPI1_IRQHandler [WEAK]
|
||||
EXPORT UART0_IRQHandler [WEAK]
|
||||
EXPORT UART1_IRQHandler [WEAK]
|
||||
EXPORT MEMCP_IRQHandler [WEAK]
|
||||
EXPORT RSA_IRQHandler [WEAK]
|
||||
EXPORT SCI0_IRQHandler [WEAK]
|
||||
EXPORT SCI1_IRQHandler [WEAK]
|
||||
EXPORT BT_IRQHandler [WEAK]
|
||||
EXPORT GPIO_IRQHandler [WEAK]
|
||||
EXPORT TIMER0_IRQHandler [WEAK]
|
||||
EXPORT TIMER1_IRQHandler [WEAK]
|
||||
EXPORT TIMER2_IRQHandler [WEAK]
|
||||
EXPORT TIMER3_IRQHandler [WEAK]
|
||||
EXPORT TIMER4_IRQHandler [WEAK]
|
||||
EXPORT TIMER5_IRQHandler [WEAK]
|
||||
EXPORT TIMER6_IRQHandler [WEAK]
|
||||
EXPORT TIMER7_IRQHandler [WEAK]
|
||||
EXPORT TIMER8_IRQHandler [WEAK]
|
||||
EXPORT SM4_IRQHandler [WEAK]
|
||||
EXPORT SEC_IRQHandler [WEAK]
|
||||
EXPORT MSR_IRQHandler [WEAK]
|
||||
EXPORT TRNG_IRQHandler [WEAK]
|
||||
EXPORT WDT_IRQHandler [WEAK]
|
||||
|
||||
; ToDo: Add here the names for the device specific external interrupts handler
|
||||
USB_IRQHandler
|
||||
IIC_IRQHandler
|
||||
QSPI_IRQHandler
|
||||
SPI0_IRQHandler
|
||||
SPI1_IRQHandler
|
||||
UART0_IRQHandler
|
||||
UART1_IRQHandler
|
||||
MEMCP_IRQHandler
|
||||
RSA_IRQHandler
|
||||
SCI0_IRQHandler
|
||||
SCI1_IRQHandler
|
||||
BT_IRQHandler
|
||||
GPIO_IRQHandler
|
||||
TIMER0_IRQHandler
|
||||
TIMER1_IRQHandler
|
||||
TIMER2_IRQHandler
|
||||
TIMER3_IRQHandler
|
||||
TIMER4_IRQHandler
|
||||
TIMER5_IRQHandler
|
||||
TIMER6_IRQHandler
|
||||
TIMER7_IRQHandler
|
||||
TIMER8_IRQHandler
|
||||
SM4_IRQHandler
|
||||
SEC_IRQHandler
|
||||
MSR_IRQHandler
|
||||
TRNG_IRQHandler
|
||||
WDT_IRQHandler
|
||||
B .
|
||||
ENDP
|
||||
|
||||
|
||||
|
||||
EXPORT isr_table
|
||||
isr_table DCD USB_IRQHandler
|
||||
DCD IIC_IRQHandler
|
||||
DCD QSPI_IRQHandler
|
||||
DCD SPI0_IRQHandler
|
||||
DCD SPI1_IRQHandler
|
||||
DCD UART0_IRQHandler
|
||||
DCD UART1_IRQHandler
|
||||
DCD MEMCP_IRQHandler
|
||||
DCD RSA_IRQHandler
|
||||
DCD SCI0_IRQHandler
|
||||
DCD SCI1_IRQHandler
|
||||
DCD BT_IRQHandler
|
||||
DCD GPIO_IRQHandler
|
||||
DCD TIMER0_IRQHandler
|
||||
DCD TIMER1_IRQHandler
|
||||
DCD TIMER2_IRQHandler
|
||||
DCD TIMER3_IRQHandler
|
||||
DCD TIMER4_IRQHandler
|
||||
DCD TIMER5_IRQHandler
|
||||
DCD TIMER6_IRQHandler
|
||||
DCD TIMER7_IRQHandler
|
||||
DCD TIMER8_IRQHandler
|
||||
DCD SM4_IRQHandler
|
||||
DCD SEC_IRQHandler
|
||||
DCD MSR_IRQHandler
|
||||
DCD TRNG_IRQHandler
|
||||
DCD WDT_IRQHandler
|
||||
END
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -0,0 +1,318 @@
|
||||
.org 0x200
|
||||
.global Reset_Handler,hard_fault_handler,svc_handler,pendsv_handler,systick,irq0,irq1,irq2,irq3,irq4,irq5,irq6,irq7,irq8,irq9,irq10,irq11,irq12,irq13,irq14,irq15,irq16,irq17,irq18,irq19,irq20,irq21,irq22,irq23,irq24,irq25,irq26,irq27,irq28,irq29,irq30,irq31
|
||||
|
||||
.long
|
||||
|
||||
|
||||
Reset_Handler:
|
||||
ldr r0,=hardware_init
|
||||
bx r0
|
||||
.thumb_func
|
||||
|
||||
hard_fault_handler:
|
||||
ldr r0,=HARD_FAULT_IRQHandler
|
||||
bx r0
|
||||
nop
|
||||
.thumb_func
|
||||
|
||||
svc_handler:
|
||||
ldr r0,=SVC_IRQHandler
|
||||
bx r0
|
||||
nop
|
||||
.thumb_func
|
||||
|
||||
pendsv_handler:
|
||||
ldr r0,=PENDSV_IRQHandler
|
||||
bx r0
|
||||
nop
|
||||
.thumb_func
|
||||
systick:
|
||||
ldr r0,=SYSTICK_IRQHandler
|
||||
bx r0
|
||||
nop
|
||||
.thumb_func
|
||||
irq0:
|
||||
mov r0,#4*0
|
||||
b isr
|
||||
.thumb_func
|
||||
irq1:
|
||||
mov r0,#4*1
|
||||
b isr
|
||||
.thumb_func
|
||||
irq2:
|
||||
mov r0,#4*2
|
||||
b isr
|
||||
.thumb_func
|
||||
irq3:
|
||||
mov r0,#4*3
|
||||
b isr
|
||||
.thumb_func
|
||||
irq4:
|
||||
mov r0,#4*4
|
||||
b isr
|
||||
.thumb_func
|
||||
irq5:
|
||||
mov r0,#4*5
|
||||
b isr
|
||||
.thumb_func
|
||||
irq6:
|
||||
mov r0,#4*6
|
||||
b isr
|
||||
.thumb_func
|
||||
irq7:
|
||||
mov r0,#4*7
|
||||
b isr
|
||||
.thumb_func
|
||||
irq8:
|
||||
mov r0,#4*8
|
||||
b isr
|
||||
.thumb_func
|
||||
irq9:
|
||||
mov r0,#4*9
|
||||
b isr
|
||||
.thumb_func
|
||||
irq10:
|
||||
mov r0,#4*10
|
||||
b isr
|
||||
.thumb_func
|
||||
irq11:
|
||||
mov r0,#4*11
|
||||
b isr
|
||||
.thumb_func
|
||||
irq12:
|
||||
mov r0,#4*12
|
||||
b isr
|
||||
.thumb_func
|
||||
irq13:
|
||||
mov r0,#4*13
|
||||
b isr
|
||||
.thumb_func
|
||||
irq14:
|
||||
mov r0,#4*14
|
||||
b isr
|
||||
.thumb_func
|
||||
irq15:
|
||||
mov r0,#4*15
|
||||
b isr
|
||||
.thumb_func
|
||||
irq16:
|
||||
mov r0,#4*16
|
||||
b isr
|
||||
.thumb_func
|
||||
irq17:
|
||||
mov r0,#4*17
|
||||
b isr
|
||||
.thumb_func
|
||||
irq18:
|
||||
mov r0,#4*18
|
||||
b isr
|
||||
.thumb_func
|
||||
irq19:
|
||||
mov r0,#4*19
|
||||
b isr
|
||||
.thumb_func
|
||||
irq20:
|
||||
mov r0,#4*20
|
||||
b isr
|
||||
.thumb_func
|
||||
irq21:
|
||||
mov r0,#4*21
|
||||
b isr
|
||||
.thumb_func
|
||||
irq22: mov r0,#4*22
|
||||
b isr
|
||||
.thumb_func
|
||||
irq23:
|
||||
mov r0,#4*23
|
||||
b isr
|
||||
.thumb_func
|
||||
irq24:
|
||||
mov r0,#4*24
|
||||
b isr
|
||||
.thumb_func
|
||||
irq25: mov r0,#4*25
|
||||
b isr
|
||||
.thumb_func
|
||||
irq26:
|
||||
mov r0,#4*26
|
||||
b isr
|
||||
.thumb_func
|
||||
irq27:
|
||||
mov r0,#4*27
|
||||
b isr
|
||||
.thumb_func
|
||||
irq28:
|
||||
mov r0,#4*28
|
||||
b isr
|
||||
.thumb_func
|
||||
irq29:
|
||||
mov r0,#4*29
|
||||
b isr
|
||||
.thumb_func
|
||||
irq30:
|
||||
mov r0,#4*30
|
||||
b isr
|
||||
.thumb_func
|
||||
irq31:
|
||||
mov r0,#4*31
|
||||
b isr
|
||||
.thumb_func
|
||||
|
||||
|
||||
|
||||
isr:
|
||||
ldr r1,=isr_table
|
||||
ldr r0,[r0, r1]
|
||||
bx r0
|
||||
|
||||
|
||||
|
||||
|
||||
.align 4
|
||||
isr_table:
|
||||
.long USB_IRQHandler
|
||||
.long IIC_IRQHandler
|
||||
.long QSPI_IRQHandler
|
||||
.long SPI0_IRQHandler
|
||||
.long SPI1_IRQHandler
|
||||
.long UART0_IRQHandler
|
||||
.long UART1_IRQHandler
|
||||
.long MEMCP_IRQHandler
|
||||
.long RSA_IRQHandler
|
||||
.long SCI0_IRQHandler
|
||||
.long SCI1_IRQHandler
|
||||
.long BT_IRQHandler
|
||||
.long GPIO_IRQHandler
|
||||
.long TIMER0_IRQHandler
|
||||
.long TIMER1_IRQHandler
|
||||
.long TIMER2_IRQHandler
|
||||
.long TIMER3_IRQHandler
|
||||
.long TIMER4_IRQHandler
|
||||
.long TIMER5_IRQHandler
|
||||
.long TIMER6_IRQHandler
|
||||
.long TIMER7_IRQHandler
|
||||
.long TIMER8_IRQHandler
|
||||
.long SM4_IRQHandler
|
||||
.long SEC_IRQHandler
|
||||
.long MSR_IRQHandler
|
||||
.long TRNG_IRQHandler
|
||||
.long WDT_IRQHandler
|
||||
|
||||
.thumb
|
||||
.thumb_func
|
||||
hardware_init:
|
||||
ldr r1, =__exidx_start
|
||||
ldr r2, =__data_start__
|
||||
ldr r3, =__data_end__
|
||||
|
||||
sub r3, r2
|
||||
ble .L_loop1_done
|
||||
|
||||
.L_loop1:
|
||||
sub r3, #4
|
||||
ldr r0, [r1,r3]
|
||||
str r0, [r2,r3]
|
||||
bgt .L_loop1
|
||||
|
||||
.L_loop1_done:
|
||||
|
||||
|
||||
|
||||
/* Single BSS section scheme.
|
||||
*
|
||||
* The BSS section is specified by following symbols
|
||||
* _sbss: start of the BSS section.
|
||||
* _ebss: end of the BSS section.
|
||||
*
|
||||
* Both addresses must be aligned to 4 bytes boundary.
|
||||
*/
|
||||
ldr r1, =__bss_start__
|
||||
ldr r2, =__bss_end__
|
||||
|
||||
mov r0, #0
|
||||
|
||||
sub r2, r1
|
||||
ble .L_loop3_done
|
||||
|
||||
.L_loop3:
|
||||
sub r2, #4
|
||||
str r0, [r1, r2]
|
||||
bgt .L_loop3
|
||||
.L_loop3_done:
|
||||
ldr r0,=0x12345
|
||||
ldr r3,=0x1111
|
||||
bl main
|
||||
|
||||
|
||||
.globl delay
|
||||
.syntax unified
|
||||
delay:
|
||||
subs r0,#1
|
||||
bne delay
|
||||
nop
|
||||
bx lr
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
.align 1
|
||||
.thumb_func
|
||||
.weak Default_Handler
|
||||
.type Default_Handler, %function
|
||||
|
||||
Default_Handler:
|
||||
b .
|
||||
.size Default_Handler, . - Default_Handler
|
||||
|
||||
/* Macro to define default handlers. Default handler
|
||||
* will be weak symbol and just dead loops. They can be
|
||||
* overwritten by other handlers */
|
||||
|
||||
.macro def_irq_handler handler_name
|
||||
.weak \handler_name
|
||||
.set \handler_name, Default_Handler
|
||||
.endm
|
||||
|
||||
def_irq_handler HARD_FAULT_IRQHandler
|
||||
def_irq_handler SVC_IRQHandler
|
||||
def_irq_handler PENDSV_IRQHandler
|
||||
def_irq_handler SYSTICK_IRQHandler
|
||||
def_irq_handler USB_IRQHandler
|
||||
def_irq_handler IIC_IRQHandler
|
||||
def_irq_handler QSPI_IRQHandler
|
||||
def_irq_handler SPI0_IRQHandler
|
||||
def_irq_handler SPI1_IRQHandler
|
||||
def_irq_handler UART0_IRQHandler
|
||||
def_irq_handler UART1_IRQHandler
|
||||
def_irq_handler MEMCP_IRQHandler
|
||||
def_irq_handler RSA_IRQHandler
|
||||
def_irq_handler SCI0_IRQHandler
|
||||
def_irq_handler SCI1_IRQHandler
|
||||
def_irq_handler BT_IRQHandler
|
||||
def_irq_handler GPIO_IRQHandler
|
||||
def_irq_handler EXTI0_IRQHandler
|
||||
def_irq_handler EXTI1_IRQHandler
|
||||
def_irq_handler EXTI2_IRQHandler
|
||||
def_irq_handler TIMER0_IRQHandler
|
||||
def_irq_handler TIMER1_IRQHandler
|
||||
def_irq_handler TIMER2_IRQHandler
|
||||
def_irq_handler TIMER3_IRQHandler
|
||||
def_irq_handler TIMER4_IRQHandler
|
||||
def_irq_handler TIMER5_IRQHandler
|
||||
def_irq_handler TIMER6_IRQHandler
|
||||
def_irq_handler TIMER7_IRQHandler
|
||||
def_irq_handler TIMER8_IRQHandler
|
||||
def_irq_handler SM4_IRQHandler
|
||||
def_irq_handler SEC_IRQHandler
|
||||
def_irq_handler MSR_IRQHandler
|
||||
def_irq_handler TRNG_IRQHandler
|
||||
def_irq_handler WDT_IRQHandler
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -0,0 +1,311 @@
|
||||
MODULE ?cstartup
|
||||
|
||||
EXTERN __iar_program_start
|
||||
|
||||
SECTION CSTACK:DATA:NOROOT(3)
|
||||
|
||||
PUBLIC start_flash
|
||||
SECTION .intvec:CODE:REORDER(2)
|
||||
start_flash
|
||||
LDR R0, =hardware_init
|
||||
BX R0
|
||||
|
||||
PUBLIC hard_fault_handler
|
||||
hard_fault_handler
|
||||
BL HARD_FAULT_IRQHandler
|
||||
|
||||
PUBLIC svc_handler
|
||||
svc_handler
|
||||
BL SVC_IRQHandler
|
||||
|
||||
PUBLIC pendsv_handler
|
||||
pendsv_handler
|
||||
BL PENDSV_IRQHandler
|
||||
|
||||
PUBLIC systick
|
||||
systick
|
||||
BL SYSTICK_IRQHandler
|
||||
|
||||
PUBLIC irq0
|
||||
irq0
|
||||
movs r0,#0
|
||||
b isr
|
||||
|
||||
PUBLIC irq1
|
||||
irq1
|
||||
movs r0,#1
|
||||
b isr
|
||||
|
||||
PUBLIC irq2
|
||||
irq2
|
||||
movs r0,#2
|
||||
b isr
|
||||
|
||||
PUBLIC irq3
|
||||
irq3
|
||||
movs r0,#3
|
||||
b isr
|
||||
|
||||
PUBLIC irq4
|
||||
irq4
|
||||
movs r0,#4
|
||||
b isr
|
||||
|
||||
PUBLIC irq5
|
||||
irq5
|
||||
movs r0,#5
|
||||
b isr
|
||||
|
||||
PUBLIC irq6
|
||||
irq6
|
||||
movs r0,#6
|
||||
b isr
|
||||
|
||||
PUBLIC irq7
|
||||
irq7
|
||||
movs r0,#7
|
||||
b isr
|
||||
|
||||
PUBLIC irq8
|
||||
irq8
|
||||
movs r0,#8
|
||||
b isr
|
||||
|
||||
PUBLIC irq9
|
||||
irq9
|
||||
movs r0,#9
|
||||
b isr
|
||||
|
||||
PUBLIC irq10
|
||||
irq10
|
||||
movs r0,#10
|
||||
b isr
|
||||
|
||||
PUBLIC irq11
|
||||
irq11
|
||||
movs r0,#11
|
||||
b isr
|
||||
|
||||
PUBLIC irq12
|
||||
irq12
|
||||
movs r0,#12
|
||||
b isr
|
||||
|
||||
PUBLIC irq13
|
||||
irq13
|
||||
movs r0,#13
|
||||
b isr
|
||||
|
||||
PUBLIC irq14
|
||||
irq14
|
||||
movs r0,#14
|
||||
b isr
|
||||
|
||||
PUBLIC irq15
|
||||
irq15
|
||||
movs r0,#15
|
||||
b isr
|
||||
|
||||
PUBLIC irq16
|
||||
irq16
|
||||
movs r0,#16
|
||||
b isr
|
||||
|
||||
PUBLIC irq17
|
||||
irq17
|
||||
movs r0,#17
|
||||
b isr
|
||||
|
||||
PUBLIC irq18
|
||||
irq18
|
||||
movs r0,#18
|
||||
b isr
|
||||
|
||||
PUBLIC irq19
|
||||
irq19
|
||||
movs r0,#19
|
||||
b isr
|
||||
|
||||
PUBLIC irq20
|
||||
irq20
|
||||
movs r0,#20
|
||||
b isr
|
||||
|
||||
PUBLIC irq21
|
||||
irq21
|
||||
movs r0,#21
|
||||
b isr
|
||||
|
||||
PUBLIC irq22
|
||||
irq22
|
||||
movs r0,#22
|
||||
b isr
|
||||
|
||||
PUBLIC irq23
|
||||
irq23
|
||||
movs r0,#23
|
||||
b isr
|
||||
|
||||
PUBLIC irq24
|
||||
irq24
|
||||
movs r0,#24
|
||||
b isr
|
||||
|
||||
PUBLIC irq25
|
||||
irq25
|
||||
movs r0,#25
|
||||
b isr
|
||||
|
||||
PUBLIC irq26
|
||||
irq26
|
||||
movs r0,#26
|
||||
b isr
|
||||
|
||||
PUBLIC irq27
|
||||
irq27
|
||||
movs r0,#27
|
||||
b isr
|
||||
|
||||
PUBLIC irq28
|
||||
irq28
|
||||
movs r0,#28
|
||||
b isr
|
||||
|
||||
PUBLIC irq29
|
||||
irq29
|
||||
movs r0,#29
|
||||
b isr
|
||||
|
||||
PUBLIC irq30
|
||||
irq30
|
||||
movs r0,#30
|
||||
b isr
|
||||
|
||||
PUBLIC irq31
|
||||
irq31
|
||||
movs r0,#31
|
||||
b isr
|
||||
|
||||
PUBLIC isr
|
||||
isr
|
||||
ldr r1,=__vector_table
|
||||
ldr r0,[r0, r1]
|
||||
bx r0
|
||||
|
||||
|
||||
PUBWEAK HARD_FAULT_IRQHandler
|
||||
PUBWEAK SVC_IRQHandler
|
||||
PUBWEAK PENDSV_IRQHandler
|
||||
PUBWEAK SYSTICK_IRQHandler
|
||||
PUBWEAK USB_IRQHandler
|
||||
PUBWEAK IIC_IRQHandler
|
||||
PUBWEAK QSPI_IRQHandler
|
||||
PUBWEAK SPI0_IRQHandler
|
||||
PUBWEAK SPI1_IRQHandler
|
||||
PUBWEAK UART0_IRQHandler
|
||||
PUBWEAK UART1_IRQHandler
|
||||
PUBWEAK MEMCP_IRQHandler
|
||||
PUBWEAK RSA_IRQHandler
|
||||
PUBWEAK SCI0_IRQHandler
|
||||
PUBWEAK SCI1_IRQHandler
|
||||
PUBWEAK BT_IRQHandler
|
||||
PUBWEAK GPIO_IRQHandler
|
||||
PUBWEAK TIMER0_IRQHandler
|
||||
PUBWEAK TIMER1_IRQHandler
|
||||
PUBWEAK TIMER2_IRQHandler
|
||||
PUBWEAK TIMER3_IRQHandler
|
||||
PUBWEAK TIMER4_IRQHandler
|
||||
PUBWEAK TIMER5_IRQHandler
|
||||
PUBWEAK TIMER6_IRQHandler
|
||||
PUBWEAK TIMER7_IRQHandler
|
||||
PUBWEAK TIMER8_IRQHandler
|
||||
PUBWEAK SM4_IRQHandler
|
||||
PUBWEAK SEC_IRQHandler
|
||||
PUBWEAK MSR_IRQHandler
|
||||
PUBWEAK TRNG_IRQHandler
|
||||
PUBWEAK WDT_IRQHandler
|
||||
|
||||
|
||||
HARD_FAULT_IRQHandler
|
||||
SVC_IRQHandler
|
||||
PENDSV_IRQHandler
|
||||
SYSTICK_IRQHandler
|
||||
|
||||
USB_IRQHandler
|
||||
IIC_IRQHandler
|
||||
QSPI_IRQHandler
|
||||
SPI0_IRQHandler
|
||||
SPI1_IRQHandler
|
||||
UART0_IRQHandler
|
||||
UART1_IRQHandler
|
||||
MEMCP_IRQHandler
|
||||
RSA_IRQHandler
|
||||
SCI0_IRQHandler
|
||||
SCI1_IRQHandler
|
||||
BT_IRQHandler
|
||||
GPIO_IRQHandler
|
||||
TIMER0_IRQHandler
|
||||
TIMER1_IRQHandler
|
||||
TIMER2_IRQHandler
|
||||
TIMER3_IRQHandler
|
||||
TIMER4_IRQHandler
|
||||
TIMER5_IRQHandler
|
||||
TIMER6_IRQHandler
|
||||
TIMER7_IRQHandler
|
||||
TIMER8_IRQHandler
|
||||
SM4_IRQHandler
|
||||
SEC_IRQHandler
|
||||
MSR_IRQHandler
|
||||
TRNG_IRQHandler
|
||||
WDT_IRQHandler
|
||||
B .
|
||||
|
||||
PUBLIC delay
|
||||
delay
|
||||
subs r0,#1
|
||||
bne delay
|
||||
nop
|
||||
bx lr
|
||||
|
||||
PUBLIC __vector_table
|
||||
ALIGNROM 2
|
||||
data
|
||||
__vector_table
|
||||
DCD USB_IRQHandler
|
||||
DCD IIC_IRQHandler
|
||||
DCD QSPI_IRQHandler
|
||||
DCD SPI0_IRQHandler
|
||||
DCD SPI1_IRQHandler
|
||||
DCD UART0_IRQHandler
|
||||
DCD UART1_IRQHandler
|
||||
DCD MEMCP_IRQHandler
|
||||
DCD RSA_IRQHandler
|
||||
DCD SCI0_IRQHandler
|
||||
DCD SCI1_IRQHandler
|
||||
DCD BT_IRQHandler
|
||||
DCD GPIO_IRQHandler
|
||||
DCD TIMER0_IRQHandler
|
||||
DCD TIMER1_IRQHandler
|
||||
DCD TIMER2_IRQHandler
|
||||
DCD TIMER3_IRQHandler
|
||||
DCD TIMER4_IRQHandler
|
||||
DCD TIMER5_IRQHandler
|
||||
DCD TIMER6_IRQHandler
|
||||
DCD TIMER7_IRQHandler
|
||||
DCD TIMER8_IRQHandler
|
||||
DCD SM4_IRQHandler
|
||||
DCD SEC_IRQHandler
|
||||
DCD MSR_IRQHandler
|
||||
DCD TRNG_IRQHandler
|
||||
DCD WDT_IRQHandler
|
||||
|
||||
|
||||
PUBLIC hardware_init
|
||||
SECTION .intvec:CODE:REORDER(2)
|
||||
CODE
|
||||
hardware_init
|
||||
LDR R0, =sfe(CSTACK)
|
||||
mov sp, R0
|
||||
LDR R0, =__iar_program_start
|
||||
BX R0
|
||||
END
|
||||
@@ -0,0 +1,175 @@
|
||||
Stack_Size EQU 0x0000100
|
||||
|
||||
AREA STACK, NOINIT, READWRITE, ALIGN=4
|
||||
Stack_Mem SPACE Stack_Size
|
||||
__initial_sp EQU 0x30000
|
||||
|
||||
|
||||
; <h> Heap Configuration
|
||||
; <o> Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
|
||||
; </h>
|
||||
|
||||
Heap_Size EQU 0x00000000
|
||||
AREA HEAP, NOINIT, READWRITE, ALIGN=4
|
||||
__heap_base
|
||||
Heap_Mem SPACE Heap_Size
|
||||
__heap_limit
|
||||
|
||||
|
||||
PRESERVE8
|
||||
THUMB
|
||||
|
||||
|
||||
; Vector Table Mapped to Address 0 at Reset
|
||||
|
||||
AREA RESET, DATA, READONLY
|
||||
IMPORT systick
|
||||
IMPORT irq0
|
||||
IMPORT irq1
|
||||
IMPORT irq2
|
||||
IMPORT irq3
|
||||
IMPORT irq4
|
||||
IMPORT irq5
|
||||
IMPORT irq6
|
||||
IMPORT irq7
|
||||
IMPORT irq8
|
||||
IMPORT irq9
|
||||
IMPORT irq10
|
||||
IMPORT irq11
|
||||
IMPORT irq12
|
||||
IMPORT irq13
|
||||
IMPORT irq14
|
||||
IMPORT irq15
|
||||
IMPORT irq16
|
||||
IMPORT irq17
|
||||
IMPORT irq18
|
||||
IMPORT irq19
|
||||
IMPORT irq20
|
||||
IMPORT irq21
|
||||
IMPORT irq22
|
||||
IMPORT irq23
|
||||
IMPORT irq24
|
||||
IMPORT irq25
|
||||
IMPORT irq26
|
||||
IMPORT irq27
|
||||
IMPORT irq28
|
||||
IMPORT irq29
|
||||
IMPORT irq30
|
||||
IMPORT irq31
|
||||
IMPORT hard_fault_handler
|
||||
|
||||
EXPORT __Vectors
|
||||
EXPORT __Vectors_End
|
||||
EXPORT __Vectors_Size
|
||||
__Vectors DCD __initial_sp ; Top of Stack
|
||||
DCD reset_handler ; Reset Handler
|
||||
DCD nmi_handler ; NMI Handler
|
||||
DCD hard_fault_handler ; Hard Fault Handler
|
||||
DCD 0 ;
|
||||
DCD 0 ;
|
||||
DCD 0 ;
|
||||
DCD 0 ;
|
||||
DCD 0 ;
|
||||
DCD 0 ;
|
||||
DCD 0 ;
|
||||
DCD 0 ;
|
||||
DCD 0 ;
|
||||
DCD 0 ;
|
||||
DCD 0 ;
|
||||
DCD systick ;
|
||||
DCD irq0 ;
|
||||
DCD irq1 ;
|
||||
DCD irq2 ;
|
||||
DCD irq3 ;
|
||||
DCD irq4 ;
|
||||
DCD irq5 ;
|
||||
DCD irq6 ;
|
||||
DCD irq7 ;
|
||||
DCD irq8 ;
|
||||
DCD irq9 ;
|
||||
DCD irq10 ;
|
||||
DCD irq11 ;
|
||||
DCD irq12 ;
|
||||
DCD irq13 ;
|
||||
DCD irq14 ;
|
||||
DCD irq15 ;
|
||||
DCD irq16 ;
|
||||
DCD irq17 ;
|
||||
DCD irq18 ;
|
||||
DCD irq19 ;
|
||||
DCD irq20 ;
|
||||
DCD irq21 ;
|
||||
DCD irq22 ;
|
||||
DCD irq23 ;
|
||||
DCD irq24 ;
|
||||
DCD irq25 ;
|
||||
DCD irq26 ;
|
||||
DCD irq27 ;
|
||||
DCD irq28 ;
|
||||
DCD irq29 ;
|
||||
DCD irq30 ;
|
||||
DCD irq31 ;
|
||||
__Vectors_End
|
||||
|
||||
__Vectors_Size EQU __Vectors_End - __Vectors
|
||||
|
||||
AREA |.text|, CODE, READONLY ,ALIGN=4
|
||||
|
||||
|
||||
|
||||
; Reset Handler
|
||||
|
||||
reset_handler PROC
|
||||
EXPORT reset_handler [WEAK]
|
||||
IMPORT Reset_Handler
|
||||
; bl Reset_Handler
|
||||
; movs r0,#0x3
|
||||
|
||||
LDR R0, =Reset_Handler
|
||||
BX R0
|
||||
nop
|
||||
ENDP
|
||||
|
||||
|
||||
|
||||
delay PROC
|
||||
EXPORT delay
|
||||
subs r0,#1
|
||||
bne delay
|
||||
nop
|
||||
bx lr
|
||||
ENDP
|
||||
|
||||
nmi_handler PROC
|
||||
EXPORT nmi_handler [WEAK]
|
||||
b nmi_handler
|
||||
ENDP
|
||||
|
||||
ALIGN
|
||||
|
||||
AREA |.INIT_STACK_HEAP|, CODE,READONLY,ALIGN=4
|
||||
; User Initial Stack & Heap
|
||||
|
||||
IF :DEF:__MICROLIB
|
||||
EXPORT __initial_sp
|
||||
EXPORT __heap_base
|
||||
EXPORT __heap_limit
|
||||
|
||||
ELSE
|
||||
|
||||
IMPORT __use_two_region_memory
|
||||
EXPORT __user_initial_stackheap
|
||||
|
||||
__user_initial_stackheap PROC
|
||||
LDR R0, = Heap_Mem
|
||||
LDR R1, = __initial_sp
|
||||
LDR R2, = (Heap_Mem + Heap_Size)
|
||||
LDR R3, = Stack_Mem
|
||||
BX LR
|
||||
ENDP
|
||||
|
||||
ALIGN
|
||||
|
||||
ENDIF
|
||||
|
||||
END
|
||||
@@ -0,0 +1,36 @@
|
||||
# YC3121-pos 板级支持包 说明
|
||||
|
||||
标签: YICHIP、Cortex-M0、YC3121、国产MCU
|
||||
|
||||
---
|
||||
|
||||
## 1. 简介
|
||||
|
||||
本文档为 YC3121-pos 的 BSP(板级支持包) 说明。
|
||||
|
||||
通过阅读本文档,开发者可以快速地上手该 BSP,将 RT-Thread 运行在开发板上。
|
||||
|
||||
### 1.1 开发板介绍
|
||||
|
||||
YC3121-pos 开发板由易兆微提供,可满足基础测试及高端开发需求。
|
||||
|
||||
开发板外观如下图所示:
|
||||
|
||||
YC3121-pos
|
||||
|
||||

|
||||
|
||||
YC3121-pos 开发板板载资源如下:
|
||||
|
||||
- MCU:YC3121 ARM 32-bit Cortex-M0,主频 96MHz,512KB FLASH ,64KB SRAM
|
||||
- 常用外设
|
||||
- LED:4 个
|
||||
- 梯形矩阵键盘
|
||||
- 蜂鸣器
|
||||
- USB
|
||||
- UART
|
||||
- SPI LCD
|
||||
- SPI NFC
|
||||
- 7816
|
||||
- 7811
|
||||
- 调试接口:SWD
|
||||
@@ -0,0 +1,11 @@
|
||||
from building import *
|
||||
|
||||
cwd = GetCurrentDir()
|
||||
|
||||
objs = []
|
||||
list = os.listdir(cwd)
|
||||
for d in list:
|
||||
path = os.path.join(cwd, d)
|
||||
if os.path.isfile(os.path.join(path, 'SConscript')):
|
||||
objs = objs + SConscript(os.path.join(d, 'SConscript'))
|
||||
Return('objs')
|
||||
@@ -0,0 +1,40 @@
|
||||
import os
|
||||
import sys
|
||||
import rtconfig
|
||||
|
||||
if os.getenv('RTT_ROOT'):
|
||||
RTT_ROOT = os.getenv('RTT_ROOT')
|
||||
else:
|
||||
RTT_ROOT = os.path.normpath(os.getcwd() + '/../..')
|
||||
|
||||
sys.path = sys.path + [os.path.join(RTT_ROOT, 'tools')]
|
||||
try:
|
||||
from building import *
|
||||
except:
|
||||
print('Cannot found RT-Thread root directory, please check RTT_ROOT')
|
||||
print(RTT_ROOT)
|
||||
exit(-1)
|
||||
|
||||
TARGET = 'rtthread.' + rtconfig.TARGET_EXT
|
||||
|
||||
DefaultEnvironment(tools=[])
|
||||
env = Environment(tools = ['mingw'],
|
||||
AS = rtconfig.AS, ASFLAGS = rtconfig.AFLAGS,
|
||||
CC = rtconfig.CC, CCFLAGS = rtconfig.CFLAGS,
|
||||
AR = rtconfig.AR, ARFLAGS = '-rc',
|
||||
LINK = rtconfig.LINK, LINKFLAGS = rtconfig.LFLAGS)
|
||||
env.PrependENVPath('PATH', rtconfig.EXEC_PATH)
|
||||
|
||||
if rtconfig.PLATFORM == 'iar':
|
||||
env.Replace(CCCOM = ['$CC $CCFLAGS $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS -o $TARGET $SOURCES'])
|
||||
env.Replace(ARFLAGS = [''])
|
||||
env.Replace(LINKCOM = env["LINKCOM"] + ' --map project.map')
|
||||
|
||||
Export('RTT_ROOT')
|
||||
Export('rtconfig')
|
||||
|
||||
# prepare building environment
|
||||
objs = PrepareBuilding(env, RTT_ROOT, has_libcpu=False)
|
||||
|
||||
# make a building
|
||||
DoBuilding(TARGET, objs)
|
||||
@@ -0,0 +1,9 @@
|
||||
from building import *
|
||||
|
||||
cwd = GetCurrentDir()
|
||||
CPPPATH = [cwd, str(Dir('#'))]
|
||||
src = Glob('*.c')
|
||||
|
||||
group = DefineGroup('Applications', src, depend = [''], CPPPATH = CPPPATH)
|
||||
|
||||
Return('group')
|
||||
@@ -0,0 +1,31 @@
|
||||
/*
|
||||
* Copyright (c) 2006-2021, YICHIP Technology Co.,Ltd.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
* Change Logs:
|
||||
* Date Author Notes
|
||||
* 2021-09-09 WSY first version
|
||||
*/
|
||||
|
||||
#include <rtthread.h>
|
||||
#include <rtdevice.h>
|
||||
/* defined the LED pin: PA12 */
|
||||
#define LED_PIN 2
|
||||
|
||||
int main(void)
|
||||
{
|
||||
int count = 1;
|
||||
/* set LED4 pin mode to output */
|
||||
rt_pin_mode(LED_PIN, PIN_MODE_OUTPUT);
|
||||
|
||||
while (count++)
|
||||
{
|
||||
rt_pin_write(LED_PIN, PIN_HIGH);
|
||||
rt_thread_mdelay(500);
|
||||
rt_pin_write(LED_PIN, PIN_LOW);
|
||||
rt_thread_mdelay(500);
|
||||
}
|
||||
|
||||
return RT_EOK;
|
||||
}
|
||||
@@ -0,0 +1,22 @@
|
||||
menu "Hardware Drivers Config"
|
||||
|
||||
menu "On-chip Peripheral Drivers"
|
||||
config BSP_USING_GPIO
|
||||
bool "Enable GPIO"
|
||||
select RT_USING_PIN
|
||||
default y
|
||||
|
||||
menu "UART Drivers"
|
||||
config BSP_USING_UART0
|
||||
bool "Enable UART0 PA2/3(R/T)"
|
||||
select RT_USING_SERIAL
|
||||
default y
|
||||
|
||||
config BSP_USING_UART1
|
||||
bool "Enable UART1 PC2/3(R/T)"
|
||||
select RT_USING_SERIAL
|
||||
default n
|
||||
endmenu
|
||||
endmenu
|
||||
|
||||
endmenu
|
||||
@@ -0,0 +1,25 @@
|
||||
# RT-Thread building script for component
|
||||
|
||||
from building import *
|
||||
|
||||
cwd = GetCurrentDir()
|
||||
|
||||
# add the general drivers.
|
||||
src = Split("""
|
||||
board.c
|
||||
""")
|
||||
|
||||
# add gpio driver code
|
||||
if GetDepend(['BSP_USING_GPIO']):
|
||||
src += ['drv_gpio.c']
|
||||
|
||||
# add serial driver code
|
||||
if GetDepend('BSP_USING_UART0') or GetDepend('BSP_USING_UART1') or GetDepend('BSP_USING_UART2') or GetDepend('BSP_USING_UART3'):
|
||||
src += ['drv_uart.c']
|
||||
|
||||
|
||||
CPPPATH = [cwd]
|
||||
|
||||
group = DefineGroup('Drivers', src, depend = [''], CPPPATH = CPPPATH)
|
||||
|
||||
Return('group')
|
||||
@@ -0,0 +1,57 @@
|
||||
/*
|
||||
* Copyright (c) 2006-2021, YICHIP Technology Co.,Ltd.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
* Change Logs:
|
||||
* Date Author Notes
|
||||
* 2021-09-09 WSY first version
|
||||
*/
|
||||
|
||||
#include <board.h>
|
||||
#if defined(BSP_USING_EXT_SRAM) && defined(RT_USING_MEMHEAP_AS_HEAP)
|
||||
static struct rt_memheap system_heap;
|
||||
#endif
|
||||
#define SystemCoreClock (48000000)
|
||||
|
||||
static void bsp_clock_config(void)
|
||||
{
|
||||
SysTick_Config(SystemCoreClock / RT_TICK_PER_SECOND);
|
||||
}
|
||||
|
||||
void SysTick_Handler(void)
|
||||
{
|
||||
/* enter interrupt */
|
||||
rt_interrupt_enter();
|
||||
|
||||
rt_tick_increase();
|
||||
|
||||
/* leave interrupt */
|
||||
rt_interrupt_leave();
|
||||
}
|
||||
|
||||
#ifdef RT_USING_SERIAL
|
||||
extern int rt_hw_uart_init(void);
|
||||
#endif
|
||||
|
||||
void rt_hw_board_init()
|
||||
{
|
||||
bsp_clock_config();
|
||||
|
||||
#if defined(RT_USING_HEAP)
|
||||
rt_system_heap_init((void *)HEAP_BEGIN, (void *)HEAP_END);
|
||||
#endif
|
||||
|
||||
/* UART driver initialization is open by default */
|
||||
#ifdef RT_USING_SERIAL
|
||||
rt_hw_uart_init();
|
||||
#endif
|
||||
|
||||
#ifdef RT_USING_CONSOLE
|
||||
rt_console_set_device(RT_CONSOLE_DEVICE_NAME);
|
||||
#endif
|
||||
|
||||
#ifdef RT_USING_COMPONENTS_INIT
|
||||
rt_components_board_init();
|
||||
#endif
|
||||
}
|
||||
@@ -0,0 +1,44 @@
|
||||
/*
|
||||
* Copyright (c) 2006-2021, YICHIP Technology Co.,Ltd.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
* Change Logs:
|
||||
* Date Author Notes
|
||||
* 2021-09-09 WSY first version
|
||||
*/
|
||||
|
||||
#ifndef BOARD_H__
|
||||
#define BOARD_H__
|
||||
#include <rtthread.h>
|
||||
#include <yc3121.h>
|
||||
#include "yc_gpio.h"
|
||||
#include "yc_uart.h"
|
||||
#include "yc_systick.h"
|
||||
#include "misc.h"
|
||||
|
||||
#define SRAM_BASE 0x20000
|
||||
#define SRAM_SIZE 0x10000
|
||||
|
||||
#ifdef BSP_USING_EXT_SRAM
|
||||
#define EXT_SRAM_BASE SRAMM_BASE
|
||||
#define EXT_SRAM_SIZE BSP_EXT_SRAM_SIZE
|
||||
#define EXT_SRAM_BEGIN EXT_SRAM_BASE
|
||||
#define EXT_SRAM_END (EXT_SRAM_BASE + EXT_SRAM_SIZE)
|
||||
#endif
|
||||
|
||||
#define SRAM_END (SRAM_BASE + SRAM_SIZE)
|
||||
#if defined(__CC_ARM) || defined(__CLANG_ARM)
|
||||
extern int Image$$RW_IRAM1$$ZI$$Limit;
|
||||
#define HEAP_BEGIN ((void *)&Image$$RW_IRAM1$$ZI$$Limit)
|
||||
#elif __ICCARM__
|
||||
#pragma section = "HEAP"
|
||||
#define HEAP_BEGIN (__segment_end("HEAP"))
|
||||
#else
|
||||
extern int __bss_end;
|
||||
#define HEAP_BEGIN ((void *)&__bss_end)
|
||||
#endif
|
||||
#define HEAP_END SRAM_END
|
||||
#define HEAP_SIZE (HEAP_END - (rt_uint32_t)HEAP_BEGIN)
|
||||
extern void rt_hw_board_init(void);
|
||||
#endif
|
||||
@@ -0,0 +1,199 @@
|
||||
/*
|
||||
* Copyright (c) 2006-2021, YICHIP Technology Co.,Ltd.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
* Change Logs:
|
||||
* Date Author Notes
|
||||
* 2021-09-09 WSY first version
|
||||
*/
|
||||
|
||||
#include <rtthread.h>
|
||||
#include <rtdevice.h>
|
||||
#include <board.h>
|
||||
#include <rthw.h>
|
||||
|
||||
typedef void (*pin_callback_t)(void *args);
|
||||
struct pin
|
||||
{
|
||||
uint32_t package_index;
|
||||
const char *name;
|
||||
IRQn_Type irq;
|
||||
rt_uint32_t irq_mode;
|
||||
pin_callback_t callback;
|
||||
void *callback_args;
|
||||
};
|
||||
typedef struct pin pin_t;
|
||||
|
||||
static void yc_pin_mode(rt_device_t dev, rt_base_t pin, rt_base_t mode)
|
||||
{
|
||||
/* Configure GPIO_InitStructure */
|
||||
if (mode == PIN_MODE_OUTPUT)
|
||||
{
|
||||
/* output setting */
|
||||
GPIO_CONFIG(pin) = OUTPUT_LOW;
|
||||
}
|
||||
else if (mode == PIN_MODE_INPUT)
|
||||
{
|
||||
/* input setting: not pull. */
|
||||
GPIO_CONFIG(pin) = INPUT;
|
||||
}
|
||||
else if (mode == PIN_MODE_INPUT_PULLUP)
|
||||
{
|
||||
/* input setting: pull up. */
|
||||
GPIO_CONFIG(pin) = PULL_UP;
|
||||
}
|
||||
else if (mode == PIN_MODE_INPUT_PULLDOWN)
|
||||
{
|
||||
/* input setting: pull down. */
|
||||
GPIO_CONFIG(pin) = PULL_DOWN;
|
||||
}
|
||||
else if (mode == PIN_MODE_OUTPUT_OD)
|
||||
{
|
||||
/* output setting: od. */
|
||||
GPIO_CONFIG(pin) = PULL_UP;
|
||||
}
|
||||
}
|
||||
|
||||
static void yc_pin_write(rt_device_t dev, rt_base_t pin, rt_base_t value)
|
||||
{
|
||||
if (value)
|
||||
{
|
||||
GPIO_CONFIG(pin) = OUTPUT_HIGH;
|
||||
}
|
||||
else
|
||||
{
|
||||
GPIO_CONFIG(pin) = OUTPUT_LOW;
|
||||
}
|
||||
}
|
||||
|
||||
static int yc_pin_read(rt_device_t dev, rt_base_t pin)
|
||||
{
|
||||
return GPIO_IN(pin / 16) & (1 << (pin % 16)) ? 1 : 0;
|
||||
}
|
||||
|
||||
static rt_err_t yc_pin_attach_irq(struct rt_device *device,
|
||||
rt_int32_t pin,
|
||||
rt_uint32_t mode,
|
||||
pin_callback_t cb,
|
||||
void *args)
|
||||
{
|
||||
pin_t *index;
|
||||
rt_base_t level;
|
||||
if (index == RT_NULL)
|
||||
{
|
||||
return RT_EINVAL;
|
||||
}
|
||||
level = rt_hw_interrupt_disable();
|
||||
index->callback = cb;
|
||||
index->callback_args = args;
|
||||
index->irq_mode = mode;
|
||||
|
||||
rt_hw_interrupt_enable(level);
|
||||
return RT_EOK;
|
||||
}
|
||||
|
||||
static rt_err_t yc_pin_detach_irq(struct rt_device *device, rt_int32_t pin)
|
||||
{
|
||||
pin_t *index;
|
||||
rt_base_t level;
|
||||
if (index == RT_NULL)
|
||||
{
|
||||
return RT_EINVAL;
|
||||
}
|
||||
level = rt_hw_interrupt_disable();
|
||||
index->callback = 0;
|
||||
index->callback_args = 0;
|
||||
index->irq_mode = 0;
|
||||
rt_hw_interrupt_enable(level);
|
||||
return RT_EOK;
|
||||
}
|
||||
|
||||
static rt_err_t yc_pin_irq_enable(struct rt_device *device,
|
||||
rt_base_t pin,
|
||||
rt_uint32_t enabled)
|
||||
{
|
||||
pin_t *index;
|
||||
rt_base_t level = 0;
|
||||
if (index == RT_NULL)
|
||||
{
|
||||
return RT_EINVAL;
|
||||
}
|
||||
if (enabled == PIN_IRQ_ENABLE)
|
||||
{
|
||||
switch (index->irq_mode)
|
||||
{
|
||||
case PIN_IRQ_MODE_RISING:
|
||||
|
||||
break;
|
||||
case PIN_IRQ_MODE_FALLING:
|
||||
|
||||
break;
|
||||
case PIN_IRQ_MODE_RISING_FALLING:
|
||||
|
||||
break;
|
||||
case PIN_IRQ_MODE_HIGH_LEVEL:
|
||||
GPIO_CONFIG(pin) = PULL_DOWN;
|
||||
GPIO_TRIG_MODE(pin/16) &= (1 << (pin % 16));
|
||||
break;
|
||||
case PIN_IRQ_MODE_LOW_LEVEL:
|
||||
GPIO_CONFIG(pin) = PULL_UP;
|
||||
GPIO_TRIG_MODE(pin/16) |= (1 << (pin % 16));
|
||||
break;
|
||||
default:
|
||||
rt_hw_interrupt_enable(level);
|
||||
return RT_EINVAL;
|
||||
}
|
||||
|
||||
level = rt_hw_interrupt_disable();
|
||||
NVIC_EnableIRQ(index->irq);
|
||||
GPIO_INTR_EN(pin / 16) |= (1 << (pin % 16));
|
||||
rt_hw_interrupt_enable(level);
|
||||
}
|
||||
else if (enabled == PIN_IRQ_DISABLE)
|
||||
{
|
||||
NVIC_DisableIRQ(index->irq);
|
||||
GPIO_INTR_EN(pin / 16) &= ~(1 << (pin % 16));
|
||||
}
|
||||
else
|
||||
{
|
||||
return RT_ENOSYS;
|
||||
}
|
||||
return RT_EOK;
|
||||
}
|
||||
|
||||
const static struct rt_pin_ops yc3121_pin_ops =
|
||||
{
|
||||
yc_pin_mode,
|
||||
yc_pin_write,
|
||||
yc_pin_read,
|
||||
yc_pin_attach_irq,
|
||||
yc_pin_detach_irq,
|
||||
yc_pin_irq_enable,
|
||||
RT_NULL,
|
||||
};
|
||||
|
||||
int rt_hw_pin_init(void)
|
||||
{
|
||||
int result;
|
||||
result = rt_device_pin_register("pin", &yc3121_pin_ops, RT_NULL);
|
||||
return result;
|
||||
}
|
||||
INIT_BOARD_EXPORT(rt_hw_pin_init);
|
||||
|
||||
void GPIOA_Handler(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
/* enter interrupt */
|
||||
rt_interrupt_enter();
|
||||
|
||||
for (i = 0; i < 48; i++)
|
||||
{
|
||||
// if(GPIO_IN(pin / 16) & (1 << (pin % 16)))
|
||||
|
||||
}
|
||||
|
||||
/* leave interrupt */
|
||||
rt_interrupt_leave();
|
||||
}
|
||||
@@ -0,0 +1,16 @@
|
||||
/*
|
||||
* Copyright (c) 2006-2021, YICHIP Technology Co.,Ltd.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
* Change Logs:
|
||||
* Date Author Notes
|
||||
* 2021-09-09 WSY first version
|
||||
*/
|
||||
|
||||
#ifndef DRV_GPIO_H__
|
||||
#define DRV_GPIO_H__
|
||||
|
||||
int rt_hw_pin_init(void);
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,194 @@
|
||||
/*
|
||||
* Copyright (c) 2006-2021, YICHIP Technology Co.,Ltd.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
* Change Logs:
|
||||
* Date Author Notes
|
||||
* 2021-09-09 WSY first version
|
||||
*/
|
||||
|
||||
#include <rtthread.h>
|
||||
#include <rtdevice.h>
|
||||
#include <board.h>
|
||||
|
||||
struct yc3121_uart
|
||||
{
|
||||
UART_TypeDef uart;
|
||||
IRQn_Type irq;
|
||||
};
|
||||
|
||||
static rt_err_t yc3121_uart_configure(struct rt_serial_device *serial,
|
||||
struct serial_configure *cfg)
|
||||
{
|
||||
struct yc3121_uart *uart;
|
||||
UART_InitTypeDef UART_initStruct;
|
||||
RT_ASSERT(serial != RT_NULL);
|
||||
RT_ASSERT(cfg != RT_NULL);
|
||||
uart = (struct yc3121_uart *)serial->parent.user_data;
|
||||
NVIC_DisableIRQ(uart->irq);
|
||||
UART_initStruct.BaudRate = cfg->baud_rate;
|
||||
UART_initStruct.FlowCtrl = FlowCtrl_None ;
|
||||
UART_initStruct.Mode = Mode_duplex;
|
||||
|
||||
switch (cfg->data_bits)
|
||||
{
|
||||
case DATA_BITS_9:
|
||||
UART_initStruct.DataBits = Databits_9b;
|
||||
break;
|
||||
default:
|
||||
UART_initStruct.DataBits = Databits_8b;
|
||||
break;
|
||||
}
|
||||
switch (cfg->stop_bits)
|
||||
{
|
||||
case STOP_BITS_2:
|
||||
UART_initStruct.StopBits = StopBits_2;
|
||||
break;
|
||||
default:
|
||||
UART_initStruct.StopBits = StopBits_1;
|
||||
break;
|
||||
}
|
||||
switch (cfg->parity)
|
||||
{
|
||||
case PARITY_ODD:
|
||||
UART_initStruct.Parity = Parity_Odd;
|
||||
break;
|
||||
case PARITY_EVEN:
|
||||
UART_initStruct.Parity = Parity_Even;
|
||||
break;
|
||||
default:
|
||||
UART_initStruct.Parity = Parity_None;
|
||||
break;
|
||||
}
|
||||
UART_Init(uart->uart, &UART_initStruct);
|
||||
return RT_EOK;
|
||||
}
|
||||
|
||||
static rt_err_t yc3121_uart_control(struct rt_serial_device *serial,
|
||||
int cmd, void *arg)
|
||||
{
|
||||
struct yc3121_uart *uart;
|
||||
RT_ASSERT(serial != RT_NULL);
|
||||
uart = (struct yc3121_uart *)serial->parent.user_data;
|
||||
switch (cmd)
|
||||
{
|
||||
case RT_DEVICE_CTRL_CLR_INT:
|
||||
/* disable rx irq */
|
||||
UART_SetRxITNum(uart->uart, 0);
|
||||
NVIC_DisableIRQ(uart->irq);
|
||||
break;
|
||||
case RT_DEVICE_CTRL_SET_INT:
|
||||
/* enable rx irq */
|
||||
UART_SetRxITNum(uart->uart, 1);
|
||||
UART_ITConfig(uart->uart, UART_IT_RX, ENABLE);
|
||||
NVIC_EnableIRQ(uart->irq);
|
||||
break;
|
||||
}
|
||||
return RT_EOK;
|
||||
}
|
||||
|
||||
static int yc3121_uart_putc(struct rt_serial_device *serial, char c)
|
||||
{
|
||||
struct yc3121_uart *uart;
|
||||
RT_ASSERT(serial != RT_NULL);
|
||||
uart = (struct yc3121_uart *)serial->parent.user_data;
|
||||
while (UART_IsUARTBusy(uart->uart));
|
||||
UART_SendData(uart->uart, c);
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int yc3121_uart_getc(struct rt_serial_device *serial)
|
||||
{
|
||||
int ch;
|
||||
struct yc3121_uart *uart;
|
||||
RT_ASSERT(serial != RT_NULL);
|
||||
uart = (struct yc3121_uart *)serial->parent.user_data;
|
||||
ch = -1;
|
||||
if (UART_ReceiveDataLen(uart->uart) != 0)
|
||||
{
|
||||
ch = UART_ReceiveData(uart->uart);
|
||||
}
|
||||
return ch;
|
||||
}
|
||||
|
||||
static const struct rt_uart_ops yc3121_uart_ops =
|
||||
{
|
||||
yc3121_uart_configure,
|
||||
yc3121_uart_control,
|
||||
yc3121_uart_putc,
|
||||
yc3121_uart_getc,
|
||||
};
|
||||
|
||||
#if defined(BSP_USING_UART0)
|
||||
/* UART0 device driver structure */
|
||||
static struct yc3121_uart uart0;
|
||||
static struct rt_serial_device serial0;
|
||||
void UART0_IRQHandler(void)
|
||||
{
|
||||
/* enter interrupt */
|
||||
rt_interrupt_enter();
|
||||
|
||||
/* UART in mode Receiver */
|
||||
if (UART_GetITIdentity(uart0.uart) == UART_IT_RX)
|
||||
{
|
||||
rt_hw_serial_isr(&serial0, RT_SERIAL_EVENT_RX_IND);
|
||||
}
|
||||
/* leave interrupt */
|
||||
rt_interrupt_leave();
|
||||
}
|
||||
#endif /* BSP_USING_UART0 */
|
||||
|
||||
#if defined(BSP_USING_UART1)
|
||||
/* UART1 device driver structure */
|
||||
static struct yc3121_uart uart1;
|
||||
static struct rt_serial_device serial1;
|
||||
void UART1_IRQHandler(void)
|
||||
{
|
||||
/* enter interrupt */
|
||||
rt_interrupt_enter();
|
||||
|
||||
/* UART in mode Receiver */
|
||||
if (UART_GetITIdentity(uart1.uart) == UART_IT_RX)
|
||||
{
|
||||
rt_hw_serial_isr(&serial1, RT_SERIAL_EVENT_RX_IND);
|
||||
}
|
||||
/* leave interrupt */
|
||||
rt_interrupt_leave();
|
||||
}
|
||||
#endif /* BSP_USING_UART1 */
|
||||
|
||||
int rt_hw_uart_init(void)
|
||||
{
|
||||
struct yc3121_uart *uart;
|
||||
struct serial_configure config = RT_SERIAL_CONFIG_DEFAULT;
|
||||
#ifdef BSP_USING_UART0
|
||||
|
||||
GPIO_CONFIG(1) = UART0_TXD;
|
||||
GPIO_CONFIG(0) = UART0_RXD;
|
||||
uart = &uart0;
|
||||
uart->uart = UART0;
|
||||
uart->irq = UART0_IRQn;
|
||||
serial0.ops = &yc3121_uart_ops;
|
||||
serial0.config = config;
|
||||
/* register UART0 device */
|
||||
rt_hw_serial_register(&serial0, RT_CONSOLE_DEVICE_NAME,
|
||||
RT_DEVICE_FLAG_RDWR | RT_DEVICE_FLAG_INT_RX,
|
||||
uart);
|
||||
#endif /* BSP_USING_UART0 */
|
||||
#ifdef BSP_USING_UART1
|
||||
GPIO_CONFIG(1) = UART1_TXD;
|
||||
GPIO_CONFIG(0) = UART1_RXD;
|
||||
uart = &uart1;
|
||||
uart->uart = UART1;
|
||||
uart->irq = UART1_IRQn;
|
||||
serial1.ops = &yc3121_uart_ops;
|
||||
serial1.config = config;
|
||||
/* register UART1 device */
|
||||
rt_hw_serial_register(&serial1, "uart1",
|
||||
RT_DEVICE_FLAG_RDWR | RT_DEVICE_FLAG_INT_RX,
|
||||
uart);
|
||||
#endif /* BSP_USING_UART1 */
|
||||
return 0;
|
||||
}
|
||||
INIT_BOARD_EXPORT(rt_hw_uart_init);
|
||||
@@ -0,0 +1,16 @@
|
||||
/*
|
||||
* Copyright (c) 2006-2021, YICHIP Technology Co.,Ltd.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
* Change Logs:
|
||||
* Date Author Notes
|
||||
* 2021-09-09 WSY first version
|
||||
*/
|
||||
|
||||
#ifndef DRV_UART_H__
|
||||
#define DRV_UART_H__
|
||||
|
||||
int rt_hw_uart_init(void);
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,32 @@
|
||||
/*###ICF### Section handled by ICF editor, don't touch! ****/
|
||||
/*-Editor annotation file-*/
|
||||
/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
|
||||
/*-Specials-*/
|
||||
define symbol __ICFEDIT_intvec_start__ = 0x1000200;
|
||||
/*-Memory Regions-*/
|
||||
define symbol __ICFEDIT_region_ROM_start__ = 0x1000200;
|
||||
define symbol __ICFEDIT_region_ROM_end__ = 0x1ffffff;
|
||||
define symbol __ICFEDIT_region_RAM_start__ = 0x20000;
|
||||
define symbol __ICFEDIT_region_RAM_end__ = 0x2FFFF;
|
||||
/*-Sizes-*/
|
||||
define symbol __ICFEDIT_size_cstack__ = 0xF800;
|
||||
define symbol __ICFEDIT_size_heap__ = 0x800;
|
||||
/**** End of ICF editor section. ###ICF###*/
|
||||
|
||||
|
||||
define memory mem with size = 4G;
|
||||
define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
|
||||
define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
|
||||
|
||||
define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
|
||||
define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
|
||||
|
||||
initialize by copy { readwrite };
|
||||
//initialize by copy with packing = none { section __DLIB_PERTHREAD }; // Required in a multi-threaded application
|
||||
do not initialize { section .noinit };
|
||||
|
||||
place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
|
||||
|
||||
place in ROM_region { readonly };
|
||||
place in RAM_region { readwrite,
|
||||
block CSTACK, block HEAP };
|
||||
@@ -0,0 +1,161 @@
|
||||
/* Linker script to configure memory regions.
|
||||
* Need modifying for a specific board.
|
||||
* FLASH.ORIGIN: starting address of flash
|
||||
* FLASH.LENGTH: length of flash
|
||||
* RAM.ORIGIN: starting address of RAM bank 0
|
||||
* RAM.LENGTH: length of RAM bank 0
|
||||
*/
|
||||
MEMORY
|
||||
{
|
||||
FLASH (rx) : ORIGIN = 0x1000000, LENGTH = 0x80000 /* 512K */
|
||||
RAM (rwx) : ORIGIN = 0x20000, LENGTH = 0x10000 /* 64K */
|
||||
}
|
||||
|
||||
/* Linker script to place sections and symbol values. Should be used together
|
||||
* with other linker script that defines memory regions FLASH and RAM.
|
||||
* It references following symbols, which must be defined in code:
|
||||
* Reset_Handler : Entry of reset handler
|
||||
*
|
||||
* It defines following symbols, which code can use without definition:
|
||||
* __exidx_start
|
||||
* __exidx_end
|
||||
* __copy_table_start__
|
||||
* __copy_table_end__
|
||||
* __zero_table_start__
|
||||
* __zero_table_end__
|
||||
* __etext
|
||||
* __data_start__
|
||||
* __preinit_array_start
|
||||
* __preinit_array_end
|
||||
* __init_array_start
|
||||
* __init_array_end
|
||||
* __fini_array_start
|
||||
* __fini_array_end
|
||||
* __data_end__
|
||||
* __bss_start__
|
||||
* __bss_end__
|
||||
* __end__
|
||||
* end
|
||||
* __HeapLimit
|
||||
* __StackLimit
|
||||
* __StackTop
|
||||
* __stack
|
||||
*/
|
||||
ENTRY(Reset_Handler)
|
||||
|
||||
SECTIONS
|
||||
{
|
||||
.text :
|
||||
{
|
||||
*flash_start*.o
|
||||
*(.text*)
|
||||
|
||||
KEEP(*(.init))
|
||||
KEEP(*(.fini))
|
||||
|
||||
/* .ctors */
|
||||
*crtbegin.o(.ctors)
|
||||
*crtbegin?.o(.ctors)
|
||||
*(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors)
|
||||
*(SORT(.ctors.*))
|
||||
*(.ctors)
|
||||
|
||||
/* .dtors */
|
||||
*crtbegin.o(.dtors)
|
||||
*crtbegin?.o(.dtors)
|
||||
*(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors)
|
||||
*(SORT(.dtors.*))
|
||||
*(.dtors)
|
||||
|
||||
*(.rodata*)
|
||||
|
||||
KEEP(*(.eh_frame*))
|
||||
} > FLASH
|
||||
|
||||
|
||||
|
||||
.ARM.extab :
|
||||
{
|
||||
*(.ARM.extab* .gnu.linkonce.armextab.*)
|
||||
} > FLASH
|
||||
|
||||
|
||||
.ARM.exidx :
|
||||
{
|
||||
*(.ARM.exidx* .gnu.linkonce.armexidx.*)
|
||||
} > FLASH
|
||||
|
||||
. = ALIGN(4);
|
||||
__exidx_start = .;
|
||||
|
||||
__etext = .;
|
||||
|
||||
.data : AT (__etext)
|
||||
{
|
||||
__data_start__ = .;
|
||||
*(vtable)
|
||||
*(.data*)
|
||||
|
||||
. = ALIGN(4);
|
||||
/* preinit data */
|
||||
PROVIDE_HIDDEN (__preinit_array_start = .);
|
||||
KEEP(*(.preinit_array))
|
||||
PROVIDE_HIDDEN (__preinit_array_end = .);
|
||||
|
||||
. = ALIGN(4);
|
||||
/* init data */
|
||||
PROVIDE_HIDDEN (__init_array_start = .);
|
||||
KEEP(*(SORT(.init_array.*)))
|
||||
KEEP(*(.init_array))
|
||||
PROVIDE_HIDDEN (__init_array_end = .);
|
||||
|
||||
|
||||
. = ALIGN(4);
|
||||
/* finit data */
|
||||
PROVIDE_HIDDEN (__fini_array_start = .);
|
||||
KEEP(*(SORT(.fini_array.*)))
|
||||
KEEP(*(.fini_array))
|
||||
PROVIDE_HIDDEN (__fini_array_end = .);
|
||||
|
||||
KEEP(*(.jcr*))
|
||||
. = ALIGN(4);
|
||||
/* All data end */
|
||||
__data_end__ = .;
|
||||
|
||||
} > RAM
|
||||
|
||||
.bss :
|
||||
{
|
||||
. = ALIGN(4);
|
||||
__bss_start__ = .;
|
||||
*(.bss*)
|
||||
*(COMMON)
|
||||
. = ALIGN(4);
|
||||
__bss_end__ = .;
|
||||
} > RAM
|
||||
|
||||
.heap (COPY):
|
||||
{
|
||||
__end__ = .;
|
||||
PROVIDE(end = .);
|
||||
*(.heap*)
|
||||
__HeapLimit = .;
|
||||
} > RAM
|
||||
|
||||
/* .stack_dummy section doesn't contains any symbols. It is only
|
||||
* used for linker to calculate size of stack sections, and assign
|
||||
* values to stack symbols later */
|
||||
.stack_dummy (COPY):
|
||||
{
|
||||
*(.stack*)
|
||||
} > RAM
|
||||
|
||||
/* Set stack top to end of RAM, and stack limit move down by
|
||||
* size of stack_dummy section */
|
||||
__StackTop = ORIGIN(RAM) + LENGTH(RAM);
|
||||
__StackLimit = __StackTop - SIZEOF(.stack_dummy);
|
||||
PROVIDE(__stack = __StackTop);
|
||||
|
||||
/* Check if data + heap + stack exceeds RAM limit */
|
||||
ASSERT(__StackLimit >= __HeapLimit, "region RAM overflowed with stack")
|
||||
}
|
||||
@@ -0,0 +1,32 @@
|
||||
; *************************************************************
|
||||
; *** Scatter-Loading Description File generated by uVision ***
|
||||
; *************************************************************
|
||||
|
||||
LR_IROM1 0x00000000 0x0007fff { ; load region size_region
|
||||
ER_IROM1 0x00000000 0x00007fff { ; load address = execution address
|
||||
startup.o (RESET, +First)
|
||||
; startup.o (.text,+RO)
|
||||
; *(InRoot$$Sections)
|
||||
}
|
||||
}
|
||||
|
||||
LR_IROM3 0x1000200 0x200{
|
||||
ER_IROM3 0x1000200 {
|
||||
flash_start.o (|.flash_start|,+RO)
|
||||
}
|
||||
ER_IROM3_1 0x1000340 {
|
||||
startup.o (|.INIT_STACK_HEAP|,+RO)
|
||||
}
|
||||
}
|
||||
|
||||
LR_IROM4 0x1000400 0x1000000{
|
||||
ER_IROM4 0x1000400 {
|
||||
*(InRoot$$Sections)
|
||||
.ANY (+RO)
|
||||
}
|
||||
|
||||
RW_IRAM1 0x00020000 0x010000 { ; RW data
|
||||
.ANY (+RW +ZI)
|
||||
}
|
||||
}
|
||||
|
||||
Binary file not shown.
|
After Width: | Height: | Size: 240 KiB |
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,10 @@
|
||||
<?xml version="1.0" encoding="iso-8859-1"?>
|
||||
|
||||
<workspace>
|
||||
<project>
|
||||
<path>$WS_DIR$\project.ewp</path>
|
||||
</project>
|
||||
<batchBuild/>
|
||||
</workspace>
|
||||
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,178 @@
|
||||
#ifndef RT_CONFIG_H__
|
||||
#define RT_CONFIG_H__
|
||||
|
||||
/* Automatically generated file; DO NOT EDIT. */
|
||||
/* RT-Thread Configuration */
|
||||
|
||||
/* RT-Thread Kernel */
|
||||
|
||||
#define RT_NAME_MAX 8
|
||||
#define RT_ALIGN_SIZE 4
|
||||
#define RT_THREAD_PRIORITY_32
|
||||
#define RT_THREAD_PRIORITY_MAX 32
|
||||
#define RT_TICK_PER_SECOND 100
|
||||
#define RT_USING_OVERFLOW_CHECK
|
||||
#define RT_USING_HOOK
|
||||
#define RT_USING_IDLE_HOOK
|
||||
#define RT_IDLE_HOOK_LIST_SIZE 4
|
||||
#define IDLE_THREAD_STACK_SIZE 256
|
||||
|
||||
/* kservice optimization */
|
||||
|
||||
#define RT_DEBUG
|
||||
#define RT_DEBUG_COLOR
|
||||
|
||||
/* Inter-Thread communication */
|
||||
|
||||
#define RT_USING_SEMAPHORE
|
||||
#define RT_USING_MUTEX
|
||||
#define RT_USING_EVENT
|
||||
#define RT_USING_MAILBOX
|
||||
#define RT_USING_MESSAGEQUEUE
|
||||
|
||||
/* Memory Management */
|
||||
|
||||
#define RT_USING_MEMPOOL
|
||||
#define RT_USING_MEMHEAP
|
||||
#define RT_USING_SMALL_MEM
|
||||
#define RT_USING_HEAP
|
||||
|
||||
/* Kernel Device Object */
|
||||
|
||||
#define RT_USING_DEVICE
|
||||
#define RT_USING_CONSOLE
|
||||
#define RT_CONSOLEBUF_SIZE 128
|
||||
#define RT_CONSOLE_DEVICE_NAME "uart0"
|
||||
#define RT_VER_NUM 0x40004
|
||||
|
||||
/* RT-Thread Components */
|
||||
|
||||
#define RT_USING_COMPONENTS_INIT
|
||||
#define RT_USING_USER_MAIN
|
||||
#define RT_MAIN_THREAD_STACK_SIZE 2048
|
||||
#define RT_MAIN_THREAD_PRIORITY 10
|
||||
|
||||
/* C++ features */
|
||||
|
||||
|
||||
/* Command shell */
|
||||
|
||||
#define RT_USING_FINSH
|
||||
#define RT_USING_MSH
|
||||
#define FINSH_USING_MSH
|
||||
#define FINSH_THREAD_NAME "tshell"
|
||||
#define FINSH_THREAD_PRIORITY 20
|
||||
#define FINSH_THREAD_STACK_SIZE 4096
|
||||
#define FINSH_USING_HISTORY
|
||||
#define FINSH_HISTORY_LINES 5
|
||||
#define FINSH_USING_SYMTAB
|
||||
#define FINSH_CMD_SIZE 80
|
||||
#define MSH_USING_BUILT_IN_COMMANDS
|
||||
#define FINSH_USING_DESCRIPTION
|
||||
#define FINSH_ARG_MAX 10
|
||||
|
||||
/* Device virtual file system */
|
||||
|
||||
|
||||
/* Device Drivers */
|
||||
|
||||
#define RT_USING_DEVICE_IPC
|
||||
#define RT_PIPE_BUFSZ 512
|
||||
#define RT_USING_SERIAL
|
||||
#define RT_USING_SERIAL_V1
|
||||
#define RT_SERIAL_RB_BUFSZ 64
|
||||
#define RT_USING_PIN
|
||||
|
||||
/* Using USB */
|
||||
|
||||
|
||||
/* POSIX layer and C standard library */
|
||||
|
||||
#define RT_LIBC_USING_TIME
|
||||
#define RT_LIBC_DEFAULT_TIMEZONE 8
|
||||
|
||||
/* Network */
|
||||
|
||||
/* Socket abstraction layer */
|
||||
|
||||
|
||||
/* Network interface device */
|
||||
|
||||
|
||||
/* light weight TCP/IP stack */
|
||||
|
||||
|
||||
/* AT commands */
|
||||
|
||||
|
||||
/* VBUS(Virtual Software BUS) */
|
||||
|
||||
|
||||
/* Utilities */
|
||||
|
||||
|
||||
/* RT-Thread Utestcases */
|
||||
|
||||
|
||||
/* RT-Thread online packages */
|
||||
|
||||
/* IoT - internet of things */
|
||||
|
||||
|
||||
/* Wi-Fi */
|
||||
|
||||
/* Marvell WiFi */
|
||||
|
||||
|
||||
/* Wiced WiFi */
|
||||
|
||||
|
||||
/* IoT Cloud */
|
||||
|
||||
|
||||
/* security packages */
|
||||
|
||||
|
||||
/* language packages */
|
||||
|
||||
|
||||
/* multimedia packages */
|
||||
|
||||
|
||||
/* tools packages */
|
||||
|
||||
|
||||
/* system packages */
|
||||
|
||||
/* acceleration: Assembly language or algorithmic acceleration packages */
|
||||
|
||||
|
||||
/* Micrium: Micrium software products porting for RT-Thread */
|
||||
|
||||
|
||||
/* peripheral libraries and drivers */
|
||||
|
||||
|
||||
/* AI packages */
|
||||
|
||||
|
||||
/* miscellaneous packages */
|
||||
|
||||
/* samples: kernel and components samples */
|
||||
|
||||
|
||||
/* entertainment: terminal games and other interesting software packages */
|
||||
|
||||
#define SOC_SWM320VET7
|
||||
|
||||
/* Hardware Drivers Config */
|
||||
|
||||
/* On-chip Peripheral Drivers */
|
||||
|
||||
#define BSP_USING_GPIO
|
||||
|
||||
/* UART Drivers */
|
||||
|
||||
#define BSP_USING_UART0
|
||||
|
||||
#endif
|
||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user