Update bsp drivers for F334.

This commit is contained in:
JamieTx
2025-08-18 14:12:12 +08:00
committed by R b b666
parent 0b14a54614
commit 5f4319a6ca
124 changed files with 5023 additions and 1435 deletions

View File

@@ -3,15 +3,18 @@
HC32 系列 BSP 目前支持情况如下表所示:
| **BSP 文件夹名称** | **开发板名称** |
|:------------------------- |:------------------------- |
| **BSP 文件夹名称** | **开发板名称** |
|:------------------------- |:----------------------------- |
| **F1 系列** | |
| **F3 系列** | |
| [ev_hc32f334_lqfp64](ev_hc32f334_lqfp64) | 小华 官方 EV_F334_LQ64 开发板 |
| **F4 系列** | |
| [ev_hc32f460_lqfp100_v2](ev_hc32f460_lqfp100_v2) | 小华 官方 EV_F460_LQ100_V2 开发板 |
| [ev_hc32f4a0_lqfp176](ev_hc32f4a0_lqfp176) | 小华 官方 EV_F4A0_LQ176 开发板 |
| [ev_hc32f448_lqfp80](ev_hc32f448_lqfp80) | 小华 官方 EV_F448_LQ80 开发板 |
| [ev_hc32f472_lqfp100](ev_hc32f472_lqfp100) | 小华 官方 EV_F472_LQ100 开发板 |
| [lckfb-hc32f4a0-lqfp100](lckfb-hc32f4a0-lqfp100) | 立创开发板 天空星-HC32F4A0PITB |
| [ev_hc32f448_lqfp80](ev_hc32f448_lqfp80) | 小华 官方 EV_F448_LQ80 开发板 |
| [ev_hc32f460_lqfp100_v2](ev_hc32f460_lqfp100_v2) | 小华 官方 EV_F460_LQ100_V2 开发板 |
| [ev_hc32f472_lqfp100](ev_hc32f472_lqfp100) | 小华 官方 EV_F472_LQ100 开发板 |
| [ev_hc32f4a0_lqfp176](ev_hc32f4a0_lqfp176) | 小华 官方 EV_F4A0_LQ176 开发板 |
| [lckfb-hc32f4a0-lqfp100](lckfb-hc32f4a0-lqfp100) | 立创开发板 天空星-HC32F4A0PITB |
| [ev_hc32f4a8_lqfp176](ev_hc32f4a8_lqfp176) | 小华 官方 EV_F4A8_LQ176 开发板 |
| **M1 系列** | |
| **M4 系列** | |
@@ -23,4 +26,3 @@ HC32 系列 BSP 目前支持情况如下表所示:
| [外设驱动介绍](docs/HC32系列驱动介绍.md) | 讲解 HC32 系列 BSP 驱动的支持情况,以及如何利用驱动框架开发应用程序 |
| **BSP 制作与提交** | **简介** |
| [BSP 制作教程](docs/HC32系列BSP制作教程.md) | 讲解 HC32 系列 BSP 的制作方法 |

View File

@@ -1,7 +1,137 @@
devices.gpio:
kconfig:
- CONFIG_BSP_USING_GPIO=y
devices.uart:
# ------ device CI ------
devices.adc:
kconfig:
- CONFIG_BSP_USING_ADC=y
- CONFIG_BSP_USING_ADC1=y
- CONFIG_BSP_USING_ADC2=y
- CONFIG_BSP_USING_ADC3=y
- CONFIG_BSP_ADC1_USING_DMA=y
- CONFIG_BSP_ADC2_USING_DMA=y
- CONFIG_BSP_ADC3_USING_DMA=y
devices.crypto:
kconfig:
- CONFIG_BSP_USING_HWCRYPTO=y
- CONFIG_BSP_USING_UQID=y
- CONFIG_BSP_USING_CRC=y
devices.dac:
kconfig:
- CONFIG_BSP_USING_DAC=y
- CONFIG_BSP_USING_DAC1=y
- CONFIG_BSP_USING_DAC2=y
devices.flash:
kconfig:
- CONFIG_BSP_USING_ON_CHIP_FLASH=y
devices.gpio:
kconfig:
- CONFIG_BSP_USING_GPIO=y
devices.hwtimer:
kconfig:
- CONFIG_BSP_USING_HWTIMER=y
- CONFIG_BSP_USING_TMRA_1=y
devices.i2c:
kconfig:
- CONFIG_BSP_USING_I2C=y
- CONFIG_BSP_USING_I2C1=y
- CONFIG_BSP_I2C1_TX_USING_DMA=y
- CONFIG_BSP_I2C1_RX_USING_DMA=y
devices.input_capture:
kconfig:
- CONFIG_BSP_USING_INPUT_CAPTURE=y
- CONFIG_BSP_USING_INPUT_CAPTURE_TMR6=y
- CONFIG_BSP_USING_INPUT_CAPTURE_TMR6_1=y
devices.mcan:
kconfig:
- CONFIG_BSP_USING_MCAN=y
- CONFIG_BSP_USING_MCAN1=y
- CONFIG_BSP_USING_MCAN2=y
- CONFIG_RT_CAN_USING_CANFD=y
- CONFIG_RT_CAN_USING_HDR=y
devices.pm:
kconfig:
- CONFIG_BSP_USING_PM=y
- CONFIG_IDLE_THREAD_STACK_SIZE=512
devices.pulse_encoder_tmr6:
kconfig:
- CONFIG_BSP_USING_PULSE_ENCODER=y
- CONFIG_BSP_USING_TMR6_PULSE_ENCODER=y
- CONFIG_BSP_USING_PULSE_ENCODER_TMR6_1=y
devices.pulse_encoder_tmra:
kconfig:
- CONFIG_BSP_USING_PULSE_ENCODER=y
- CONFIG_BSP_USING_TMRA_PULSE_ENCODER=y
- CONFIG_BSP_USING_PULSE_ENCODER_TMRA_1=y
devices.pwm_tmr4:
kconfig:
- CONFIG_BSP_USING_PWM=y
- CONFIG_BSP_USING_PWM_TMR4=y
- CONFIG_BSP_USING_PWM_TMR4_1=y
- CONFIG_BSP_USING_PWM_TMR4_1_OUH=y
- CONFIG_BSP_USING_PWM_TMR4_1_OUL=y
- CONFIG_BSP_USING_PWM_TMR4_1_OVH=y
- CONFIG_BSP_USING_PWM_TMR4_1_OVL=y
- CONFIG_BSP_USING_PWM_TMR4_1_OWH=y
- CONFIG_BSP_USING_PWM_TMR4_1_OWL=y
- CONFIG_BSP_USING_PWM_TMR4_1_OXH=y
- CONFIG_BSP_USING_PWM_TMR4_1_OXL=y
devices.pwm_tmr6:
kconfig:
- CONFIG_BSP_USING_PWM=y
- CONFIG_BSP_USING_PWM_TMR6=y
- CONFIG_BSP_USING_PWM_TMR6_1=y
- CONFIG_BSP_USING_PWM_TMR6_1_A=y
- CONFIG_BSP_USING_PWM_TMR6_1_B=y
devices.pwm_tmra:
kconfig:
- CONFIG_BSP_USING_PWM=y
- CONFIG_BSP_USING_PWM_TMRA=y
- CONFIG_BSP_USING_PWM_TMRA_1=y
- CONFIG_BSP_USING_PWM_TMRA_1_CH1=y
- CONFIG_BSP_USING_PWM_TMRA_1_CH2=y
- CONFIG_BSP_USING_PWM_TMRA_1_CH3=y
- CONFIG_BSP_USING_PWM_TMRA_1_CH4=y
devices.rtc:
kconfig:
- CONFIG_BSP_USING_RTC=y
- CONFIG_RT_USING_ALARM=y
devices.soft_i2c:
kconfig:
- CONFIG_BSP_USING_I2C=y
- CONFIG_BSP_USING_I2C1_SW=y
devices.spi:
kconfig:
- CONFIG_BSP_USING_SPI=y
- CONFIG_BSP_USING_SPI1=y
- CONFIG_BSP_SPI1_TX_USING_DMA=y
- CONFIG_BSP_SPI1_RX_USING_DMA=y
- CONFIG_BSP_SPI_USING_DMA=y
devices.uart_v1:
kconfig:
- CONFIG_RT_USING_SERIAL_V1=y
- CONFIG_BSP_USING_UART=y
- CONFIG_BSP_USING_UART2=y
- CONFIG_BSP_USING_UART1=y
- CONFIG_RT_SERIAL_USING_DMA=y
- CONFIG_BSP_UART1_RX_USING_DMA=y
- CONFIG_BSP_UART1_TX_USING_DMA=y
devices.uart_v2:
kconfig:
- CONFIG_RT_USING_SERIAL_V2=y
- CONFIG_BSP_USING_UART=y
- CONFIG_BSP_USING_UART1=y
- CONFIG_RT_SERIAL_USING_DMA=y
- CONFIG_BSP_UART1_RX_USING_DMA=y
- CONFIG_BSP_UART1_TX_USING_DMA=y
devices.watchdog_swdt:
kconfig:
- CONFIG_BSP_USING_WDT_TMR=y
- CONFIG_BSP_USING_SWDT=y
devices.watchdog_wdt:
kconfig:
- CONFIG_BSP_USING_WDT_TMR=y
- CONFIG_BSP_USING_WDT=y
# ------ peripheral CI ------
peripheral.spi_flash:
kconfig:
- CONFIG_BSP_USING_SPI_FLASH=y
- CONFIG_BSP_USING_SPI=y
- CONFIG_BSP_USING_SPI1=y

View File

@@ -1,8 +1,8 @@
# XHSC EV_F334_LQ64_Rev1.0 开发板 BSP 说明
# XHSC EV_F334_LQ64 开发板 BSP 说明
## 简介
本文档为小华半导体为 EV_F334_LQ64_Rev1.0 开发板提供的 BSP (板级支持包) 说明。
本文档为小华半导体为 EV_F334_LQ64 开发板提供的 BSP (板级支持包) 说明。
主要内容如下:
@@ -14,79 +14,63 @@
## 开发板介绍
EV_F334_LQ64_Rev1.0 是 XHSC 官方推出的开发板,搭载 HC32F334MCTI 芯片,基于 ARM Cortex-M4 内核,最高主频 200 MHz具有丰富的板载资源可以充分发挥 HC32F334MCTI 的芯片性能。
EV_F334_LQ64 是 XHSC 官方推出的开发板,搭载 HC32F334KATI 芯片,基于 ARM Cortex-M4 内核,最高主频 120 MHz具有丰富的板载资源可以充分发挥 HC32F334KATI 的芯片性能。
开发板外观如下图所示:
![board](figures/board.png)
EV_F334_LQ64_Rev1.0 开发板常用 **板载资源** 如下:
EV_F334_LQ64 开发板常用 **板载资源** 如下:
- **MCU**
- HC32F334MCTI
- 主频200MHz
- 256KB FLASH
- 68KB RAM
- **外部Memory**
- BL24C256EEPROM, 256Kbits
- W25Q64SPI NOR64MB
- IS62WV51216SRAM 1MB
- **常用外设**
- LED: 4 个User LEDLED0LED1LED2LED3
- 按键: 5 个矩阵键盘K1~K4 WAKEUPK5RESETK0
- **常用接口**
- USB转串口
- CAN DB9接口 * 2
- TFT接口
- SmartCard接口
- I2C/USART/SPI接口
- **调试接口**
- 板载DAP调试器
- 标准JTAG/SWD/Trace
- MCUHC32F334KATI主频120MHz128KB FLASH36KB RAM
- 常用外设
- LED2 个User LED(LED0、LED1)。
- 按键4个K1、K2、WAKEUP(K3)、RESET(K0)。
- 常用接口CAN接口、LIN接口、RS485接口。
- 调试接口板载DAP调试器含USB转串口、标准JTAG/SWD。
开发板更多详细信息请参考小华半导体半导体[EV_F334_LQ64_Rev1.0](https://www.xhsc.com.cn)
开发板更多详细信息请参考小华半导体半导体[EV_F334_LQ64](https://www.xhsc.com.cn)
## 外设支持
本 BSP 目前对外设的支持情况如下:
| **板载外设** | **支持情况** | **备注** |
|:-------- |:--------:|:--------:|
| USB 转串口 | 支持 | 使用 UART2 |
| LED | 支持 | LED1~4 |
| **板载外设** | **支持情况** | **备注** |
| :------------ | :-----------: | :-----------------------------------: |
| USB 转串口 | 支持 | 使用 UART2 |
| **片上外设** | **支持情况** | **备注** |
|:------------- |:--------:|:------------------------------------------:|
| Crypto | 支持 | AES, CRC, HASH, RNG, UID |
| DAC | 支持 | |
| ADC | 支持 | ADC1: CH10, CH11, <br>ADC3: CH1 |
| CAN | 支持 | CAN1、CAN2 |
| GPIO | 支持 | PA0, PA1... PH2 ---> PIN: 0, 1...82 |
| I2C | 支持 | 软件模拟<br>硬件I2C1~2<br>I2C1支持EEPROMBL24C256 |
| PM | 支持 | |
| Lptimer | 支持 | |
| Hwtimer | 支持 | Hwtimer1~5 |
| Pulse_encoder | 支持 | |
| PWM | 支持 | |
| RTC | 支持 | 闹钟精度为1分钟 |
| WDT | 支持 | |
| I2C | 支持 | 软件、硬件 I2C |
| QSPI | 支持 | |
| SPI | 支持 | SPI1~3<br>SPI1支持W25Q |
| UART | 支持 | UART1~6<br>UART2为console使用 |
| **片上外设** | **支持情况** | **备注** |
| :------------ | :-----------: | :-----------------------------------: |
| ADC | 支持 | |
| Crypto | 支持 | CRC |
| DAC | 支持 | |
| FLASH | 支持 | |
| GPIO | 支持 | PA0PA1...PF3 ---> PIN01...68 |
| HwTimer | 支持 | |
| I2C | 支持 | 软件、硬件 I2C |
| InputCapture | 支持 | |
| MCAN | 支持 | |
| PM | 支持 | |
| PulseEncoder | 支持 | |
| PWM | 支持 | |
| RTC | 支持 | 闹钟精度为1分钟 |
| SPI | 支持 | |
| UART V1 & V2 | 支持 | |
| WDT | 支持 | |
## 使用说明
使用说明分为如下两个章节:
- 快速上手
本章节是为刚接触 RT-Thread 的新手准备的使用说明,遵循简单的步骤即可将 RT-Thread 操作系统运行在该开发板上,看到实验效果 。
- 进阶使用
本章节是为需要在 RT-Thread 操作系统上使用更多开发板资源的开发者准备的。通过使用 ENV 工具对 BSP 进行配置,可以开启更多板载资源,实现更多高级功能。
### 快速上手
本 BSP 为开发者提供 MDK5 和 IAR 工程,并且支持 GCC 开发环境。下面以 MDK5 开发环境为例,介绍如何将系统运行起来。
@@ -103,14 +87,14 @@ EV_F334_LQ64_Rev1.0 开发板常用 **板载资源** 如下:
#### 运行结果
下载程序成功之后系统会自动运行观察开发板上LED的运行效果绿色LED3会周期性闪烁。
下载程序成功之后系统会自动运行观察开发板上LED的运行效果绿色LED1会周期性闪烁。
USB虚拟COM端口默认连接串口2在终端工具里打开相应的串口复位设备后可以看到 RT-Thread 的输出信息:
```
\ | /
- RT - Thread Operating System
/ | \ 5.0.1 build Feb 4 2024 16:44:26
/ | \ 4.1.0 build Apr 24 2022 13:32:39
2006 - 2022 Copyright by RT-Thread team
msh >
```
@@ -127,12 +111,6 @@ msh >
4. 输入`scons --target=mdk5/iar` 命令重新生成工程。
## 注意事项
| 板载外设 | 模式 | 注意事项 |
| ---- | ---- | ------------------------------------------------------------------------------------------------------ |
| USB | host | 若配置为U盘主机模式出现部分U盘无法识别或者写入失败时可以尝试将RTT抽象层中rt_udisk_run()函数的rt_usbh_storage_reset()操作注释掉,测试是否可以获得更好的兼容性。 |
## 联系人信息
维护人:

View File

@@ -30,11 +30,6 @@ menu "Onboard Peripheral Drivers"
bool "Enable SPI FLASH (w25q64 spi1)"
select BSP_USING_SPI
select BSP_USING_SPI1
select BSP_USING_ON_CHIP_FLASH
select RT_USING_SFUD
select RT_USING_DFS
select RT_USING_FAL
select RT_USING_MTD_NOR
default n
endmenu
@@ -198,11 +193,11 @@ menu "On-chip Peripheral Drivers"
config BSP_I2C1_SCL_PIN
int "i2c1 scl pin number"
range 1 68
default 22
default 22 # PB6
config BSP_I2C1_SDA_PIN
int "I2C1 sda pin number"
range 1 68
default 23
default 23 # PB7
endif
endif
@@ -262,36 +257,6 @@ menu "On-chip Peripheral Drivers"
select BSP_SPI1_TX_USING_DMA
default n
endif
menuconfig BSP_USING_SPI2
bool "Enable SPI2 BUS"
default n
if BSP_USING_SPI2
config BSP_SPI2_TX_USING_DMA
bool "Enable SPI2 TX DMA"
select BSP_SPI_USING_DMA
default n
config BSP_SPI2_RX_USING_DMA
bool "Enable SPI2 RX DMA"
select BSP_SPI_USING_DMA
select BSP_SPI2_TX_USING_DMA
default n
endif
menuconfig BSP_USING_SPI3
bool "Enable SPI3 BUS"
default n
if BSP_USING_SPI3
config BSP_SPI3_TX_USING_DMA
bool "Enable SPI3 TX DMA"
select BSP_SPI_USING_DMA
default n
config BSP_SPI3_RX_USING_DMA
bool "Enable SPI3 RX DMA"
select BSP_SPI_USING_DMA
select BSP_SPI3_TX_USING_DMA
default n
endif
endif
menuconfig BSP_USING_ADC
@@ -333,6 +298,9 @@ menu "On-chip Peripheral Drivers"
config BSP_USING_DAC1
bool "using dac1"
default n
config BSP_USING_DAC2
bool "using dac2"
default n
endif
menuconfig BSP_USING_MCAN
@@ -361,7 +329,7 @@ menu "On-chip Peripheral Drivers"
config BSP_USING_SWDT
bool "SWDT(3.72hour(max))"
config BSP_USING_WDT
bool "WDT(10.7s(max))"
bool "WDT(8.9s(max))"
endchoice
config BSP_WDT_CONTINUE_COUNT
@@ -383,9 +351,6 @@ menu "On-chip Peripheral Drivers"
config BSP_RTC_USING_LRC
bool "RTC Using LRC"
config BSP_RTC_USING_XTAL_DIV
bool "RTC Using XTAL Division"
endchoice
endif
@@ -479,16 +444,11 @@ menu "On-chip Peripheral Drivers"
config BSP_USING_PWM_TMRA_1_CH2
bool "Enable timerA-1 channel2"
default n
endif
menuconfig BSP_USING_PWM_TMRA_2
bool "Enable timerA-2 output PWM"
default n
if BSP_USING_PWM_TMRA_2
config BSP_USING_PWM_TMRA_2_CH1
bool "Enable timerA-2 channel1"
config BSP_USING_PWM_TMRA_1_CH3
bool "Enable timerA-1 channel3"
default n
config BSP_USING_PWM_TMRA_2_CH2
bool "Enable timerA-2 channel2"
config BSP_USING_PWM_TMRA_1_CH4
bool "Enable timerA-1 channel4"
default n
endif
endif
@@ -518,6 +478,12 @@ menu "On-chip Peripheral Drivers"
config BSP_USING_PWM_TMR4_1_OWL
bool "Enable TMR4_1_OWL channel5"
default n
config BSP_USING_PWM_TMR4_1_OXH
bool "Enable TMR4_1_OXH channel6"
default n
config BSP_USING_PWM_TMR4_1_OXL
bool "Enable TMR4_1_OXL channel7"
default n
endif
endif
menuconfig BSP_USING_PWM_TMR6
@@ -600,14 +566,6 @@ menu "On-chip Peripheral Drivers"
bool "unit 3"
config BSP_USING_INPUT_CAPTURE_TMR6_4
bool "unit 4"
config BSP_USING_INPUT_CAPTURE_TMR6_5
bool "unit 5"
config BSP_USING_INPUT_CAPTURE_TMR6_6
bool "unit 6"
config BSP_USING_INPUT_CAPTURE_TMR6_7
bool "unit 7"
config BSP_USING_INPUT_CAPTURE_TMR6_8
bool "unit 8"
endif
endif
endmenu

View File

@@ -80,7 +80,7 @@ void SystemClock_Config(void)
#if defined(BSP_RTC_USING_XTAL32) || defined(RT_USING_PM)
/* Xtal32 config */
GPIO_AnalogCmd(XTAL32_PORT, XTAL32_IN_PIN | XTAL32_OUT_PIN, ENABLE);
GPIO_AnalogCmd(XTAL32_PORT, XTAL32_PIN, ENABLE);
(void)CLK_Xtal32StructInit(&stcXtal32Init);
stcXtal32Init.u8State = CLK_XTAL32_ON;
stcXtal32Init.u8Drv = CLK_XTAL32_DRV_HIGH;

View File

@@ -114,10 +114,15 @@ rt_err_t rt_hw_board_dac_init(CM_DAC_TypeDef *DACx)
switch ((rt_uint32_t)DACx)
{
#if defined(BSP_USING_DAC1)
case (rt_uint32_t)CM_DAC:
case (rt_uint32_t)CM_DAC1:
(void)GPIO_Init(DAC1_CH1_PORT, DAC1_CH1_PIN, &stcGpioInit);
(void)GPIO_Init(DAC1_CH2_PORT, DAC1_CH2_PIN, &stcGpioInit);
break;
#endif
#if defined(BSP_USING_DAC2)
case (rt_uint32_t)CM_DAC2:
(void)GPIO_Init(DAC2_CH1_PORT, DAC2_CH1_PIN, &stcGpioInit);
break;
#endif
default:
result = -RT_ERROR;
@@ -131,15 +136,22 @@ rt_err_t rt_hw_board_dac_init(CM_DAC_TypeDef *DACx)
#if defined(RT_USING_CAN)
void CanPhyEnable(void)
{
stc_gpio_init_t stcGpioInit;
#if defined(BSP_USING_MCAN1)
TCA9539_WritePin(CAN1_STB_PORT, CAN1_STB_PIN, TCA9539_PIN_RESET);
TCA9539_ConfigPin(CAN1_STB_PORT, CAN1_STB_PIN, TCA9539_DIR_OUT);
GPIO_StructInit(&stcGpioInit);
stcGpioInit.u16PinState = PIN_STAT_RST;
stcGpioInit.u16PinDir = PIN_DIR_OUT;
GPIO_Init(MCAN1_PHY_STBY_PORT, MCAN1_PHY_STBY_PIN, &stcGpioInit);
#endif
#if defined(BSP_USING_MCAN2)
TCA9539_WritePin(CAN2_STB_PORT, CAN2_STB_PIN, TCA9539_PIN_RESET);
TCA9539_ConfigPin(CAN2_STB_PORT, CAN2_STB_PIN, TCA9539_DIR_OUT);
GPIO_StructInit(&stcGpioInit);
stcGpioInit.u16PinState = PIN_STAT_RST;
stcGpioInit.u16PinDir = PIN_DIR_OUT;
GPIO_Init(MCAN2_PHY_STBY_PORT, MCAN2_PHY_STBY_PIN, &stcGpioInit);
#endif
}
rt_err_t rt_hw_board_mcan_init(CM_MCAN_TypeDef *MCANx)
{
rt_err_t result = RT_EOK;
@@ -178,13 +190,7 @@ rt_err_t rt_hw_spi_board_init(CM_SPI_TypeDef *CM_SPIx)
switch ((rt_uint32_t)CM_SPIx)
{
#if defined(BSP_USING_SPI1)
case (rt_uint32_t)CM_SPI1:
GPIO_StructInit(&stcGpioInit);
stcGpioInit.u16PinState = PIN_STAT_SET;
stcGpioInit.u16PinDir = PIN_DIR_OUT;
GPIO_Init(SPI1_WP_PORT, SPI1_WP_PIN, &stcGpioInit);
GPIO_Init(SPI1_HOLD_PORT, SPI1_HOLD_PIN, &stcGpioInit);
case (rt_uint32_t)CM_SPI:
(void)GPIO_StructInit(&stcGpioInit);
stcGpioInit.u16PinDrv = PIN_HIGH_DRV;
stcGpioInit.u16PinInputType = PIN_IN_TYPE_CMOS;
@@ -227,22 +233,6 @@ rt_err_t rt_hw_board_pwm_tmra_init(CM_TMRA_TypeDef *TMRAx)
GPIO_SetFunc(PWM_TMRA_1_CH4_PORT, PWM_TMRA_1_CH4_PIN, PWM_TMRA_1_CH4_PIN_FUNC);
#endif
break;
#endif
#if defined(BSP_USING_PWM_TMRA_2)
case (rt_uint32_t)CM_TMRA_2:
#ifdef BSP_USING_PWM_TMRA_2_CH1
GPIO_SetFunc(PWM_TMRA_2_CH1_PORT, PWM_TMRA_2_CH1_PIN, PWM_TMRA_2_CH1_PIN_FUNC);
#endif
#ifdef BSP_USING_PWM_TMRA_2_CH2
GPIO_SetFunc(PWM_TMRA_2_CH2_PORT, PWM_TMRA_2_CH2_PIN, PWM_TMRA_2_CH2_PIN_FUNC);
#endif
#ifdef BSP_USING_PWM_TMRA_2_CH3
GPIO_SetFunc(PWM_TMRA_2_CH3_PORT, PWM_TMRA_2_CH3_PIN, PWM_TMRA_2_CH3_PIN_FUNC);
#endif
#ifdef BSP_USING_PWM_TMRA_2_CH4
GPIO_SetFunc(PWM_TMRA_2_CH4_PORT, PWM_TMRA_2_CH4_PIN, PWM_TMRA_2_CH4_PIN_FUNC);
#endif
break;
#endif
default:
result = -RT_ERROR;
@@ -260,7 +250,7 @@ rt_err_t rt_hw_board_pwm_tmr4_init(CM_TMR4_TypeDef *TMR4x)
switch ((rt_uint32_t)TMR4x)
{
#if defined(BSP_USING_PWM_TMR4_1)
case (rt_uint32_t)CM_TMR4_1:
case (rt_uint32_t)CM_TMR4:
#ifdef BSP_USING_PWM_TMR4_1_OUH
GPIO_SetFunc(PWM_TMR4_1_OUH_PORT, PWM_TMR4_1_OUH_PIN, PWM_TMR4_1_OUH_PIN_FUNC);
#endif
@@ -278,6 +268,12 @@ rt_err_t rt_hw_board_pwm_tmr4_init(CM_TMR4_TypeDef *TMR4x)
#endif
#ifdef BSP_USING_PWM_TMR4_1_OWL
GPIO_SetFunc(PWM_TMR4_1_OWL_PORT, PWM_TMR4_1_OWL_PIN, PWM_TMR4_1_OWL_PIN_FUNC);
#endif
#ifdef BSP_USING_PWM_TMR4_1_OXH
GPIO_SetFunc(PWM_TMR4_1_OXH_PORT, PWM_TMR4_1_OXH_PIN, PWM_TMR4_1_OXH_PIN_FUNC);
#endif
#ifdef BSP_USING_PWM_TMR4_1_OXL
GPIO_SetFunc(PWM_TMR4_1_OXL_PORT, PWM_TMR4_1_OXL_PIN, PWM_TMR4_1_OXL_PIN_FUNC);
#endif
break;
#endif

View File

@@ -66,8 +66,8 @@
#endif
#if defined(BSP_USING_ADC3)
#define ADC3_CH_PORT (GPIO_PORT_E) /* Default ADC3_IN1 */
#define ADC3_CH_PIN (GPIO_PIN_03)
#define ADC3_CH_PORT (GPIO_PORT_B) /* Default ADC3_IN1 */
#define ADC3_CH_PIN (GPIO_PIN_13)
#endif
/*********** DAC configure *********/
@@ -77,58 +77,61 @@
#define DAC1_CH2_PORT (GPIO_PORT_A)
#define DAC1_CH2_PIN (GPIO_PIN_05)
#endif
#if defined(BSP_USING_DAC2)
#define DAC2_CH1_PORT (GPIO_PORT_A)
#define DAC2_CH1_PIN (GPIO_PIN_06)
#endif
/*********** CAN configure *********/
#if defined(BSP_USING_MCAN1)
#define MCAN1_TX_PORT (GPIO_PORT_C)
#define MCAN1_TX_PIN (GPIO_PIN_12)
#define MCAN1_TX_PIN_FUNC (GPIO_FUNC_56)
#define MCAN1_TX_PORT (GPIO_PORT_A)
#define MCAN1_TX_PIN (GPIO_PIN_02)
#define MCAN1_TX_PIN_FUNC (GPIO_FUNC_54)
#define MCAN1_RX_PORT (GPIO_PORT_D)
#define MCAN1_RX_PIN (GPIO_PIN_00)
#define MCAN1_RX_PIN_FUNC (GPIO_FUNC_57)
#define MCAN1_RX_PORT (GPIO_PORT_C)
#define MCAN1_RX_PIN (GPIO_PIN_05)
#define MCAN1_RX_PIN_FUNC (GPIO_FUNC_55)
#define MCAN1_PHY_STBY_PORT (GPIO_PORT_B)
#define MCAN1_PHY_STBY_PIN (GPIO_PIN_01)
#endif
#if defined(BSP_USING_MCAN2)
#define MCAN2_TX_PORT (GPIO_PORT_H)
#define MCAN2_TX_PIN (GPIO_PIN_02)
#define MCAN2_TX_PORT (GPIO_PORT_B)
#define MCAN2_TX_PIN (GPIO_PIN_11)
#define MCAN2_TX_PIN_FUNC (GPIO_FUNC_56)
#define MCAN2_RX_PORT (GPIO_PORT_E)
#define MCAN2_RX_PIN (GPIO_PIN_04)
#define MCAN2_RX_PORT (GPIO_PORT_B)
#define MCAN2_RX_PIN (GPIO_PIN_10)
#define MCAN2_RX_PIN_FUNC (GPIO_FUNC_57)
#define MCAN2_PHY_STBY_PORT (GPIO_PORT_B)
#define MCAN2_PHY_STBY_PIN (GPIO_PIN_02)
#endif
/************************* SPI port ***********************/
#if defined(BSP_USING_SPI1)
#define SPI1_CS_PORT (GPIO_PORT_C)
#define SPI1_CS_PIN (GPIO_PIN_07)
#define SPI1_CS_PIN (GPIO_PIN_01)
#define SPI1_SCK_PORT (GPIO_PORT_B)
#define SPI1_SCK_PIN (GPIO_PIN_14)
#define SPI1_SCK_FUNC (GPIO_FUNC_47)
#define SPI1_SCK_PIN (GPIO_PIN_05)
#define SPI1_SCK_FUNC (GPIO_FUNC_49)
#define SPI1_MOSI_PORT (GPIO_PORT_B)
#define SPI1_MOSI_PIN (GPIO_PIN_13)
#define SPI1_MOSI_FUNC (GPIO_FUNC_44)
#define SPI1_MOSI_PORT (GPIO_PORT_A)
#define SPI1_MOSI_PIN (GPIO_PIN_00)
#define SPI1_MOSI_FUNC (GPIO_FUNC_50)
#define SPI1_MISO_PORT (GPIO_PORT_D)
#define SPI1_MISO_PIN (GPIO_PIN_09)
#define SPI1_MISO_FUNC (GPIO_FUNC_45)
#define SPI1_WP_PORT (GPIO_PORT_D)
#define SPI1_WP_PIN (GPIO_PIN_10)
#define SPI1_HOLD_PORT (GPIO_PORT_D)
#define SPI1_HOLD_PIN (GPIO_PIN_11)
#define SPI1_MISO_PORT (GPIO_PORT_A)
#define SPI1_MISO_PIN (GPIO_PIN_01)
#define SPI1_MISO_FUNC (GPIO_FUNC_51)
#endif
/************************ RTC/PM *****************************/
#if defined(BSP_USING_RTC) || defined(RT_USING_PM)
#if defined(BSP_RTC_USING_XTAL32) || defined(RT_USING_PM)
#define XTAL32_PORT (GPIO_PORT_C)
#define XTAL32_IN_PIN (GPIO_PIN_14)
#define XTAL32_OUT_PIN (GPIO_PIN_15)
#define XTAL32_PIN (GPIO_PIN_14 | GPIO_PIN_15)
#endif
#endif
@@ -137,46 +140,23 @@
#if defined(BSP_USING_PWM_TMRA_1)
#if defined(BSP_USING_PWM_TMRA_1_CH1)
#define PWM_TMRA_1_CH1_PORT (GPIO_PORT_A)
#define PWM_TMRA_1_CH1_PIN (GPIO_PIN_08)
#define PWM_TMRA_1_CH1_PIN_FUNC (GPIO_FUNC_4)
#define PWM_TMRA_1_CH1_PIN (GPIO_PIN_00)
#define PWM_TMRA_1_CH1_PIN_FUNC (GPIO_FUNC_15)
#endif
#if defined(BSP_USING_PWM_TMRA_1_CH2)
#define PWM_TMRA_1_CH2_PORT (GPIO_PORT_A)
#define PWM_TMRA_1_CH2_PIN (GPIO_PIN_09)
#define PWM_TMRA_1_CH2_PIN_FUNC (GPIO_FUNC_4)
#define PWM_TMRA_1_CH2_PIN (GPIO_PIN_01)
#define PWM_TMRA_1_CH2_PIN_FUNC (GPIO_FUNC_15)
#endif
#if defined(BSP_USING_PWM_TMRA_1_CH3)
#define PWM_TMRA_1_CH3_PORT (GPIO_PORT_A)
#define PWM_TMRA_1_CH3_PIN (GPIO_PIN_10)
#define PWM_TMRA_1_CH3_PIN_FUNC (GPIO_FUNC_4)
#define PWM_TMRA_1_CH3_PIN (GPIO_PIN_02)
#define PWM_TMRA_1_CH3_PIN_FUNC (GPIO_FUNC_15)
#endif
#if defined(BSP_USING_PWM_TMRA_1_CH4)
#define PWM_TMRA_1_CH4_PORT (GPIO_PORT_A)
#define PWM_TMRA_1_CH4_PIN (GPIO_PIN_11)
#define PWM_TMRA_1_CH4_PIN_FUNC (GPIO_FUNC_4)
#endif
#endif
#if defined(BSP_USING_PWM_TMRA_2)
#if defined(BSP_USING_PWM_TMRA_2_CH1)
#define PWM_TMRA_2_CH1_PORT (GPIO_PORT_A)
#define PWM_TMRA_2_CH1_PIN (GPIO_PIN_00)
#define PWM_TMRA_2_CH1_PIN_FUNC (GPIO_FUNC_4)
#endif
#if defined(BSP_USING_PWM_TMRA_2_CH2)
#define PWM_TMRA_2_CH2_PORT (GPIO_PORT_A)
#define PWM_TMRA_2_CH2_PIN (GPIO_PIN_01)
#define PWM_TMRA_2_CH2_PIN_FUNC (GPIO_FUNC_4)
#endif
#if defined(BSP_USING_PWM_TMRA_2_CH3)
#define PWM_TMRA_2_CH3_PORT (GPIO_PORT_A)
#define PWM_TMRA_2_CH3_PIN (GPIO_PIN_02)
#define PWM_TMRA_2_CH3_PIN_FUNC (GPIO_FUNC_4)
#endif
#if defined(BSP_USING_PWM_TMRA_2_CH4)
#define PWM_TMRA_2_CH4_PORT (GPIO_PORT_A)
#define PWM_TMRA_2_CH4_PIN (GPIO_PIN_03)
#define PWM_TMRA_2_CH4_PIN_FUNC (GPIO_FUNC_4)
#define PWM_TMRA_1_CH4_PIN (GPIO_PIN_03)
#define PWM_TMRA_1_CH4_PIN_FUNC (GPIO_FUNC_15)
#endif
#endif
@@ -184,65 +164,75 @@
#if defined(BSP_USING_PWM_TMR4_1)
#if defined(BSP_USING_PWM_TMR4_1_OUH)
#define PWM_TMR4_1_OUH_PORT (GPIO_PORT_A)
#define PWM_TMR4_1_OUH_PIN (GPIO_PIN_08)
#define PWM_TMR4_1_OUH_PIN_FUNC (GPIO_FUNC_2)
#define PWM_TMR4_1_OUH_PIN (GPIO_PIN_02)
#define PWM_TMR4_1_OUH_PIN_FUNC (GPIO_FUNC_20)
#endif
#if defined(BSP_USING_PWM_TMR4_1_OUL)
#define PWM_TMR4_1_OUL_PORT (GPIO_PORT_A)
#define PWM_TMR4_1_OUL_PIN (GPIO_PIN_07)
#define PWM_TMR4_1_OUL_PIN_FUNC (GPIO_FUNC_2)
#define PWM_TMR4_1_OUL_PIN (GPIO_PIN_01)
#define PWM_TMR4_1_OUL_PIN_FUNC (GPIO_FUNC_20)
#endif
#if defined(BSP_USING_PWM_TMR4_1_OVH)
#define PWM_TMR4_1_OVH_PORT (GPIO_PORT_A)
#define PWM_TMR4_1_OVH_PIN (GPIO_PIN_09)
#define PWM_TMR4_1_OVH_PIN_FUNC (GPIO_FUNC_2)
#define PWM_TMR4_1_OVH_PIN (GPIO_PIN_06)
#define PWM_TMR4_1_OVH_PIN_FUNC (GPIO_FUNC_20)
#endif
#if defined(BSP_USING_PWM_TMR4_1_OVL)
#define PWM_TMR4_1_OVL_PORT (GPIO_PORT_B)
#define PWM_TMR4_1_OVL_PIN (GPIO_PIN_00)
#define PWM_TMR4_1_OVL_PIN_FUNC (GPIO_FUNC_2)
#define PWM_TMR4_1_OVL_PORT (GPIO_PORT_A)
#define PWM_TMR4_1_OVL_PIN (GPIO_PIN_04)
#define PWM_TMR4_1_OVL_PIN_FUNC (GPIO_FUNC_20)
#endif
#if defined(BSP_USING_PWM_TMR4_1_OWH)
#define PWM_TMR4_1_OWH_PORT (GPIO_PORT_A)
#define PWM_TMR4_1_OWH_PIN (GPIO_PIN_10)
#define PWM_TMR4_1_OWH_PIN_FUNC (GPIO_FUNC_2)
#define PWM_TMR4_1_OWH_PIN (GPIO_PIN_07)
#define PWM_TMR4_1_OWH_PIN_FUNC (GPIO_FUNC_20)
#endif
#if defined(BSP_USING_PWM_TMR4_1_OWL)
#define PWM_TMR4_1_OWL_PORT (GPIO_PORT_B)
#define PWM_TMR4_1_OWL_PIN (GPIO_PIN_01)
#define PWM_TMR4_1_OWL_PIN_FUNC (GPIO_FUNC_2)
#define PWM_TMR4_1_OWL_PIN (GPIO_PIN_02)
#define PWM_TMR4_1_OWL_PIN_FUNC (GPIO_FUNC_20)
#endif
#if defined(BSP_USING_PWM_TMR4_1_OXH)
#define PWM_TMR4_1_OXH_PORT (GPIO_PORT_A)
#define PWM_TMR4_1_OXH_PIN (GPIO_PIN_01)
#define PWM_TMR4_1_OXH_PIN_FUNC (GPIO_FUNC_23)
#endif
#if defined(BSP_USING_PWM_TMR4_1_OXL)
#define PWM_TMR4_1_OXL_PORT (GPIO_PORT_A)
#define PWM_TMR4_1_OXL_PIN (GPIO_PIN_00)
#define PWM_TMR4_1_OXL_PIN_FUNC (GPIO_FUNC_23)
#endif
#endif
/*********** PWM_TMR6 configure *********/
#if defined(BSP_USING_PWM_TMR6_1)
#if defined(BSP_USING_PWM_TMR6_1_A)
#define PWM_TMR6_1_A_PORT (GPIO_PORT_A)
#define PWM_TMR6_1_A_PIN (GPIO_PIN_08)
#define PWM_TMR6_1_A_PIN_FUNC (GPIO_FUNC_3)
#define PWM_TMR6_1_A_PORT (GPIO_PORT_C)
#define PWM_TMR6_1_A_PIN (GPIO_PIN_00)
#define PWM_TMR6_1_A_PIN_FUNC (GPIO_FUNC_12)
#endif
#if defined(BSP_USING_PWM_TMR6_1_B)
#define PWM_TMR6_1_B_PORT (GPIO_PORT_A)
#define PWM_TMR6_1_B_PIN (GPIO_PIN_07)
#define PWM_TMR6_1_B_PIN_FUNC (GPIO_FUNC_3)
#define PWM_TMR6_1_B_PIN (GPIO_PIN_00)
#define PWM_TMR6_1_B_PIN_FUNC (GPIO_FUNC_12)
#endif
#endif
#endif
#if defined(BSP_USING_INPUT_CAPTURE)
#define INPUT_CAPTURE_TMR6_FUNC (GPIO_FUNC_3)
#define INPUT_CAPTURE_TMR6_FUNC (GPIO_FUNC_14)
#if defined(BSP_USING_INPUT_CAPTURE_TMR6_1)
#define INPUT_CAPTURE_TMR6_1_PORT (GPIO_PORT_B)
#define INPUT_CAPTURE_TMR6_1_PIN (GPIO_PIN_09)
#define INPUT_CAPTURE_TMR6_1_PORT (GPIO_PORT_C)
#define INPUT_CAPTURE_TMR6_1_PIN (GPIO_PIN_06)
#endif
#if defined(BSP_USING_INPUT_CAPTURE_TMR6_2)
#define INPUT_CAPTURE_TMR6_2_PORT (GPIO_PORT_E)
#define INPUT_CAPTURE_TMR6_2_PORT (GPIO_PORT_C)
#define INPUT_CAPTURE_TMR6_2_PIN (GPIO_PIN_07)
#endif
#if defined(BSP_USING_INPUT_CAPTURE_TMR6_3)
#define INPUT_CAPTURE_TMR6_3_PORT (GPIO_PORT_A)
#define INPUT_CAPTURE_TMR6_3_PIN (GPIO_PIN_00)
#define INPUT_CAPTURE_TMR6_3_PORT (GPIO_PORT_B)
#define INPUT_CAPTURE_TMR6_3_PIN (GPIO_PIN_02)
#endif
#endif

View File

@@ -34,7 +34,7 @@ extern "C" {
.internal_trig0_sel = EVT_SRC_TMR0_1_CMP_B, \
.internal_trig1_comtrg0_enable = RT_FALSE, \
.internal_trig1_comtrg1_enable = RT_FALSE, \
.internal_trig1_sel = EVT_SRC_MAX, \
.internal_trig1_sel = EVT_SRC_TMR0_1_CMP_A, \
.continue_conv_mode_enable = RT_FALSE, \
.data_reg_auto_clear = RT_TRUE, \
}
@@ -77,7 +77,7 @@ extern "C" {
.internal_trig0_sel = EVT_SRC_TMR0_1_CMP_B, \
.internal_trig1_comtrg0_enable = RT_FALSE, \
.internal_trig1_comtrg1_enable = RT_FALSE, \
.internal_trig1_sel = EVT_SRC_MAX, \
.internal_trig1_sel = EVT_SRC_TMR0_1_CMP_A, \
.continue_conv_mode_enable = RT_FALSE, \
.data_reg_auto_clear = RT_TRUE, \
}
@@ -120,7 +120,7 @@ extern "C" {
.internal_trig0_sel = EVT_SRC_TMR0_1_CMP_B, \
.internal_trig1_comtrg0_enable = RT_FALSE, \
.internal_trig1_comtrg1_enable = RT_FALSE, \
.internal_trig1_sel = EVT_SRC_MAX, \
.internal_trig1_sel = EVT_SRC_TMR0_1_CMP_A, \
.continue_conv_mode_enable = RT_FALSE, \
.data_reg_auto_clear = RT_TRUE, \
}

View File

@@ -27,14 +27,26 @@ extern "C" {
.dac_adp_sel = DAC_ADP_SEL_ALL, \
.ch1_output_enable = RT_TRUE, \
.ch2_output_enable = RT_TRUE, \
.ch1_data_src = DAC_DATA_SRC_DATAREG, \
.ch2_data_src = DAC_DATA_SRC_DATAREG, \
.ch1_amp_enable = RT_TRUE, \
.ch2_amp_enable = RT_TRUE, \
}
#endif /* DAC1_INIT_PARAMS */
#endif /* BSP_USING_DAC1 */
#ifdef BSP_USING_DAC2
#ifndef DAC2_INIT_PARAMS
#define DAC2_INIT_PARAMS \
{ \
.name = "dac2", \
.vref = 3300, \
.dac_adp_enable = RT_FALSE, \
.dac_adp_sel = DAC_ADP_SEL_ALL, \
.ch1_output_enable = RT_TRUE, \
.ch1_amp_enable = RT_TRUE, \
}
#endif /* DAC2_INIT_PARAMS */
#endif /* BSP_USING_DAC2 */
#ifdef __cplusplus
}
#endif

View File

@@ -120,20 +120,10 @@ extern "C" {
#endif /* BSP_USING_UART4 */
#if defined(BSP_USING_SPI1)
#define BSP_SPI1_ERR_IRQ_NUM SPI1_IRQn
#define BSP_SPI1_ERR_IRQ_NUM SPI_IRQn
#define BSP_SPI1_ERR_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif
#if defined(BSP_USING_SPI2)
#define BSP_SPI2_ERR_IRQ_NUM SPI2_IRQn
#define BSP_SPI2_ERR_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif
#if defined(BSP_USING_SPI3)
#define BSP_SPI3_ERR_IRQ_NUM SPI3_IRQn
#define BSP_SPI3_ERR_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif
#if defined (BSP_USING_QSPI)
#define BSP_QSPI_ERR_IRQ_NUM QSPI_IRQn
#define BSP_QSPI_ERR_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
@@ -167,17 +157,11 @@ extern "C" {
#if defined(BSP_USING_MCAN1)
#define BSP_MCAN1_INT0_IRQ_NUM MCAN1_INT0_IRQn
#define BSP_MCAN1_INT0_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#define BSP_MCAN1_INT1_IRQ_NUM MCAN1_INT1_IRQn
#define BSP_MCAN1_INT1_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif/* BSP_USING_MCAN1 */
#if defined(BSP_USING_MCAN2)
#define BSP_MCAN2_INT0_IRQ_NUM MCAN2_INT0_IRQn
#define BSP_MCAN2_INT0_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#define BSP_MCAN2_INT1_IRQ_NUM MCAN2_INT1_IRQn
#define BSP_MCAN2_INT1_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif/* BSP_USING_MCAN2 */
#if defined(RT_USING_ALARM)
@@ -229,6 +213,28 @@ extern "C" {
#define BSP_PULSE_ENCODER_TMR6_2_UDF_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif/* BSP_USING_PULSE_ENCODER_TMR6_2 */
#if defined(BSP_USING_INPUT_CAPTURE)
#define BSP_INPUT_CAPTURE_TMR6_1_OVF_IRQ_NUM (INT008_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_1_OVF_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_1_CAP_IRQ_NUM (INT009_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_1_CAP_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_2_OVF_IRQ_NUM (INT010_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_2_OVF_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_2_CAP_IRQ_NUM (INT011_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_2_CAP_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_3_OVF_IRQ_NUM (INT012_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_3_OVF_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_3_CAP_IRQ_NUM (INT013_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_3_CAP_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_4_OVF_IRQ_NUM (INT014_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_4_OVF_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_4_CAP_IRQ_NUM (INT015_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_4_CAP_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#endif/* BSP_USING_INPUT_CAPTURE */
#ifdef __cplusplus
}
#endif

View File

@@ -54,8 +54,6 @@ extern void rt_hw_board_pm_sysclk_cfg(uint8_t run_mode);
{ \
{ \
.u16Clock = PWC_STOP_CLK_KEEP, \
.u8StopDrv = PWC_STOP_DRV_HIGH, \
.u16ExBusHold = PWC_STOP_EXBUS_HIZ, \
.u16FlashWait = PWC_STOP_FLASH_WAIT_ON, \
}, \
.pwc_stop_type = PWC_STOP_WFE_INT, \
@@ -71,7 +69,6 @@ extern void rt_hw_board_pm_sysclk_cfg(uint8_t run_mode);
{ \
.u8Mode = PWC_PD_MD1, \
.u8IOState = PWC_PD_IO_KEEP1, \
.u8VcapCtrl = PWC_PD_VCAP_0P047UF, \
}, \
}
#endif /*PM_SLEEP_STANDBY_CFG*/
@@ -85,7 +82,6 @@ extern void rt_hw_board_pm_sysclk_cfg(uint8_t run_mode);
{ \
.u8Mode = PWC_PD_MD3, \
.u8IOState = PWC_PD_IO_KEEP1, \
.u8VcapCtrl = PWC_PD_VCAP_0P047UF, \
}, \
}
#endif /*PM_SLEEP_SHUTDOWN_CFG*/

View File

@@ -182,7 +182,7 @@ extern "C" {
#define PWM_TMR4_1_CONFIG \
{ \
.name = "pwm_t41", \
.instance = CM_TMR4_1, \
.instance = CM_TMR4, \
.channel = 0, \
.stcTmr4Init = \
{ \
@@ -209,70 +209,6 @@ extern "C" {
#endif /* PWM_TMR4_1_CONFIG */
#endif /* BSP_USING_PWM_TMR4_1 */
#ifdef BSP_USING_PWM_TMR4_2
#ifndef PWM_TMR4_2_CONFIG
#define PWM_TMR4_2_CONFIG \
{ \
.name = "pwm_t42", \
.instance = CM_TMR4_2, \
.channel = 0, \
.stcTmr4Init = \
{ \
.u16ClockDiv = TMR4_CLK_DIV1, \
.u16PeriodValue = 0xFFFFU, \
.u16CountMode = TMR4_MD_SAWTOOTH, \
.u16ClockSrc = TMR4_CLK_SRC_INTERNCLK,\
}, \
.stcTmr4OcInit = \
{ \
.u16CompareValue = 0x0000, \
.u16OcInvalidPolarity = TMR4_OC_INVD_LOW, \
.u16CompareModeBufCond = TMR4_OC_BUF_COND_IMMED,\
.u16CompareValueBufCond = TMR4_OC_BUF_COND_PEAK, \
.u16BufLinkTransObject = 0U, \
}, \
.stcTmr4PwmInit = \
{ \
.u16Mode = TMR4_PWM_MD_THROUGH, \
.u16ClockDiv = TMR4_PWM_CLK_DIV1, \
.u16Polarity = TMR4_PWM_OXH_HOLD_OXL_HOLD,\
}, \
}
#endif /* PWM_TMR4_2_CONFIG */
#endif /* BSP_USING_PWM_TMR4_2 */
#ifdef BSP_USING_PWM_TMR4_3
#ifndef PWM_TMR4_3_CONFIG
#define PWM_TMR4_3_CONFIG \
{ \
.name = "pwm_t43", \
.instance = CM_TMR4_3, \
.channel = 0, \
.stcTmr4Init = \
{ \
.u16ClockDiv = TMR4_CLK_DIV1, \
.u16PeriodValue = 0xFFFFU, \
.u16CountMode = TMR4_MD_SAWTOOTH, \
.u16ClockSrc = TMR4_CLK_SRC_INTERNCLK,\
}, \
.stcTmr4OcInit = \
{ \
.u16CompareValue = 0x0000, \
.u16OcInvalidPolarity = TMR4_OC_INVD_LOW, \
.u16CompareModeBufCond = TMR4_OC_BUF_COND_IMMED,\
.u16CompareValueBufCond = TMR4_OC_BUF_COND_PEAK, \
.u16BufLinkTransObject = 0U, \
}, \
.stcTmr4PwmInit = \
{ \
.u16Mode = TMR4_PWM_MD_THROUGH, \
.u16ClockDiv = TMR4_PWM_CLK_DIV1, \
.u16Polarity = TMR4_PWM_OXH_HOLD_OXL_HOLD,\
}, \
}
#endif /* PWM_TMR4_3_CONFIG */
#endif /* BSP_USING_PWM_TMR4_3 */
#endif /* BSP_USING_PWM_TMR4 */
#ifdef BSP_USING_PWM_TMR6
@@ -328,7 +264,7 @@ extern "C" {
#ifndef PWM_TMR6_2_CONFIG
#define PWM_TMR6_2_CONFIG \
{ \
.name = "pwm_t61", \
.name = "pwm_t62", \
.instance = CM_TMR6_2, \
.channel = 0, \
.stcTmr6Init = \
@@ -375,7 +311,7 @@ extern "C" {
#ifndef PWM_TMR6_3_CONFIG
#define PWM_TMR6_3_CONFIG \
{ \
.name = "pwm_t61", \
.name = "pwm_t63", \
.instance = CM_TMR6_3, \
.channel = 0, \
.stcTmr6Init = \
@@ -422,7 +358,7 @@ extern "C" {
#ifndef PWM_TMR6_4_CONFIG
#define PWM_TMR6_4_CONFIG \
{ \
.name = "pwm_t61", \
.name = "pwm_t64", \
.instance = CM_TMR6_4, \
.channel = 0, \
.stcTmr6Init = \
@@ -465,194 +401,6 @@ extern "C" {
}
#endif /* PWM_TMR6_4_CONFIG */
#endif /* BSP_USING_PWM_TMR6_4 */
#ifdef BSP_USING_PWM_TMR6_5
#ifndef PWM_TMR6_5_CONFIG
#define PWM_TMR6_5_CONFIG \
{ \
.name = "pwm_t61", \
.instance = CM_TMR6_5, \
.channel = 0, \
.stcTmr6Init = \
{ \
.u8CountSrc = TMR6_CNT_SRC_SW, \
.sw_count = \
{ \
.u32ClockDiv = TMR6_CLK_DIV1, \
.u32CountMode = TMR6_MD_SAWTOOTH, \
.u32CountDir = TMR6_CNT_DOWN, \
}, \
.u32PeriodValue = 0xFFFF, \
.u32CountReload = TMR6_CNT_RELOAD_ON, \
}, \
.stcPwmInit = \
{ \
{ \
.u32CompareValue = 0x0000, \
.u32StartPolarity = TMR6_PWM_LOW, \
.u32StopPolarity = TMR6_PWM_LOW, \
.u32CountUpMatchAPolarity = TMR6_PWM_HIGH, \
.u32CountDownMatchAPolarity = TMR6_PWM_HIGH, \
.u32CountUpMatchBPolarity = TMR6_PWM_HOLD, \
.u32CountDownMatchBPolarity = TMR6_PWM_HOLD, \
.u32UdfPolarity = TMR6_PWM_LOW, \
.u32OvfPolarity = TMR6_PWM_LOW, \
}, \
{ \
.u32CompareValue = 0x0000, \
.u32StartPolarity = TMR6_PWM_LOW, \
.u32StopPolarity = TMR6_PWM_LOW, \
.u32CountUpMatchAPolarity = TMR6_PWM_HOLD, \
.u32CountDownMatchAPolarity = TMR6_PWM_HOLD, \
.u32CountUpMatchBPolarity = TMR6_PWM_HIGH, \
.u32CountDownMatchBPolarity = TMR6_PWM_HIGH, \
.u32UdfPolarity = TMR6_PWM_LOW, \
.u32OvfPolarity = TMR6_PWM_LOW, \
} \
}, \
}
#endif /* PWM_TMR6_5_CONFIG */
#endif /* BSP_USING_PWM_TMR6_5 */
#ifdef BSP_USING_PWM_TMR6_6
#ifndef PWM_TMR6_6_CONFIG
#define PWM_TMR6_6_CONFIG \
{ \
.name = "pwm_t61", \
.instance = CM_TMR6_6, \
.channel = 0, \
.stcTmr6Init = \
{ \
.u8CountSrc = TMR6_CNT_SRC_SW, \
.sw_count = \
{ \
.u32ClockDiv = TMR6_CLK_DIV1, \
.u32CountMode = TMR6_MD_SAWTOOTH, \
.u32CountDir = TMR6_CNT_DOWN, \
}, \
.u32PeriodValue = 0xFFFF, \
.u32CountReload = TMR6_CNT_RELOAD_ON, \
}, \
.stcPwmInit = \
{ \
{ \
.u32CompareValue = 0x0000, \
.u32StartPolarity = TMR6_PWM_LOW, \
.u32StopPolarity = TMR6_PWM_LOW, \
.u32CountUpMatchAPolarity = TMR6_PWM_HIGH, \
.u32CountDownMatchAPolarity = TMR6_PWM_HIGH, \
.u32CountUpMatchBPolarity = TMR6_PWM_HOLD, \
.u32CountDownMatchBPolarity = TMR6_PWM_HOLD, \
.u32UdfPolarity = TMR6_PWM_LOW, \
.u32OvfPolarity = TMR6_PWM_LOW, \
}, \
{ \
.u32CompareValue = 0x0000, \
.u32StartPolarity = TMR6_PWM_LOW, \
.u32StopPolarity = TMR6_PWM_LOW, \
.u32CountUpMatchAPolarity = TMR6_PWM_HOLD, \
.u32CountDownMatchAPolarity = TMR6_PWM_HOLD, \
.u32CountUpMatchBPolarity = TMR6_PWM_HIGH, \
.u32CountDownMatchBPolarity = TMR6_PWM_HIGH, \
.u32UdfPolarity = TMR6_PWM_LOW, \
.u32OvfPolarity = TMR6_PWM_LOW, \
} \
}, \
}
#endif /* PWM_TMR6_6_CONFIG */
#endif /* BSP_USING_PWM_TMR6_6 */
#ifdef BSP_USING_PWM_TMR6_7
#ifndef PWM_TMR6_7_CONFIG
#define PWM_TMR6_7_CONFIG \
{ \
.name = "pwm_t61", \
.instance = CM_TMR6_7, \
.channel = 0, \
.stcTmr6Init = \
{ \
.u8CountSrc = TMR6_CNT_SRC_SW, \
.sw_count = \
{ \
.u32ClockDiv = TMR6_CLK_DIV1, \
.u32CountMode = TMR6_MD_SAWTOOTH, \
.u32CountDir = TMR6_CNT_DOWN, \
}, \
.u32PeriodValue = 0xFFFF, \
.u32CountReload = TMR6_CNT_RELOAD_ON, \
}, \
.stcPwmInit = \
{ \
{ \
.u32CompareValue = 0x0000, \
.u32StartPolarity = TMR6_PWM_LOW, \
.u32StopPolarity = TMR6_PWM_LOW, \
.u32CountUpMatchAPolarity = TMR6_PWM_HIGH, \
.u32CountDownMatchAPolarity = TMR6_PWM_HIGH, \
.u32CountUpMatchBPolarity = TMR6_PWM_HOLD, \
.u32CountDownMatchBPolarity = TMR6_PWM_HOLD, \
.u32UdfPolarity = TMR6_PWM_LOW, \
.u32OvfPolarity = TMR6_PWM_LOW, \
}, \
{ \
.u32CompareValue = 0x0000, \
.u32StartPolarity = TMR6_PWM_LOW, \
.u32StopPolarity = TMR6_PWM_LOW, \
.u32CountUpMatchAPolarity = TMR6_PWM_HOLD, \
.u32CountDownMatchAPolarity = TMR6_PWM_HOLD, \
.u32CountUpMatchBPolarity = TMR6_PWM_HIGH, \
.u32CountDownMatchBPolarity = TMR6_PWM_HIGH, \
.u32UdfPolarity = TMR6_PWM_LOW, \
.u32OvfPolarity = TMR6_PWM_LOW, \
} \
}, \
}
#endif /* PWM_TMR6_7_CONFIG */
#endif /* BSP_USING_PWM_TMR6_7 */
#ifdef BSP_USING_PWM_TMR6_8
#ifndef PWM_TMR6_8_CONFIG
#define PWM_TMR6_8_CONFIG \
{ \
.name = "pwm_t61", \
.instance = CM_TMR6_8, \
.channel = 0, \
.stcTmr6Init = \
{ \
.u8CountSrc = TMR6_CNT_SRC_SW, \
.sw_count = \
{ \
.u32ClockDiv = TMR6_CLK_DIV1, \
.u32CountMode = TMR6_MD_SAWTOOTH, \
.u32CountDir = TMR6_CNT_DOWN, \
}, \
.u32PeriodValue = 0xFFFF, \
.u32CountReload = TMR6_CNT_RELOAD_ON, \
}, \
.stcPwmInit = \
{ \
{ \
.u32CompareValue = 0x0000, \
.u32StartPolarity = TMR6_PWM_LOW, \
.u32StopPolarity = TMR6_PWM_LOW, \
.u32CountUpMatchAPolarity = TMR6_PWM_HIGH, \
.u32CountDownMatchAPolarity = TMR6_PWM_HIGH, \
.u32CountUpMatchBPolarity = TMR6_PWM_HOLD, \
.u32CountDownMatchBPolarity = TMR6_PWM_HOLD, \
.u32UdfPolarity = TMR6_PWM_LOW, \
.u32OvfPolarity = TMR6_PWM_LOW, \
}, \
{ \
.u32CompareValue = 0x0000, \
.u32StartPolarity = TMR6_PWM_LOW, \
.u32StopPolarity = TMR6_PWM_LOW, \
.u32CountUpMatchAPolarity = TMR6_PWM_HOLD, \
.u32CountDownMatchAPolarity = TMR6_PWM_HOLD, \
.u32CountUpMatchBPolarity = TMR6_PWM_HIGH, \
.u32CountDownMatchBPolarity = TMR6_PWM_HIGH, \
.u32UdfPolarity = TMR6_PWM_LOW, \
.u32OvfPolarity = TMR6_PWM_LOW, \
} \
}, \
}
#endif /* PWM_TMR6_8_CONFIG */
#endif /* BSP_USING_PWM_TMR6_8 */
#endif /* BSP_USING_PWM_TMR6 */

View File

@@ -39,7 +39,7 @@ extern "C" {
.name = IC2_NAME, \
.ch = TMR6_CH_A, \
.clk_div = TMR6_CLK_DIV32, \
.first_edge = TMR6_CAPT_COND_TRIGB_RISING, \
.first_edge = TMR6_CAPT_COND_PWMA_RISING, \
.irq_num_cap = BSP_INPUT_CAPTURE_TMR6_2_CAP_IRQ_NUM, \
.irq_prio_cap = BSP_INPUT_CAPTURE_TMR6_2_CAP_IRQ_PRIO, \
.irq_num_ovf = BSP_INPUT_CAPTURE_TMR6_2_OVF_IRQ_NUM, \
@@ -54,7 +54,7 @@ extern "C" {
.name = IC3_NAME, \
.ch = TMR6_CH_B, \
.clk_div = TMR6_CLK_DIV16, \
.first_edge = TMR6_CAPT_COND_TRIGC_FALLING, \
.first_edge = TMR6_CAPT_COND_TRIGD_RISING, \
.irq_num_cap = BSP_INPUT_CAPTURE_TMR6_3_CAP_IRQ_NUM, \
.irq_prio_cap = BSP_INPUT_CAPTURE_TMR6_3_CAP_IRQ_PRIO, \
.irq_num_ovf = BSP_INPUT_CAPTURE_TMR6_3_OVF_IRQ_NUM, \
@@ -62,6 +62,21 @@ extern "C" {
}
#endif
#if defined (BSP_USING_INPUT_CAPTURE_TMR6_4)
#define IC4_NAME "ic4"
#define INPUT_CAPTURE_CFG_TMR6_4 \
{ \
.name = IC4_NAME, \
.ch = TMR6_CH_B, \
.clk_div = TMR6_CLK_DIV16, \
.first_edge = TMR6_CAPT_COND_PWMA_RISING, \
.irq_num_cap = BSP_INPUT_CAPTURE_TMR6_4_CAP_IRQ_NUM, \
.irq_prio_cap = BSP_INPUT_CAPTURE_TMR6_4_CAP_IRQ_PRIO, \
.irq_num_ovf = BSP_INPUT_CAPTURE_TMR6_4_OVF_IRQ_NUM, \
.irq_prio_ovf = BSP_INPUT_CAPTURE_TMR6_4_OVF_IRQ_PRIO, \
}
#endif
#ifdef __cplusplus
}
#endif

View File

@@ -82,9 +82,9 @@ define symbol __ICFEDIT_region_ERAM3_start__ = 0x0;
define symbol __ICFEDIT_region_ERAM3_end__ = 0x0;
/*-Sizes-*/
define symbol __ICFEDIT_size_cstack__ = 0x1000;
define symbol __ICFEDIT_size_cstack__ = 0x800;
define symbol __ICFEDIT_size_proc_stack__ = 0x0;
define symbol __ICFEDIT_size_heap__ = 0x1000;
define symbol __ICFEDIT_size_heap__ = 0x0;
/**** End of ICF editor section. ###ICF###*/
/*******************************************************************************

View File

@@ -0,0 +1,91 @@
scons --attach=devices.adc
scons -j4
scons --attach=default
scons --attach=devices.crypto
scons -j4
scons --attach=default
scons --attach=devices.dac
scons -j4
scons --attach=default
scons --attach=devices.flash
scons -j4
scons --attach=default
scons --attach=devices.gpio
scons -j4
scons --attach=default
scons --attach=devices.hwtimer
scons -j4
scons --attach=default
scons --attach=devices.i2c
scons -j4
scons --attach=default
scons --attach=devices.input_capture
scons -j4
scons --attach=default
scons --attach=devices.mcan
scons -j4
scons --attach=default
scons --attach=devices.pm
scons -j4
scons --attach=default
scons --attach=devices.pulse_encoder_tmr6
scons -j4
scons --attach=default
scons --attach=devices.pulse_encoder_tmra
scons -j4
scons --attach=default
scons --attach=devices.pwm_tmr4
scons -j4
scons --attach=default
scons --attach=devices.pwm_tmr6
scons -j4
scons --attach=default
scons --attach=devices.pwm_tmra
scons -j4
scons --attach=default
scons --attach=devices.rtc
scons -j4
scons --attach=default
scons --attach=devices.soft_i2c
scons -j4
scons --attach=default
scons --attach=devices.spi
scons -j4
scons --attach=default
scons --attach=devices.uart_v1
scons -j4
scons --attach=default
scons --attach=devices.uart_v2
scons -j4
scons --attach=default
scons --attach=devices.watchdog_swdt
scons -j4
scons --attach=default
scons --attach=devices.watchdog_wdt
scons -j4
scons --attach=default
scons --attach=peripheral.spi_flash
scons -j4
scons --attach=default

Binary file not shown.

Before

Width:  |  Height:  |  Size: 7.5 MiB

After

Width:  |  Height:  |  Size: 7.8 MiB

View File

@@ -322,7 +322,7 @@
<uThumb>0</uThumb>
<uSurpInc>0</uSurpInc>
<uC99>1</uC99>
<uGnu>0</uGnu>
<uGnu>1</uGnu>
<useXO>0</useXO>
<v6Lang>0</v6Lang>
<v6LangP>0</v6LangP>

View File

@@ -325,7 +325,7 @@
<uThumb>0</uThumb>
<uSurpInc>0</uSurpInc>
<uC99>1</uC99>
<uGnu>0</uGnu>
<uGnu>1</uGnu>
<useXO>0</useXO>
<v6Lang>0</v6Lang>
<v6LangP>0</v6LangP>

View File

@@ -1,12 +1,133 @@
# ------ device CI ------
devices.adc:
kconfig:
- CONFIG_BSP_USING_ADC=y
- CONFIG_BSP_USING_ADC1=y
- CONFIG_BSP_ADC1_USING_DMA=y
devices.crypto:
kconfig:
- CONFIG_BSP_USING_HWCRYPTO=y
- CONFIG_BSP_USING_UQID=y
- CONFIG_BSP_USING_RNG=y
- CONFIG_BSP_USING_CRC=y
- CONFIG_BSP_USING_HASH=y
devices.dac:
kconfig:
- CONFIG_BSP_USING_DAC=y
- CONFIG_BSP_USING_DAC1=y
devices.flash:
kconfig:
- CONFIG_BSP_USING_ON_CHIP_FLASH=y
- CONFIG_RT_USING_FAL=y
- CONFIG_RT_USING_SPI=y
- CONFIG_RT_USING_SFUD=y
devices.gpio:
kconfig:
- CONFIG_BSP_USING_GPIO=y
- CONFIG_BSP_USING_I2C=y
- CONFIG_BSP_USING_I2C_HW=y
- CONFIG_BSP_USING_I2C1=y
- CONFIG_BSP_USING_TCA9539=y
- CONFIG_BSP_USING_EXT_IO=y
devices.uart:
devices.hwtimer:
kconfig:
- CONFIG_BSP_USING_HWTIMER=y
- CONFIG_BSP_USING_TMRA_1=y
devices.i2c:
kconfig:
- CONFIG_BSP_USING_I2C=y
- CONFIG_BSP_USING_I2C1=y
- CONFIG_BSP_I2C1_TX_USING_DMA=y
- CONFIG_BSP_I2C1_RX_USING_DMA=y
devices.input_capture:
kconfig:
- CONFIG_BSP_USING_INPUT_CAPTURE=y
- CONFIG_BSP_USING_INPUT_CAPTURE_TMR6=y
- CONFIG_BSP_USING_INPUT_CAPTURE_TMR6_1=y
devices.mcan:
kconfig:
- CONFIG_BSP_USING_MCAN=y
- CONFIG_BSP_USING_MCAN1=y
- CONFIG_RT_CAN_USING_CANFD=y
- CONFIG_RT_CAN_USING_HDR=y
devices.pm:
kconfig:
- CONFIG_BSP_USING_PM=y
- CONFIG_IDLE_THREAD_STACK_SIZE=512
devices.pulse_encoder_tmr6:
kconfig:
- CONFIG_BSP_USING_PULSE_ENCODER=y
- CONFIG_BSP_USING_TMR6_PULSE_ENCODER=y
- CONFIG_BSP_USING_PULSE_ENCODER_TMR6_1=y
devices.pulse_encoder_tmra:
kconfig:
- CONFIG_BSP_USING_PULSE_ENCODER=y
- CONFIG_BSP_USING_TMRA_PULSE_ENCODER=y
- CONFIG_BSP_USING_PULSE_ENCODER_TMRA_1=y
devices.pwm_tmr4:
kconfig:
- CONFIG_BSP_USING_PWM=y
- CONFIG_BSP_USING_PWM_TMR4=y
- CONFIG_BSP_USING_PWM_TMR4_1=y
- CONFIG_BSP_USING_PWM_TMR4_1_OUH=y
- CONFIG_BSP_USING_PWM_TMR4_1_OUL=y
devices.pwm_tmr6:
kconfig:
- CONFIG_BSP_USING_PWM=y
- CONFIG_BSP_USING_PWM_TMR6=y
- CONFIG_BSP_USING_PWM_TMR6_1=y
- CONFIG_BSP_USING_PWM_TMR6_1_A=y
- CONFIG_BSP_USING_PWM_TMR6_1_B=y
devices.pwm_tmra:
kconfig:
- CONFIG_BSP_USING_PWM=y
- CONFIG_BSP_USING_PWM_TMRA=y
- CONFIG_BSP_USING_PWM_TMRA_1=y
- CONFIG_BSP_USING_PWM_TMRA_1_CH1=y
- CONFIG_BSP_USING_PWM_TMRA_1_CH2=y
devices.qspi:
kconfig:
- CONFIG_BSP_USING_QSPI=y
- CONFIG_BSP_QSPI_USING_DMA=y
- CONFIG_BSP_QSPI_USING_SOFT_CS=y
devices.rtc:
kconfig:
- CONFIG_BSP_USING_RTC=y
- CONFIG_RT_USING_ALARM=y
devices.soft_i2c:
kconfig:
- CONFIG_BSP_USING_I2C=y
- CONFIG_BSP_USING_I2C1_SW=y
devices.spi:
kconfig:
- CONFIG_BSP_USING_SPI=y
- CONFIG_BSP_USING_SPI1=y
- CONFIG_BSP_SPI1_TX_USING_DMA=y
- CONFIG_BSP_SPI1_RX_USING_DMA=y
- CONFIG_BSP_SPI_USING_DMA=y
- CONFIG_RT_USING_DFS=y
- CONFIG_RT_USING_DFS_ELMFAT=y
devices.uart_v1:
kconfig:
- CONFIG_RT_USING_SERIAL_V1=y
- CONFIG_BSP_USING_UART=y
- CONFIG_BSP_USING_UART2=y
- CONFIG_BSP_USING_UART1=y
- CONFIG_RT_SERIAL_USING_DMA=y
- CONFIG_BSP_UART1_RX_USING_DMA=y
- CONFIG_BSP_UART1_TX_USING_DMA=y
devices.uart_v2:
kconfig:
- CONFIG_RT_USING_SERIAL_V2=y
- CONFIG_BSP_USING_UART=y
- CONFIG_BSP_USING_UART1=y
- CONFIG_RT_SERIAL_USING_DMA=y
- CONFIG_BSP_UART1_RX_USING_DMA=y
- CONFIG_BSP_UART1_TX_USING_DMA=y
devices.watchdog_swdt:
kconfig:
- CONFIG_BSP_USING_WDT_TMR=y
- CONFIG_BSP_USING_SWDT=y
devices.watchdog_wdt:
kconfig:
- CONFIG_BSP_USING_WDT_TMR=y
- CONFIG_BSP_USING_WDT=y
# ------ peripheral CI ------
peripheral.spi_flash:
kconfig:
- CONFIG_BSP_USING_SPI_FLASH=y

View File

@@ -1,8 +1,8 @@
# XHSC EV_F448_LQ80_Rev1.0 开发板 BSP 说明
# XHSC EV_F448_LQ80 开发板 BSP 说明
## 简介
本文档为小华半导体为 EV_F448_LQ80_Rev1.0 开发板提供的 BSP (板级支持包) 说明。
本文档为小华半导体为 EV_F448_LQ80 开发板提供的 BSP (板级支持包) 说明。
主要内容如下:
@@ -14,79 +14,65 @@
## 开发板介绍
EV_F448_LQ80_Rev1.0 是 XHSC 官方推出的开发板,搭载 HC32F448MCTI 芯片,基于 ARM Cortex-M4 内核,最高主频 200 MHz具有丰富的板载资源可以充分发挥 HC32F448MCTI 的芯片性能。
EV_F448_LQ80 是 XHSC 官方推出的开发板,搭载 HC32F448MCTI 芯片,基于 ARM Cortex-M4 内核,最高主频 200 MHz具有丰富的板载资源可以充分发挥 HC32F448MCTI 的芯片性能。
开发板外观如下图所示:
![board](figures/board.png)
EV_F448_LQ80_Rev1.0 开发板常用 **板载资源** 如下:
EV_F448_LQ80 开发板常用 **板载资源** 如下:
- **MCU**
- HC32F448MCTI
- 主频200MHz
- 256KB FLASH
- 68KB RAM
- **外部Memory**
- BL24C256EEPROM, 256Kbits
- W25Q64SPI NOR64MB
- IS62WV51216SRAM 1MB
- **常用外设**
- LED: 4 个User LEDLED0LED1LED2LED3
- 按键: 5 个矩阵键盘K1~K4 WAKEUPK5RESETK0
- **常用接口**
- USB转串口
- CAN DB9接口 * 2
- TFT接口
- SmartCard接口
- I2C/USART/SPI接口
- **调试接口**
- 板载DAP调试器
- 标准JTAG/SWD/Trace
- MCUHC32F448MCTI主频200MHz256KB FLASH68KB RAM
- 外部RAMIS61LV6416SRAM 128KB
- 常用外设
- LED3 个User LED(LED0、LED1、LED2)
- 按键6个矩阵键盘K1~K4 WAKEUPK5RESETK0
- 常用接口LCD接口、CAN接口、LIN接口。
- 调试接口板载DAP调试器含USB转串口、标准JTAG/SWD。
开发板更多详细信息请参考小华半导体半导体[EV_F448_LQ80_Rev1.0](https://www.xhsc.com.cn)
开发板更多详细信息请参考小华半导体半导体[EV_F448_LQ80](https://www.xhsc.com.cn)
## 外设支持
本 BSP 目前对外设的支持情况如下:
| **板载外设** | **支持情况** | **备注** |
|:-------- |:--------:|:--------:|
| USB 转串口 | 支持 | 使用 UART2 |
| LED | 支持 | LED1~4 |
| **板载外设** | **支持情况** | **备注** |
| :------------ | :-----------: | :-----------------------------------: |
| USB 转串口 | 支持 | 使用 UART2 |
| **片上外设** | **支持情况** | **备注** |
|:------------- |:--------:|:------------------------------------------:|
| Crypto | 支持 | AES, CRC, HASH, RNG, UID |
| DAC | 支持 | |
| ADC | 支持 | ADC1: CH10, CH11, <br>ADC3: CH1 |
| CAN | 支持 | CAN1、CAN2 |
| GPIO | 支持 | PA0, PA1... PH2 ---> PIN: 0, 1...82 |
| I2C | 支持 | 软件模拟<br>硬件I2C1~2<br>I2C1支持EEPROMBL24C256 |
| PM | 支持 | |
| Lptimer | 支持 | |
| Hwtimer | 支持 | Hwtimer1~5 |
| Pulse_encoder | 支持 | |
| PWM | 支持 | |
| RTC | 支持 | 闹钟精度为1分钟 |
| WDT | 支持 | |
| I2C | 支持 | 软件、硬件 I2C |
| QSPI | 支持 | |
| SPI | 支持 | SPI1~3<br>SPI1支持W25Q |
| UART | 支持 | UART1~6<br>UART2为console使用 |
| **片上外设** | **支持情况** | **备注** |
| :------------ | :-----------: | :-----------------------------------: |
| ADC | 支持 | |
| Crypto | 支持 | CRCHASHRNG |
| DAC | 支持 | |
| FLASH | 支持 | |
| GPIO | 支持 | PA0PA1...PH2 ---> PIN01...82 |
| HwTimer | 支持 | |
| I2C | 支持 | 软件、硬件 I2C |
| InputCapture | 支持 | |
| MCAN | 支持 | |
| PM | 支持 | |
| PulseEncoder | 支持 | |
| PWM | 支持 | |
| QSPI | 支持 | |
| RTC | 支持 | 闹钟精度为1分钟 |
| SPI | 支持 | |
| UART V1 & V2 | 支持 | |
| WDT | 支持 | |
## 使用说明
使用说明分为如下两个章节:
- 快速上手
本章节是为刚接触 RT-Thread 的新手准备的使用说明,遵循简单的步骤即可将 RT-Thread 操作系统运行在该开发板上,看到实验效果 。
- 进阶使用
本章节是为需要在 RT-Thread 操作系统上使用更多开发板资源的开发者准备的。通过使用 ENV 工具对 BSP 进行配置,可以开启更多板载资源,实现更多高级功能。
### 快速上手
本 BSP 为开发者提供 MDK5 和 IAR 工程,并且支持 GCC 开发环境。下面以 MDK5 开发环境为例,介绍如何将系统运行起来。
@@ -110,7 +96,7 @@ USB虚拟COM端口默认连接串口2在终端工具里打开相应的串口
```
\ | /
- RT - Thread Operating System
/ | \ 5.0.1 build Feb 4 2024 16:44:26
/ | \ 4.1.0 build Apr 24 2022 13:32:39
2006 - 2022 Copyright by RT-Thread team
msh >
```
@@ -127,12 +113,6 @@ msh >
4. 输入`scons --target=mdk5/iar` 命令重新生成工程。
## 注意事项
| 板载外设 | 模式 | 注意事项 |
| ---- | ---- | ------------------------------------------------------------------------------------------------------ |
| USB | host | 若配置为U盘主机模式出现部分U盘无法识别或者写入失败时可以尝试将RTT抽象层中rt_udisk_run()函数的rt_usbh_storage_reset()操作注释掉,测试是否可以获得更好的兼容性。 |
## 联系人信息
维护人:

View File

@@ -662,6 +662,22 @@ menu "On-chip Peripheral Drivers"
default n
endif
menuconfig BSP_USING_INPUT_CAPTURE
bool "Enable Input Capture"
default n
select RT_USING_INPUT_CAPTURE
if BSP_USING_INPUT_CAPTURE
menuconfig BSP_USING_INPUT_CAPTURE_TMR6
bool "Use Timer6 As The Input Capture"
default n
if BSP_USING_INPUT_CAPTURE_TMR6
config BSP_USING_INPUT_CAPTURE_TMR6_1
bool "unit 1"
config BSP_USING_INPUT_CAPTURE_TMR6_2
bool "unit 2"
endif
endif
menuconfig BSP_USING_SENSOR
bool "Enable SENSOR"
default n

View File

@@ -332,6 +332,31 @@ rt_err_t rt_hw_board_pwm_tmr6_init(CM_TMR6_TypeDef *TMR6x)
#endif
#endif
#if defined (BSP_USING_INPUT_CAPTURE)
rt_err_t rt_hw_board_input_capture_init(uint32_t *tmr_instance)
{
rt_err_t result = RT_EOK;
switch ((rt_uint32_t)tmr_instance)
{
#if defined (BSP_USING_INPUT_CAPTURE_TMR6_1)
case (rt_uint32_t)CM_TMR6_1:
GPIO_SetFunc(INPUT_CAPTURE_TMR6_1_PORT, INPUT_CAPTURE_TMR6_1_PIN, INPUT_CAPTURE_TMR6_1_FUNC);
break;
#endif
#if defined (BSP_USING_INPUT_CAPTURE_TMR6_2)
case (rt_uint32_t)CM_TMR6_2:
GPIO_SetFunc(INPUT_CAPTURE_TMR6_2_PORT, INPUT_CAPTURE_TMR6_2_PIN, INPUT_CAPTURE_TMR6_2_FUNC);
break;
#endif
default:
result = -RT_ERROR;
break;
}
return result;
}
#endif
#ifdef RT_USING_PM
#define PLL_SRC ((CM_CMU->PLLHCFGR & CMU_PLLHCFGR_PLLSRC) >> CMU_PLLHCFGR_PLLSRC_POS)
void rt_hw_board_pm_sysclk_cfg(uint8_t run_mode)

View File

@@ -252,6 +252,19 @@
#endif
#if defined(BSP_USING_INPUT_CAPTURE)
#if defined(BSP_USING_INPUT_CAPTURE_TMR6_1)
#define INPUT_CAPTURE_TMR6_1_FUNC (GPIO_FUNC_3)
#define INPUT_CAPTURE_TMR6_1_PORT (GPIO_PORT_A)
#define INPUT_CAPTURE_TMR6_1_PIN (GPIO_PIN_08)
#endif
#if defined(BSP_USING_INPUT_CAPTURE_TMR6_2)
#define INPUT_CAPTURE_TMR6_2_FUNC (GPIO_FUNC_3)
#define INPUT_CAPTURE_TMR6_2_PORT (GPIO_PORT_B)
#define INPUT_CAPTURE_TMR6_2_PIN (GPIO_PIN_02)
#endif
#endif
#if defined(BSP_USING_QSPI)
#ifndef BSP_QSPI_USING_SOFT_CS
/* QSSN */

View File

@@ -191,17 +191,11 @@ extern "C" {
#if defined(BSP_USING_MCAN1)
#define BSP_MCAN1_INT0_IRQ_NUM MCAN1_INT0_IRQn
#define BSP_MCAN1_INT0_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#define BSP_MCAN1_INT1_IRQ_NUM MCAN1_INT1_IRQn
#define BSP_MCAN1_INT1_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif/* BSP_USING_MCAN1 */
#if defined(BSP_USING_MCAN2)
#define BSP_MCAN2_INT0_IRQ_NUM MCAN2_INT0_IRQn
#define BSP_MCAN2_INT0_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#define BSP_MCAN2_INT1_IRQ_NUM MCAN2_INT1_IRQn
#define BSP_MCAN2_INT1_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif/* BSP_USING_MCAN2 */
#if defined(RT_USING_ALARM)
@@ -253,6 +247,18 @@ extern "C" {
#define BSP_PULSE_ENCODER_TMR6_2_UDF_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif/* BSP_USING_PULSE_ENCODER_TMR6_2 */
#if defined(BSP_USING_INPUT_CAPTURE)
#define BSP_INPUT_CAPTURE_TMR6_1_OVF_IRQ_NUM (INT012_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_1_OVF_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_1_CAP_IRQ_NUM (INT013_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_1_CAP_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_2_OVF_IRQ_NUM (INT014_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_2_OVF_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_2_CAP_IRQ_NUM (INT015_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_2_CAP_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#endif
#ifdef __cplusplus
}
#endif

View File

@@ -0,0 +1,54 @@
/*
* Copyright (C) 2022-2024, Xiaohua Semiconductor Co., Ltd.
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2025-08-14 CDT first version
*/
#ifndef __IC_CONFIG_H__
#define __IC_CONFIG_H__
#include <rtthread.h>
#ifdef __cplusplus
extern "C" {
#endif
#if defined (BSP_USING_INPUT_CAPTURE_TMR6_1)
#define IC1_NAME "ic1"
#define INPUT_CAPTURE_CFG_TMR6_1 \
{ \
.name = IC1_NAME, \
.ch = TMR6_CH_A, \
.clk_div = TMR6_CLK_DIV32, \
.first_edge = TMR6_CAPT_COND_PWMA_RISING, \
.irq_num_cap = BSP_INPUT_CAPTURE_TMR6_1_CAP_IRQ_NUM, \
.irq_prio_cap = BSP_INPUT_CAPTURE_TMR6_1_CAP_IRQ_PRIO, \
.irq_num_ovf = BSP_INPUT_CAPTURE_TMR6_1_OVF_IRQ_NUM, \
.irq_prio_ovf = BSP_INPUT_CAPTURE_TMR6_1_OVF_IRQ_PRIO, \
}
#endif
#if defined (BSP_USING_INPUT_CAPTURE_TMR6_2)
#define IC2_NAME "ic2"
#define INPUT_CAPTURE_CFG_TMR6_2 \
{ \
.name = IC2_NAME, \
.ch = TMR6_CH_A, \
.clk_div = TMR6_CLK_DIV32, \
.first_edge = TMR6_CAPT_COND_TRIGB_RISING, \
.irq_num_cap = BSP_INPUT_CAPTURE_TMR6_2_CAP_IRQ_NUM, \
.irq_prio_cap = BSP_INPUT_CAPTURE_TMR6_2_CAP_IRQ_PRIO, \
.irq_num_ovf = BSP_INPUT_CAPTURE_TMR6_2_OVF_IRQ_NUM, \
.irq_prio_ovf = BSP_INPUT_CAPTURE_TMR6_2_OVF_IRQ_PRIO, \
}
#endif
#ifdef __cplusplus
}
#endif
#endif /* __IC_CONFIG_H__ */

View File

@@ -30,6 +30,7 @@ extern "C" {
#include "qspi_config.h"
#include "pulse_encoder_config.h"
#include "timer_config.h"
#include "tmr_capture_config.h"
#ifdef __cplusplus
}

View File

@@ -75,9 +75,9 @@ define symbol __ICFEDIT_region_ERAM3_start__ = 0x0;
define symbol __ICFEDIT_region_ERAM3_end__ = 0x0;
/*-Sizes-*/
define symbol __ICFEDIT_size_cstack__ = 0xC00;
define symbol __ICFEDIT_size_cstack__ = 0x800;
define symbol __ICFEDIT_size_proc_stack__ = 0x0;
define symbol __ICFEDIT_size_heap__ = 0x400;
define symbol __ICFEDIT_size_heap__ = 0x0;
/**** End of ICF editor section. ###ICF###*/
/*******************************************************************************

View File

@@ -0,0 +1,96 @@
scons --attach=devices.adc
scons -j4
scons --attach=default
scons --attach=devices.crypto
scons -j4
scons --attach=default
scons --attach=devices.dac
scons -j4
scons --attach=default
scons --attach=devices.flash
scons -j4
scons --attach=default
scons --attach=devices.gpio
scons -j4
scons --attach=default
scons --attach=devices.hwtimer
scons -j4
scons --attach=default
scons --attach=devices.i2c
scons -j4
scons --attach=default
scons --attach=devices.input_capture
scons -j4
scons --attach=default
scons --attach=devices.mcan
scons -j4
scons --attach=default
scons --attach=devices.pm
scons -j4
scons --attach=default
scons --attach=devices.pulse_encoder_tmr6
scons -j4
scons --attach=default
scons --attach=devices.pulse_encoder_tmra
scons -j4
scons --attach=default
scons --attach=devices.pwm_tmr4
scons -j4
scons --attach=default
scons --attach=devices.pwm_tmr6
scons -j4
scons --attach=default
scons --attach=devices.pwm_tmra
scons -j4
scons --attach=default
scons --attach=devices.qspi
scons -j4
scons --attach=default
scons --attach=devices.rtc
scons -j4
scons --attach=default
scons --attach=devices.soft_i2c
scons -j4
scons --attach=default
scons --attach=devices.spi
scons -j4
scons --attach=default
scons --attach=devices.uart_v1
scons -j4
scons --attach=default
scons --attach=devices.uart_v2
scons -j4
scons --attach=default
scons --attach=devices.watchdog_swdt
scons -j4
scons --attach=default
scons --attach=devices.watchdog_wdt
scons -j4
scons --attach=default
scons --attach=peripheral.spi_flash
scons -j4
scons --attach=default

View File

@@ -323,7 +323,7 @@
<uThumb>0</uThumb>
<uSurpInc>0</uSurpInc>
<uC99>1</uC99>
<uGnu>0</uGnu>
<uGnu>1</uGnu>
<useXO>0</useXO>
<v6Lang>0</v6Lang>
<v6LangP>0</v6LangP>

View File

@@ -326,7 +326,7 @@
<uThumb>0</uThumb>
<uSurpInc>0</uSurpInc>
<uC99>1</uC99>
<uGnu>0</uGnu>
<uGnu>1</uGnu>
<useXO>0</useXO>
<v6Lang>0</v6Lang>
<v6LangP>0</v6LangP>

View File

@@ -1,7 +1,166 @@
# ------ device CI ------
devices.adc:
kconfig:
- CONFIG_BSP_USING_ADC=y
- CONFIG_BSP_USING_ADC1=y
- CONFIG_BSP_ADC1_USING_DMA=y
devices.can:
kconfig:
- CONFIG_BSP_USING_CAN=y
- CONFIG_BSP_USING_CAN1=y
- CONFIG_RT_CAN_USING_HDR=y
devices.crypto:
kconfig:
- CONFIG_BSP_USING_HWCRYPTO=y
- CONFIG_BSP_USING_UQID=y
- CONFIG_BSP_USING_RNG=y
- CONFIG_BSP_USING_CRC=y
- CONFIG_BSP_USING_HASH=y
devices.flash:
kconfig:
- CONFIG_BSP_USING_ON_CHIP_FLASH=y
- CONFIG_RT_USING_FAL=y
- CONFIG_RT_USING_SPI=y
- CONFIG_RT_USING_SFUD=y
devices.gpio:
kconfig:
- CONFIG_BSP_USING_GPIO=y
devices.uart:
devices.hwtimer:
kconfig:
- CONFIG_BSP_USING_HWTIMER=y
- CONFIG_BSP_USING_TMRA_1=y
devices.i2c:
kconfig:
- CONFIG_BSP_USING_I2C=y
- CONFIG_BSP_USING_I2C1=y
- CONFIG_BSP_I2C1_TX_USING_DMA=y
- CONFIG_BSP_I2C1_RX_USING_DMA=y
devices.input_capture:
kconfig:
- CONFIG_BSP_USING_INPUT_CAPTURE=y
- CONFIG_BSP_USING_INPUT_CAPTURE_TMR6=y
- CONFIG_BSP_USING_INPUT_CAPTURE_TMR6_1=y
devices.pm:
kconfig:
- CONFIG_BSP_USING_PM=y
- CONFIG_IDLE_THREAD_STACK_SIZE=512
devices.pulse_encoder_tmr6:
kconfig:
- CONFIG_BSP_USING_PULSE_ENCODER=y
- CONFIG_BSP_USING_TMR6_PULSE_ENCODER=y
- CONFIG_BSP_USING_PULSE_ENCODER_TMR6_1=y
devices.pulse_encoder_tmra:
kconfig:
- CONFIG_BSP_USING_PULSE_ENCODER=y
- CONFIG_BSP_USING_TMRA_PULSE_ENCODER=y
- CONFIG_BSP_USING_PULSE_ENCODER_TMRA_1=y
devices.pwm_tmr4:
kconfig:
- CONFIG_BSP_USING_PWM=y
- CONFIG_BSP_USING_PWM_TMR4=y
- CONFIG_BSP_USING_PWM_TMR4_1=y
- CONFIG_BSP_USING_PWM_TMR4_1_OUH=y
- CONFIG_BSP_USING_PWM_TMR4_1_OUL=y
devices.pwm_tmr6:
kconfig:
- CONFIG_BSP_USING_PWM=y
- CONFIG_BSP_USING_PWM_TMR6=y
- CONFIG_BSP_USING_PWM_TMR6_1=y
- CONFIG_BSP_USING_PWM_TMR6_1_A=y
- CONFIG_BSP_USING_PWM_TMR6_1_B=y
devices.pwm_tmra:
kconfig:
- CONFIG_BSP_USING_PWM=y
- CONFIG_BSP_USING_PWM_TMRA=y
- CONFIG_BSP_USING_PWM_TMRA_1=y
- CONFIG_BSP_USING_PWM_TMRA_1_CH1=y
- CONFIG_BSP_USING_PWM_TMRA_1_CH2=y
devices.qspi:
kconfig:
- CONFIG_BSP_USING_QSPI=y
- CONFIG_BSP_QSPI_USING_DMA=y
- CONFIG_BSP_QSPI_USING_SOFT_CS=y
devices.rtc:
kconfig:
- CONFIG_BSP_USING_RTC=y
- CONFIG_RT_USING_ALARM=y
devices.sdio:
kconfig:
- CONFIG_BSP_USING_SDIO=y
- CONFIG_BSP_USING_SDIO1=y
- CONFIG_RT_USING_DFS=y
- CONFIG_RT_USING_DFS_ELMFAT=y
devices.soft_i2c:
kconfig:
- CONFIG_BSP_USING_I2C=y
- CONFIG_BSP_USING_I2C1_SW=y
devices.spi:
kconfig:
- CONFIG_BSP_USING_SPI=y
- CONFIG_BSP_USING_SPI1=y
- CONFIG_BSP_SPI1_TX_USING_DMA=y
- CONFIG_BSP_SPI1_RX_USING_DMA=y
- CONFIG_BSP_SPI_USING_DMA=y
- CONFIG_RT_USING_DFS=y
- CONFIG_RT_USING_DFS_ELMFAT=y
devices.uart_v1:
kconfig:
- CONFIG_RT_USING_SERIAL_V1=y
- CONFIG_BSP_USING_UART=y
- CONFIG_BSP_USING_UART4=y
- CONFIG_BSP_USING_UART1=y
- CONFIG_RT_SERIAL_USING_DMA=y
- CONFIG_BSP_UART1_RX_USING_DMA=y
- CONFIG_BSP_UART1_TX_USING_DMA=y
devices.uart_v2:
kconfig:
- CONFIG_RT_USING_SERIAL_V2=y
- CONFIG_BSP_USING_UART=y
- CONFIG_BSP_USING_UART1=y
- CONFIG_RT_SERIAL_USING_DMA=y
- CONFIG_BSP_UART1_RX_USING_DMA=y
- CONFIG_BSP_UART1_TX_USING_DMA=y
devices.usb_hs_device:
kconfig:
- CONFIG_BSP_USING_USB=y
- CONFIG_BSP_USING_USBD=y
- CONFIG_BSP_USING_USBHS=y
- CONFIG_BSP_USING_USBD_HS=y
- CONFIG_RT_USB_DEVICE_MSTORAGE=y
devices.usb_hs_host:
kconfig:
- CONFIG_BSP_USING_USB=y
- CONFIG_BSP_USING_USBH=y
- CONFIG_BSP_USING_USBHS=y
- CONFIG_BSP_USING_USBH_HS=y
- CONFIG_RT_USBH_MSTORAGE=y
- CONFIG_RT_USING_DFS=y
- CONFIG_RT_USING_DFS_ELMFAT=y
devices.usb_fs_device:
kconfig:
- CONFIG_BSP_USING_USB=y
- CONFIG_BSP_USING_USBD=y
- CONFIG_BSP_USING_USBFS=y
- CONFIG_BSP_USING_USBD_FS=y
- CONFIG_RT_USB_DEVICE_MSTORAGE=y
devices.usb_fs_host:
kconfig:
- CONFIG_BSP_USING_USB=y
- CONFIG_BSP_USING_USBH=y
- CONFIG_BSP_USING_USBFS=y
- CONFIG_BSP_USING_USBH_FS=y
- CONFIG_RT_USBH_MSTORAGE=y
- CONFIG_RT_USING_DFS=y
- CONFIG_RT_USING_DFS_ELMFAT=y
devices.watchdog_swdt:
kconfig:
- CONFIG_BSP_USING_WDT_TMR=y
- CONFIG_BSP_USING_SWDT=y
devices.watchdog_wdt:
kconfig:
- CONFIG_BSP_USING_WDT_TMR=y
- CONFIG_BSP_USING_WDT=y
# ------ peripheral CI ------
peripheral.spi_flash:
kconfig:
- CONFIG_BSP_USING_SPI_FLASH=y

View File

@@ -22,12 +22,12 @@ EV_F460_LQ100_V2 是 XHSC 官方推出的开发板,搭载 HC32F460PETB 芯片
EV_F460_LQ100_V2 开发板常用 **板载资源** 如下:
- MCU: HC32F460PETB主频200MHz512KB FLASH192KB RAM
- MCUHC32F460PETB主频200MHz512KB FLASH192KB RAM
- 常用外设
- LED: 4 个User LED(LED0LED1LED2LED3)。
- 按键: 11 个,矩阵键盘(K1~K9), WAKEUP(K10), RESET(K11)
- 常用接口: USB转串口、SD卡接口、USB FS、3.5mm耳机接口、Line in接口、喇叭接口
- 调试接口: 板载DAP调试器、标准JTAG/SWD
- LED4 个User LED(LED0LED1LED2LED3)。
- 按键11 个,矩阵键盘(K1~K9)WAKEUP(K10)RESET(K11)
- 常用接口SD卡接口、USB FS接口、3.5mm耳机接口、Line in接口、CAN接口
- 调试接口板载DAP调试器含USB转串口、标准JTAG/SWD
开发板更多详细信息请参考小华半导体半导体[EV_F460_LQ100_V2](https://www.xhsc.com.cn)
@@ -35,31 +35,44 @@ EV_F460_LQ100_V2 开发板常用 **板载资源** 如下:
本 BSP 目前对外设的支持情况如下:
| **板载外设** | **支持情况** | **备注** |
|:-------- |:--------:|:--------:|
| USB 转串口 | 支持 | 使用 UART4 |
| LED | 支持 | LED |
| **板载外设** | **支持情况** | **备注** |
| :------------ | :-----------: | :-----------------------------------: |
| USB 转串口 | 支持 | 使用 UART4 |
| **片上外设** | **支持情况** | **备注** |
|:-------- |:--------:|:-----------------------------------:|
| ADC | 支持 | ADC1~2 |
| CAN | 支持 | CAN1 |
| GPIO | 支持 | PA0, PA1... PH2 ---> PIN: 0, 1...82 |
| I2C | 支持 | 软件 |
| UART | 支持 | UART1~4 |
| **片上外设** | **支持情况** | **备注** |
| :------------ | :-----------: | :-----------------------------------: |
| ADC | 支持 | |
| CAN | 支持 | |
| Crypto | 支持 | CRCHASHRNG |
| FLASH | 支持 | |
| GPIO | 支持 | PA0PA1... PH2 ---> PIN01...82 |
| HwTimer | 支持 | |
| I2C | 支持 | 软件、硬件 I2C |
| InputCapture | 支持 | |
| PM | 支持 | |
| PulseEncoder | 支持 | |
| PWM | 支持 | |
| QSPI | 支持 | |
| RTC | 支持 | 闹钟精度为1分钟 |
| SDIO | 支持 | |
| SPI | 支持 | |
| UART V1 & V2 | 支持 | |
| USB | 支持 | USBFS Core device/host模式 |
| WDT | 支持 | |
## 使用说明
使用说明分为如下两个章节:
- 快速上手
本章节是为刚接触 RT-Thread 的新手准备的使用说明,遵循简单的步骤即可将 RT-Thread 操作系统运行在该开发板上,看到实验效果 。
- 进阶使用
本章节是为需要在 RT-Thread 操作系统上使用更多开发板资源的开发者准备的。通过使用 ENV 工具对 BSP 进行配置,可以开启更多板载资源,实现更多高级功能。
### 快速上手
本 BSP 为开发者提供 MDK5 和 IAR 工程,并且支持 GCC 开发环境。下面以 MDK5 开发环境为例,介绍如何将系统运行起来。
@@ -83,7 +96,7 @@ USB虚拟COM端口默认连接串口4在终端工具里打开相应的串口
```
\ | /
- RT - Thread Operating System
/ | \ 4.1.1 build May 25 2022 08:55:55
/ | \ 4.1.0 build Apr 24 2022 13:32:39
2006 - 2022 Copyright by RT-Thread team
msh >
```
@@ -102,11 +115,14 @@ msh >
## 注意事项
| 板载外设 | 模式 | 注意事项 |
| -------- | ------ | ------------------------------------------------------------ |
| USB | device | 由于RTT抽象层的设计当配置为CDC设备时打开USB虚拟串口需使能流控的DTR信号。如使用SSCOM串口助手打开USB虚拟串口时勾选DTR选框 |
| USB | host | 若配置为U盘主机模式出现部分U盘无法识别或者写入失败时可以尝试将RTT抽象层中rt_udisk_run()函数的rt_usbh_storage_reset()操作注释掉,测试是否可以获得更好的兼容性。 |
| USB | host | 目前仅实现并测试了对U盘的支持。 |
| 板载外设 | 模式 | 协议栈 | 注意事项 |
| -------- | ------ | :------------: | ------------------------------------------------------------ |
| USB | device | ALL | 由于协议栈的设计当配置为CDC设备时打开USB虚拟串口需使能流控的DTR信号。如使用SSCOM串口助手打开USB虚拟串口时勾选DTR选框 |
| USB | host | RTT legacy USB | 若配置为U盘主机模式出现部分U盘无法识别或者写入失败时可以尝试将RTT抽象层中rt_udisk_run()函数的rt_usbh_storage_reset()操作注释掉,测试是否可以获得更好的兼容性。 |
| USB | host | RTT legacy USB | 目前仅实现并测试了对U盘的支持。 |
| USB | ALL | ALL | CherryUSB 与 RTT legacy USB 组件不可同时使用;<br />CherryUSB与 ”On-Chip Peripheral Driver---> []Enable USB“ 不可同时使能及配置。 |
| USB | ALL | RTT legacy USB | 通过“board/config/usb_config/usb_app_conf.h” 进行应用个性化配置主要为FIFO分配 |
| USB | ALL | CherryUSB | 通过“board/ports/usb_config.h”进行应用个性化配置如FIFO分配、是否使用DMA[Device]等) |
## 联系人信息

View File

@@ -68,7 +68,7 @@ menu "On-chip Peripheral Drivers"
int "Set UART1 RX DMA ping-pong buffer size"
range 32 65535
depends on RT_USING_SERIAL_V2 && BSP_UART1_RX_USING_DMA
default 64
default 64
endif
menuconfig BSP_USING_UART2
@@ -101,7 +101,7 @@ menu "On-chip Peripheral Drivers"
int "Set UART2 RX DMA ping-pong buffer size"
range 32 65535
depends on RT_USING_SERIAL_V2 && BSP_UART2_RX_USING_DMA
default 64
default 64
endif
menuconfig BSP_USING_UART3
@@ -134,7 +134,7 @@ menu "On-chip Peripheral Drivers"
int "Set UART3 RX DMA ping-pong buffer size"
range 32 65535
depends on RT_USING_SERIAL_V2 && BSP_UART3_RX_USING_DMA
default 64
default 64
endif
menuconfig BSP_USING_UART4
@@ -167,7 +167,7 @@ menu "On-chip Peripheral Drivers"
int "Set UART4 RX DMA ping-pong buffer size"
range 32 65535
depends on RT_USING_SERIAL_V2 && BSP_UART4_RX_USING_DMA
default 64
default 64
endif
endif
@@ -377,7 +377,7 @@ menu "On-chip Peripheral Drivers"
select RT_USING_WDT
if BSP_USING_WDT_TMR
config BSP_USING_WDT
bool
bool
default y
config BSP_WDT_CONTINUE_COUNT
@@ -562,6 +562,7 @@ menu "On-chip Peripheral Drivers"
menuconfig BSP_USING_USB
bool "Enable USB"
default n
depends on !RT_USING_CHERRYUSB
select RT_USING_USB_DEVICE if BSP_USING_USBD
select RT_USING_USB_HOST if BSP_USING_USBH
if BSP_USING_USB

View File

@@ -32,7 +32,7 @@ void SystemClock_Config(void)
{
stc_clock_xtal_init_t stcXtalInit;
stc_clock_pll_init_t stcMpllInit;
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH)
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH) || defined(RT_USING_CHERRYUSB)
stc_clock_pllx_init_t stcUpllInit;
#endif
#if defined(BSP_RTC_USING_XTAL32) || defined(RT_USING_PM)
@@ -80,7 +80,7 @@ void SystemClock_Config(void)
/* Switch system clock source to MPLL. */
CLK_SetSysClockSrc(CLK_SYSCLK_SRC_PLL);
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH)
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH) || defined(RT_USING_CHERRYUSB)
/* PLLX for USB */
(void)CLK_PLLxStructInit(&stcUpllInit);
/* VCO = (8/2)*120 = 480MHz*/
@@ -113,7 +113,7 @@ void PeripheralClock_Config(void)
CLK_SetPeriClockSrc(CLK_PERIPHCLK_PCLK);
#endif
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH)
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH) || defined(RT_USING_CHERRYUSB)
CLK_SetUSBClockSrc(CLK_USBCLK_PLLXP);
#endif
}

View File

@@ -366,6 +366,27 @@ rt_err_t rt_hw_usbfs_board_init(void)
}
#endif
#if defined(RT_USING_CHERRYUSB)
rt_err_t rt_hw_usbfs_board_init(uint8_t devmode)
{
stc_gpio_init_t stcGpioCfg;
(void)GPIO_StructInit(&stcGpioCfg);
stcGpioCfg.u16PinAttr = PIN_ATTR_ANALOG;
(void)GPIO_Init(USBF_DM_PORT, USBF_DM_PIN, &stcGpioCfg);
(void)GPIO_Init(USBF_DP_PORT, USBF_DP_PIN, &stcGpioCfg);
if (0U != devmode)
{
GPIO_SetFunc(USBF_VBUS_PORT, USBF_VBUS_PIN, USBF_VBUS_FUNC); /* VBUS */
}
else
{
GPIO_SetFunc(USBF_DRVVBUS_PORT, USBF_DRVVBUS_PIN, USBF_DRVVBUS_FUNC); /* DRV VBUS */
}
return RT_EOK;
}
#endif
#if defined(BSP_USING_QSPI)
rt_err_t rt_hw_qspi_board_init(void)
{

View File

@@ -15,7 +15,9 @@
#include <rtconfig.h>
#include "hc32_ll.h"
#include "drv_config.h"
#if defined(RT_USING_CHERRYUSB)
#include "usb_config.h"
#endif
/************************* XTAL port **********************/
#define XTAL_PORT (GPIO_PORT_H)
@@ -242,8 +244,15 @@
#endif
#endif
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH)
#if defined(BSP_USING_USBFS)
#if defined(RT_USING_CHERRYUSB)
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH) || \
defined(BSP_USING_USBFS) || defined(RT_USING_USB)
#error "When using CherryUSB, Please donot Enable 'On-Chip Peripheral Driver---> []Enable USB' or using USB legacy version!"
#endif
#endif
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH) || defined(RT_USING_CHERRYUSB)
#if defined(BSP_USING_USBFS) || defined(RT_USING_CHERRYUSB)
/* USBFS Core*/
#define USBF_DP_PORT (GPIO_PORT_A)
#define USBF_DP_PIN (GPIO_PIN_12)

View File

@@ -204,7 +204,7 @@ extern "C" {
#define BSP_RTC_ALARM_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif/* RT_USING_ALARM */
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH)
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH) || defined(RT_USING_CHERRYUSB)
#define BSP_USBFS_GLB_IRQ_NUM INT003_IRQn
#define BSP_USBFS_GLB_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif/* BSP_USING_USBD */

View File

@@ -73,9 +73,9 @@ define symbol __ICFEDIT_region_ERAM3_start__ = 0x0;
define symbol __ICFEDIT_region_ERAM3_end__ = 0x0;
/*-Sizes-*/
define symbol __ICFEDIT_size_cstack__ = 0x2000;
define symbol __ICFEDIT_size_cstack__ = 0x800;
define symbol __ICFEDIT_size_proc_stack__ = 0x0;
define symbol __ICFEDIT_size_heap__ = 0x2000;
define symbol __ICFEDIT_size_heap__ = 0x0;
/**** End of ICF editor section. ###ICF###*/
/*******************************************************************************

View File

@@ -88,6 +88,12 @@ SECTIONS
__rt_init_end = .;
. = ALIGN(4);
/* section for CherryUSB. */
. = ALIGN(4);
__usbh_class_info_start__ = .;
KEEP(*(.usbh_class_info))
__usbh_class_info_end__ = .;
. = ALIGN(4);
_etext = .;
} >FLASH

View File

@@ -0,0 +1,307 @@
/*
* Copyright (c) 2022-2024, Xiaohua Semiconductor Co., Ltd.
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2025-08-08 CDT first version
*/
#ifndef CHERRYUSB_CONFIG_H
#define CHERRYUSB_CONFIG_H
/* ================ USB common Configuration ================ */
#ifdef __RTTHREAD__
#include <rtthread.h>
#define CONFIG_USB_PRINTF(...) rt_kprintf(__VA_ARGS__)
#else
#define CONFIG_USB_PRINTF(...) printf(__VA_ARGS__)
#endif
#ifndef CONFIG_USB_DBG_LEVEL
#define CONFIG_USB_DBG_LEVEL USB_DBG_INFO
#endif
/* Enable print with color */
#define CONFIG_USB_PRINTF_COLOR_ENABLE
// #define CONFIG_USB_DCACHE_ENABLE
/* data align size when use dma or use dcache */
#ifdef CONFIG_USB_DCACHE_ENABLE
#define CONFIG_USB_ALIGN_SIZE 32 // 32 or 64
#else
#define CONFIG_USB_ALIGN_SIZE 4
#endif
/* attribute data into no cache ram */
#define USB_NOCACHE_RAM_SECTION __attribute__((section(".noncacheable")))
/* use usb_memcpy default for high performance but cost more flash memory.
* And, arm libc has a bug that memcpy() may cause data misalignment when the size is not a multiple of 4.
*/
// #define CONFIG_USB_MEMCPY_DISABLE
/* ================= USB Device Stack Configuration ================ */
/* Ep0 in and out transfer buffer */
#ifndef CONFIG_USBDEV_REQUEST_BUFFER_LEN
#define CONFIG_USBDEV_REQUEST_BUFFER_LEN 512
#endif
/* Send ep0 in data from user buffer instead of copying into ep0 reqdata
* Please note that user buffer must be aligned with CONFIG_USB_ALIGN_SIZE
*/
// #define CONFIG_USBDEV_EP0_INDATA_NO_COPY
/* Check if the input descriptor is correct */
// #define CONFIG_USBDEV_DESC_CHECK
/* Enable test mode */
// #define CONFIG_USBDEV_TEST_MODE
/* enable advance desc register api */
#define CONFIG_USBDEV_ADVANCE_DESC
/* move ep0 setup handler from isr to thread */
// #define CONFIG_USBDEV_EP0_THREAD
#ifndef CONFIG_USBDEV_EP0_PRIO
#define CONFIG_USBDEV_EP0_PRIO 4
#endif
#ifndef CONFIG_USBDEV_EP0_STACKSIZE
#define CONFIG_USBDEV_EP0_STACKSIZE 2048
#endif
#ifndef CONFIG_USBDEV_MSC_MAX_LUN
#define CONFIG_USBDEV_MSC_MAX_LUN 1
#endif
#ifndef CONFIG_USBDEV_MSC_MAX_BUFSIZE
#define CONFIG_USBDEV_MSC_MAX_BUFSIZE 512
#endif
#ifndef CONFIG_USBDEV_MSC_MANUFACTURER_STRING
#define CONFIG_USBDEV_MSC_MANUFACTURER_STRING ""
#endif
#ifndef CONFIG_USBDEV_MSC_PRODUCT_STRING
#define CONFIG_USBDEV_MSC_PRODUCT_STRING ""
#endif
#ifndef CONFIG_USBDEV_MSC_VERSION_STRING
#define CONFIG_USBDEV_MSC_VERSION_STRING "0.01"
#endif
/* move msc read & write from isr to while(1), you should call usbd_msc_polling in while(1) */
// #define CONFIG_USBDEV_MSC_POLLING
/* move msc read & write from isr to thread */
// #define CONFIG_USBDEV_MSC_THREAD
#ifndef CONFIG_USBDEV_MSC_PRIO
#define CONFIG_USBDEV_MSC_PRIO 4
#endif
#ifndef CONFIG_USBDEV_MSC_STACKSIZE
#define CONFIG_USBDEV_MSC_STACKSIZE 2048
#endif
#ifndef CONFIG_USBDEV_MTP_MAX_BUFSIZE
#define CONFIG_USBDEV_MTP_MAX_BUFSIZE 2048
#endif
#ifndef CONFIG_USBDEV_MTP_MAX_OBJECTS
#define CONFIG_USBDEV_MTP_MAX_OBJECTS 256
#endif
#ifndef CONFIG_USBDEV_MTP_MAX_PATHNAME
#define CONFIG_USBDEV_MTP_MAX_PATHNAME 256
#endif
#define CONFIG_USBDEV_MTP_THREAD
#ifndef CONFIG_USBDEV_MTP_PRIO
#define CONFIG_USBDEV_MTP_PRIO 4
#endif
#ifndef CONFIG_USBDEV_MTP_STACKSIZE
#define CONFIG_USBDEV_MTP_STACKSIZE 4096
#endif
#ifndef CONFIG_USBDEV_RNDIS_RESP_BUFFER_SIZE
#define CONFIG_USBDEV_RNDIS_RESP_BUFFER_SIZE 156
#endif
/* rndis transfer buffer size, must be a multiple of (1536 + 44)*/
#ifndef CONFIG_USBDEV_RNDIS_ETH_MAX_FRAME_SIZE
#define CONFIG_USBDEV_RNDIS_ETH_MAX_FRAME_SIZE 1580
#endif
#ifndef CONFIG_USBDEV_RNDIS_VENDOR_ID
#define CONFIG_USBDEV_RNDIS_VENDOR_ID 0x0000ffff
#endif
#ifndef CONFIG_USBDEV_RNDIS_VENDOR_DESC
#define CONFIG_USBDEV_RNDIS_VENDOR_DESC "CherryUSB"
#endif
#define CONFIG_USBDEV_RNDIS_USING_LWIP
#define CONFIG_USBDEV_CDC_ECM_USING_LWIP
/* ================ USB HOST Stack Configuration ================== */
#define CONFIG_USBHOST_MAX_RHPORTS 1
#define CONFIG_USBHOST_MAX_EXTHUBS 1
#define CONFIG_USBHOST_MAX_EHPORTS 4
#define CONFIG_USBHOST_MAX_INTERFACES 8
#define CONFIG_USBHOST_MAX_INTF_ALTSETTINGS 8
#define CONFIG_USBHOST_MAX_ENDPOINTS 4
#define CONFIG_USBHOST_MAX_CDC_ACM_CLASS 4
#define CONFIG_USBHOST_MAX_HID_CLASS 4
#define CONFIG_USBHOST_MAX_MSC_CLASS 2
#define CONFIG_USBHOST_MAX_AUDIO_CLASS 1
#define CONFIG_USBHOST_MAX_VIDEO_CLASS 1
#define CONFIG_USBHOST_DEV_NAMELEN 16
#ifndef CONFIG_USBHOST_PSC_PRIO
#define CONFIG_USBHOST_PSC_PRIO 0
#endif
#ifndef CONFIG_USBHOST_PSC_STACKSIZE
#define CONFIG_USBHOST_PSC_STACKSIZE 2048
#endif
//#define CONFIG_USBHOST_GET_STRING_DESC
// #define CONFIG_USBHOST_MSOS_ENABLE
#ifndef CONFIG_USBHOST_MSOS_VENDOR_CODE
#define CONFIG_USBHOST_MSOS_VENDOR_CODE 0x00
#endif
/* Ep0 max transfer buffer */
#ifndef CONFIG_USBHOST_REQUEST_BUFFER_LEN
#define CONFIG_USBHOST_REQUEST_BUFFER_LEN 512
#endif
#ifndef CONFIG_USBHOST_CONTROL_TRANSFER_TIMEOUT
#define CONFIG_USBHOST_CONTROL_TRANSFER_TIMEOUT 500
#endif
#ifndef CONFIG_USBHOST_MSC_TIMEOUT
#define CONFIG_USBHOST_MSC_TIMEOUT 5000
#endif
/* This parameter affects usb performance, and depends on (TCP_WND)tcp eceive windows size,
* you can change to 2K ~ 16K and must be larger than TCP RX windows size in order to avoid being overflow.
*/
#ifndef CONFIG_USBHOST_RNDIS_ETH_MAX_RX_SIZE
#define CONFIG_USBHOST_RNDIS_ETH_MAX_RX_SIZE (2048)
#endif
/* Because lwip do not support multi pbuf at a time, so increasing this variable has no performance improvement */
#ifndef CONFIG_USBHOST_RNDIS_ETH_MAX_TX_SIZE
#define CONFIG_USBHOST_RNDIS_ETH_MAX_TX_SIZE (2048)
#endif
/* This parameter affects usb performance, and depends on (TCP_WND)tcp eceive windows size,
* you can change to 2K ~ 16K and must be larger than TCP RX windows size in order to avoid being overflow.
*/
#ifndef CONFIG_USBHOST_CDC_NCM_ETH_MAX_RX_SIZE
#define CONFIG_USBHOST_CDC_NCM_ETH_MAX_RX_SIZE (2048)
#endif
/* Because lwip do not support multi pbuf at a time, so increasing this variable has no performance improvement */
#ifndef CONFIG_USBHOST_CDC_NCM_ETH_MAX_TX_SIZE
#define CONFIG_USBHOST_CDC_NCM_ETH_MAX_TX_SIZE (2048)
#endif
/* This parameter affects usb performance, and depends on (TCP_WND)tcp eceive windows size,
* you can change to 2K ~ 16K and must be larger than TCP RX windows size in order to avoid being overflow.
*/
#ifndef CONFIG_USBHOST_ASIX_ETH_MAX_RX_SIZE
#define CONFIG_USBHOST_ASIX_ETH_MAX_RX_SIZE (2048)
#endif
/* Because lwip do not support multi pbuf at a time, so increasing this variable has no performance improvement */
#ifndef CONFIG_USBHOST_ASIX_ETH_MAX_TX_SIZE
#define CONFIG_USBHOST_ASIX_ETH_MAX_TX_SIZE (2048)
#endif
/* This parameter affects usb performance, and depends on (TCP_WND)tcp eceive windows size,
* you can change to 2K ~ 16K and must be larger than TCP RX windows size in order to avoid being overflow.
*/
#ifndef CONFIG_USBHOST_RTL8152_ETH_MAX_RX_SIZE
#define CONFIG_USBHOST_RTL8152_ETH_MAX_RX_SIZE (2048)
#endif
/* Because lwip do not support multi pbuf at a time, so increasing this variable has no performance improvement */
#ifndef CONFIG_USBHOST_RTL8152_ETH_MAX_TX_SIZE
#define CONFIG_USBHOST_RTL8152_ETH_MAX_TX_SIZE (2048)
#endif
#define CONFIG_USBHOST_BLUETOOTH_HCI_H4
// #define CONFIG_USBHOST_BLUETOOTH_HCI_LOG
#ifndef CONFIG_USBHOST_BLUETOOTH_TX_SIZE
#define CONFIG_USBHOST_BLUETOOTH_TX_SIZE 2048
#endif
#ifndef CONFIG_USBHOST_BLUETOOTH_RX_SIZE
#define CONFIG_USBHOST_BLUETOOTH_RX_SIZE 2048
#endif
/* ================ USB Device Port Configuration ================*/
#ifndef CONFIG_USBDEV_MAX_BUS
#define CONFIG_USBDEV_MAX_BUS 1 // for now, bus num must be 1 except hpm ip
#endif
#ifndef CONFIG_USBDEV_EP_NUM
#define CONFIG_USBDEV_EP_NUM 8
#endif
// #define CONFIG_USBDEV_SOF_ENABLE
/* ---------------- DWC2 Configuration ---------------- */
/* enable dwc2 buffer dma mode for device
*/
// #define CONFIG_USB_DWC2_DMA_ENABLE
/* Defined FS Core device FIFO Size in words 32-bits */
#define CONFIG_USB_FS_CORE_DEVICE_RX_FIFO_SIZE (128)
#define CONFIG_USB_FS_CORE_DEVICE_TX0_FIFO_SIZE (32)
#define CONFIG_USB_FS_CORE_DEVICE_TX1_FIFO_SIZE (32)
#define CONFIG_USB_FS_CORE_DEVICE_TX2_FIFO_SIZE (32)
#define CONFIG_USB_FS_CORE_DEVICE_TX3_FIFO_SIZE (32)
#define CONFIG_USB_FS_CORE_DEVICE_TX4_FIFO_SIZE (32)
#define CONFIG_USB_FS_CORE_DEVICE_TX5_FIFO_SIZE (32)
/* Defined FS Core host FIFO Size in words 32-bits */
#define CONFIG_USB_FS_CORE_HOST_RX_FIFO_SIZE (128)
#define CONFIG_USB_FS_CORE_HOST_NP_FIFO_SIZE (32)
#define CONFIG_USB_FS_CORE_HOST_PE_FIFO_SIZE (64)
/* Defined FS Core total FIFO Size in words 32-bits */
#define CONFIG_USB_FS_CORE_TOTAL_FIFO_SIZE (320)
/* ================ USB Host Port Configuration ==================*/
#ifndef CONFIG_USBHOST_MAX_BUS
#define CONFIG_USBHOST_MAX_BUS 1
#endif
#ifndef CONFIG_USBHOST_PIPE_NUM
#define CONFIG_USBHOST_PIPE_NUM 10
#endif
#ifndef usb_phyaddr2ramaddr
#define usb_phyaddr2ramaddr(addr) (addr)
#endif
#ifndef usb_ramaddr2phyaddr
#define usb_ramaddr2phyaddr(addr) (addr)
#endif
#endif

View File

@@ -0,0 +1,112 @@
scons --attach=devices.adc
scons -j4
scons --attach=default
scons --attach=devices.can
scons -j4
scons --attach=default
scons --attach=devices.crypto
scons -j4
scons --attach=default
scons --attach=devices.flash
scons -j4
scons --attach=default
scons --attach=devices.gpio
scons -j4
scons --attach=default
scons --attach=devices.hwtimer
scons -j4
scons --attach=default
scons --attach=devices.i2c
scons -j4
scons --attach=default
scons --attach=devices.input_capture
scons -j4
scons --attach=default
scons --attach=devices.pm
scons -j4
scons --attach=default
scons --attach=devices.pulse_encoder_tmr6
scons -j4
scons --attach=default
scons --attach=devices.pulse_encoder_tmra
scons -j4
scons --attach=default
scons --attach=devices.pwm_tmr4
scons -j4
scons --attach=default
scons --attach=devices.pwm_tmr6
scons -j4
scons --attach=default
scons --attach=devices.pwm_tmra
scons -j4
scons --attach=default
scons --attach=devices.qspi
scons -j4
scons --attach=default
scons --attach=devices.rtc
scons -j4
scons --attach=default
scons --attach=devices.sdio
scons -j4
scons --attach=default
scons --attach=devices.soft_i2c
scons -j4
scons --attach=default
scons --attach=devices.spi
scons -j4
scons --attach=default
scons --attach=devices.uart_v1
scons -j4
scons --attach=default
scons --attach=devices.uart_v2
scons -j4
scons --attach=default
scons --attach=devices.usb_hs_device
scons -j4
scons --attach=default
scons --attach=devices.usb_hs_host
scons -j4
scons --attach=default
scons --attach=devices.usb_fs_device
scons -j4
scons --attach=default
scons --attach=devices.usb_fs_host
scons -j4
scons --attach=default
scons --attach=devices.watchdog_swdt
scons -j4
scons --attach=default
scons --attach=devices.watchdog_wdt
scons -j4
scons --attach=default
scons --attach=peripheral.spi_flash
scons -j4
scons --attach=default

View File

@@ -323,7 +323,7 @@
<uThumb>0</uThumb>
<uSurpInc>0</uSurpInc>
<uC99>1</uC99>
<uGnu>0</uGnu>
<uGnu>1</uGnu>
<useXO>0</useXO>
<v6Lang>0</v6Lang>
<v6LangP>0</v6LangP>

View File

@@ -326,7 +326,7 @@
<uThumb>0</uThumb>
<uSurpInc>0</uSurpInc>
<uC99>1</uC99>
<uGnu>0</uGnu>
<uGnu>1</uGnu>
<useXO>0</useXO>
<v6Lang>0</v6Lang>
<v6LangP>0</v6LangP>

View File

@@ -1,12 +1,166 @@
# ------ device CI ------
devices.adc:
kconfig:
- CONFIG_BSP_USING_ADC=y
- CONFIG_BSP_USING_ADC1=y
- CONFIG_BSP_ADC1_USING_DMA=y
devices.can:
kconfig:
- CONFIG_BSP_USING_CAN=y
- CONFIG_BSP_USING_CAN1=y
- CONFIG_RT_CAN_USING_CANFD=y
- CONFIG_RT_CAN_USING_HDR=y
devices.crypto:
kconfig:
- CONFIG_BSP_USING_HWCRYPTO=y
- CONFIG_BSP_USING_UQID=y
- CONFIG_BSP_USING_RNG=y
- CONFIG_BSP_USING_CRC=y
- CONFIG_BSP_USING_AES=y
- CONFIG_BSP_USING_HASH=y
devices.dac:
kconfig:
- CONFIG_BSP_USING_DAC=y
- CONFIG_BSP_USING_DAC1=y
devices.flash:
kconfig:
- CONFIG_BSP_USING_ON_CHIP_FLASH=y
- CONFIG_RT_USING_FAL=y
- CONFIG_RT_USING_SPI=y
- CONFIG_RT_USING_SFUD=y
devices.gpio:
kconfig:
- CONFIG_BSP_USING_GPIO=y
- CONFIG_BSP_USING_I2C=y
- CONFIG_BSP_USING_I2C_HW=y
- CONFIG_BSP_USING_I2C1=y
- CONFIG_BSP_USING_TCA9539=y
- CONFIG_BSP_USING_EXT_IO=y
devices.uart:
devices.hwtimer:
kconfig:
- CONFIG_BSP_USING_HWTIMER=y
- CONFIG_BSP_USING_TMRA_1=y
devices.i2c:
kconfig:
- CONFIG_BSP_USING_I2C=y
- CONFIG_BSP_USING_I2C1=y
- CONFIG_BSP_I2C1_TX_USING_DMA=y
- CONFIG_BSP_I2C1_RX_USING_DMA=y
devices.input_capture:
kconfig:
- CONFIG_BSP_USING_INPUT_CAPTURE=y
- CONFIG_BSP_USING_INPUT_CAPTURE_TMR6=y
- CONFIG_BSP_USING_INPUT_CAPTURE_TMR6_1=y
devices.pm:
kconfig:
- CONFIG_BSP_USING_PM=y
- CONFIG_IDLE_THREAD_STACK_SIZE=512
devices.pulse_encoder_tmr6:
kconfig:
- CONFIG_BSP_USING_PULSE_ENCODER=y
- CONFIG_BSP_USING_TMR6_PULSE_ENCODER=y
- CONFIG_BSP_USING_PULSE_ENCODER_TMR6_1=y
devices.pulse_encoder_tmra:
kconfig:
- CONFIG_BSP_USING_PULSE_ENCODER=y
- CONFIG_BSP_USING_TMRA_PULSE_ENCODER=y
- CONFIG_BSP_USING_PULSE_ENCODER_TMRA_1=y
devices.pwm_tmr4:
kconfig:
- CONFIG_BSP_USING_PWM=y
- CONFIG_BSP_USING_PWM_TMR4=y
- CONFIG_BSP_USING_PWM_TMR4_1=y
- CONFIG_BSP_USING_PWM_TMR4_1_OUH=y
- CONFIG_BSP_USING_PWM_TMR4_1_OUL=y
devices.pwm_tmr6:
kconfig:
- CONFIG_BSP_USING_PWM=y
- CONFIG_BSP_USING_PWM_TMR6=y
- CONFIG_BSP_USING_PWM_TMR6_1=y
- CONFIG_BSP_USING_PWM_TMR6_1_A=y
- CONFIG_BSP_USING_PWM_TMR6_1_B=y
devices.pwm_tmra:
kconfig:
- CONFIG_BSP_USING_PWM=y
- CONFIG_BSP_USING_PWM_TMRA=y
- CONFIG_BSP_USING_PWM_TMRA_1=y
- CONFIG_BSP_USING_PWM_TMRA_1_CH1=y
- CONFIG_BSP_USING_PWM_TMRA_1_CH2=y
devices.qspi:
kconfig:
- CONFIG_BSP_USING_QSPI=y
- CONFIG_BSP_QSPI_USING_DMA=y
- CONFIG_BSP_QSPI_USING_SOFT_CS=y
devices.rtc:
kconfig:
- CONFIG_BSP_USING_RTC=y
- CONFIG_RT_USING_ALARM=y
devices.soft_i2c:
kconfig:
- CONFIG_BSP_USING_I2C=y
- CONFIG_BSP_USING_I2C1_SW=y
devices.spi:
kconfig:
- CONFIG_BSP_USING_SPI=y
- CONFIG_BSP_USING_SPI1=y
- CONFIG_BSP_SPI1_TX_USING_DMA=y
- CONFIG_BSP_SPI1_RX_USING_DMA=y
- CONFIG_BSP_SPI_USING_DMA=y
- CONFIG_RT_USING_DFS=y
- CONFIG_RT_USING_DFS_ELMFAT=y
devices.uart_v1:
kconfig:
- CONFIG_RT_USING_SERIAL_V1=y
- CONFIG_BSP_USING_UART=y
- CONFIG_BSP_USING_UART2=y
- CONFIG_BSP_USING_UART1=y
- CONFIG_RT_SERIAL_USING_DMA=y
- CONFIG_BSP_UART1_RX_USING_DMA=y
- CONFIG_BSP_UART1_TX_USING_DMA=y
devices.uart_v2:
kconfig:
- CONFIG_RT_USING_SERIAL_V2=y
- CONFIG_BSP_USING_UART=y
- CONFIG_BSP_USING_UART1=y
- CONFIG_RT_SERIAL_USING_DMA=y
- CONFIG_BSP_UART1_RX_USING_DMA=y
- CONFIG_BSP_UART1_TX_USING_DMA=y
devices.usb_hs_device:
kconfig:
- CONFIG_BSP_USING_USB=y
- CONFIG_BSP_USING_USBD=y
- CONFIG_BSP_USING_USBHS=y
- CONFIG_BSP_USING_USBD_HS=y
- CONFIG_RT_USB_DEVICE_MSTORAGE=y
devices.usb_hs_host:
kconfig:
- CONFIG_BSP_USING_USB=y
- CONFIG_BSP_USING_USBH=y
- CONFIG_BSP_USING_USBHS=y
- CONFIG_BSP_USING_USBH_HS=y
- CONFIG_RT_USBH_MSTORAGE=y
- CONFIG_RT_USING_DFS=y
- CONFIG_RT_USING_DFS_ELMFAT=y
devices.usb_fs_device:
kconfig:
- CONFIG_BSP_USING_USB=y
- CONFIG_BSP_USING_USBD=y
- CONFIG_BSP_USING_USBFS=y
- CONFIG_BSP_USING_USBD_FS=y
- CONFIG_RT_USB_DEVICE_MSTORAGE=y
devices.usb_fs_host:
kconfig:
- CONFIG_BSP_USING_USB=y
- CONFIG_BSP_USING_USBH=y
- CONFIG_BSP_USING_USBFS=y
- CONFIG_BSP_USING_USBH_FS=y
- CONFIG_RT_USBH_MSTORAGE=y
- CONFIG_RT_USING_DFS=y
- CONFIG_RT_USING_DFS_ELMFAT=y
devices.watchdog_swdt:
kconfig:
- CONFIG_BSP_USING_WDT_TMR=y
- CONFIG_BSP_USING_SWDT=y
devices.watchdog_wdt:
kconfig:
- CONFIG_BSP_USING_WDT_TMR=y
- CONFIG_BSP_USING_WDT=y
# ------ peripheral CI ------
peripheral.spi_flash:
kconfig:
- CONFIG_BSP_USING_SPI_FLASH=y

View File

@@ -1,8 +1,8 @@
# XHSC EV_F472_LQ80_Rev1.0 开发板 BSP 说明
# XHSC EV_F472_LQ100 开发板 BSP 说明
## 简介
本文档为小华半导体为 EV_F472_LQ80_Rev1.0 开发板提供的 BSP (板级支持包) 说明。
本文档为小华半导体为 EV_F472_LQ100 开发板提供的 BSP (板级支持包) 说明。
主要内容如下:
@@ -14,69 +14,66 @@
## 开发板介绍
EV_F472_LQ80_Rev1.0 是 XHSC 官方推出的开发板,搭载 HC32F472PETI 芯片,基于 ARM Cortex-M4 内核,最高主频 200 MHz具有丰富的板载资源可以充分发挥 HC32F472PETI 的芯片性能。
EV_F472_LQ100 是 XHSC 官方推出的开发板,搭载 HC32F472PETI 芯片,基于 ARM Cortex-M4 内核,最高主频 200 MHz具有丰富的板载资源可以充分发挥 HC32F472PETI 的芯片性能。
开发板外观如下图所示:
![board](figures/board.png)
EV_F472_LQ80_Rev1.0 开发板常用 **板载资源** 如下:
EV_F472_LQ100 开发板常用 **板载资源** 如下:
- **MCU**
- HC32F472PETI
- 主频200MHz
- 256KB FLASH
- 68KB RAM
- **外部Memory**
- BL24C256EEPROM, 256Kbits
- W25Q64SPI NOR64MB
- IS62WV51216SRAM 1MB
- **常用外设**
- LED: 4 个User LEDLED0LED1LED2LED3
- 按键: 5 个矩阵键盘K1~K4 WAKEUPK5RESETK0
- **常用接口**
- USB转串口
- CAN DB9接口 * 2
- TFT接口
- SmartCard接口
- I2C/USART/SPI接口
- **调试接口**
- 板载DAP调试器
- 标准JTAG/SWD/Trace
- MCUHC32F472PETI主频200MHz256KB FLASH68KB RAM
- 外部RAMIS62WV51216(SRAM1MB)
- 常用外设
- LED3 个User LED(LED0、LED1、LED2)。
- 按键11 个,矩阵键盘(K1~K9)、WAKEUP(K10)、RESET(K0)。
- 常用接口LCD接口、USB FS接口、CAN接口、LIN接口。
- 调试接口板载DAP调试器含USB转串口、标准JTAG/SWD。
开发板更多详细信息请参考小华半导体半导体[EV_F472_LQ80_Rev1.0](https://www.xhsc.com.cn)
开发板更多详细信息请参考小华半导体半导体[EV_F472_LQ100](https://www.xhsc.com.cn)
## 外设支持
本 BSP 目前对外设的支持情况如下:
| **板载外设** | **支持情况** | **备注** |
|:-------- |:--------:|:--------:|
| USB 转串口 | 支持 | 使用 UART2 |
| LED | 支持 | LED1~4 |
| **板载外设** | **支持情况** | **备注** |
| :------------ | :-----------: | :-----------------------------------: |
| USB 转串口 | 支持 | 使用 UART2 |
| **片上外设** | **支持情况** | **备注** |
|:-------- |:--------:|:------------------------------------------:|
| ADC | 支持 | ADC1: CH10, CH11, <br>ADC3: CH1 |
| CAN | 支持 | CAN1、CAN2 |
| GPIO | 支持 | PA0, PA1... PH2 ---> PIN: 0, 1...82 |
| I2C | 支持 | 软件模拟<br>硬件I2C1~2<br>I2C1支持EEPROMBL24C256 |
| Hwtimer | 支持 | Hwtimer1~5 |
| SPI | 支持 | SPI1~3<br>SPI1支持W25Q |
| UART | 支持 | UART1~6<br>UART2为console使用 |
| **片上外设** | **支持情况** | **备注** |
| :------------ | :-----------: | :-----------------------------------: |
| ADC | 支持 | |
| CAN | 支持 | |
| Crypto | 支持 | AESCRCHASHRNG |
| DAC | 支持 | |
| FLASH | 支持 | |
| GPIO | 支持 | PA0PA1... PF8 ---> PIN01...89 |
| HwTimer | 支持 | |
| I2C | 支持 | 软件、硬件 I2C |
| InputCapture | 支持 | |
| PM | 支持 | |
| PulseEncoder | 支持 | |
| PWM | 支持 | |
| QSPI | 支持 | |
| RTC | 支持 | 闹钟精度为1分钟 |
| SPI | 支持 | |
| UART V1 & V2 | 支持 | |
| USB | 支持 | USBFS Core device/host模式 |
| WDT | 支持 | |
## 使用说明
使用说明分为如下两个章节:
- 快速上手
本章节是为刚接触 RT-Thread 的新手准备的使用说明,遵循简单的步骤即可将 RT-Thread 操作系统运行在该开发板上,看到实验效果 。
- 进阶使用
本章节是为需要在 RT-Thread 操作系统上使用更多开发板资源的开发者准备的。通过使用 ENV 工具对 BSP 进行配置,可以开启更多板载资源,实现更多高级功能。
### 快速上手
本 BSP 为开发者提供 MDK5 和 IAR 工程,并且支持 GCC 开发环境。下面以 MDK5 开发环境为例,介绍如何将系统运行起来。
@@ -93,14 +90,14 @@ EV_F472_LQ80_Rev1.0 开发板常用 **板载资源** 如下:
#### 运行结果
下载程序成功之后系统会自动运行观察开发板上LED的运行效果绿色LED3会周期性闪烁。
下载程序成功之后系统会自动运行观察开发板上LED的运行效果绿色LED5会周期性闪烁。
USB虚拟COM端口默认连接串口2在终端工具里打开相应的串口复位设备后可以看到 RT-Thread 的输出信息:
```
\ | /
- RT - Thread Operating System
/ | \ 5.0.1 build Feb 4 2024 16:44:26
/ | \ 4.1.0 build Apr 24 2022 13:32:39
2006 - 2022 Copyright by RT-Thread team
msh >
```
@@ -119,13 +116,16 @@ msh >
## 注意事项
| 板载外设 | 模式 | 注意事项 |
| -------- | ------ | ------------------------------------------------------------ |
| USB | device | 由于RTT抽象层的设计当配置为CDC设备时打开USB虚拟串口需使能流控的DTR信号。如使用SSCOM串口助手打开USB虚拟串口时勾选DTR选框 |
| USB | host | 由于main()函数中的LED闪烁示例使用的是USBFS主机的供电控制管脚,因而当配置为使用USBFS 的主机模式需要将main()函数中的LED示例代码手动屏蔽。 |
| USB | host | 若配置为U盘主机模式出现部分U盘无法识别或者写入失败时可以尝试将RTT抽象层中rt_udisk_run()函数的rt_usbh_storage_reset()操作注释掉,测试是否可以获得更好的兼容性。 |
| USB | host | 为确保USB主机对外供电充足建议通过J7外接5V电源供电并短接J8的VIN跳帽。 |
| USB | host | 目前仅实现并测试了对U盘的支持。 |
| 板载外设 | 模式 | 协议栈 | 注意事项 |
| -------- | ------ | :------------: | ------------------------------------------------------------ |
| USB | device | ALL | 由于协议栈的设计当配置为CDC设备时打开USB虚拟串口需使能流控的DTR信号。如使用SSCOM串口助手打开USB虚拟串口时勾选DTR选框 |
| USB | ALL | ALL | 由于main()函数中的LED闪烁示例使用的是USBFS主机的供电控制管脚因而当使用USBFS时需要将main()函数中的LED示例代码手动屏蔽。 |
| USB | host | RTT legacy USB | 若配置为U盘主机模式出现部分U盘无法识别或者写入失败时可以尝试将RTT抽象层中rt_udisk_run()函数的rt_usbh_storage_reset()操作注释掉,测试是否可以获得更好的兼容性。 |
| USB | host | ALL | 为确保USB主机对外供电充足建议通过J7外接5V电源供电并短接J8的VIN跳帽。 |
| USB | host | RTT legacy USB | 目前仅实现并测试了对U盘的支持。 |
| USB | ALL | ALL | CherryUSB 与 RTT legacy USB 组件不可同时使用;<br />CherryUSB与 ”On-Chip Peripheral Driver---> []Enable USB“ 不可同时使能及配置。 |
| USB | ALL | RTT legacy USB | 通过“board/config/usb_config/usb_app_conf.h” 进行应用个性化配置主要为FIFO分配 |
| USB | ALL | CherryUSB | 通过“board/ports/usb_config.h”进行应用个性化配置如FIFO分配、是否使用DMA[Device]等) |
## 联系人信息

View File

@@ -90,7 +90,7 @@ menu "On-chip Peripheral Drivers"
int "Set UART1 RX DMA ping-pong buffer size"
range 32 65535
depends on RT_USING_SERIAL_V2 && BSP_UART1_RX_USING_DMA
default 64
default 64
endif
menuconfig BSP_USING_UART2
@@ -123,7 +123,7 @@ menu "On-chip Peripheral Drivers"
int "Set UART2 RX DMA ping-pong buffer size"
range 32 65535
depends on RT_USING_SERIAL_V2 && BSP_UART2_RX_USING_DMA
default 64
default 64
endif
menuconfig BSP_USING_UART3
@@ -173,7 +173,7 @@ menu "On-chip Peripheral Drivers"
int "Set UART4 RX DMA ping-pong buffer size"
range 32 65535
depends on RT_USING_SERIAL_V2 && BSP_UART4_RX_USING_DMA
default 64
default 64
endif
menuconfig BSP_USING_UART5
@@ -206,7 +206,7 @@ menu "On-chip Peripheral Drivers"
int "Set UART5 RX DMA ping-pong buffer size"
range 32 65535
depends on RT_USING_SERIAL_V2 && BSP_UART5_RX_USING_DMA
default 64
default 64
endif
menuconfig BSP_USING_UART6
@@ -634,6 +634,38 @@ menu "On-chip Peripheral Drivers"
endif
endif
menuconfig BSP_USING_INPUT_CAPTURE
bool "Enable Input Capture"
default n
select RT_USING_INPUT_CAPTURE
if BSP_USING_INPUT_CAPTURE
menuconfig BSP_USING_INPUT_CAPTURE_TMR6
bool "Use Timer6 As The Input Capture"
default n
if BSP_USING_INPUT_CAPTURE_TMR6
config BSP_USING_INPUT_CAPTURE_TMR6_1
bool "unit 1"
config BSP_USING_INPUT_CAPTURE_TMR6_2
bool "unit 2"
config BSP_USING_INPUT_CAPTURE_TMR6_3
bool "unit 3"
config BSP_USING_INPUT_CAPTURE_TMR6_4
bool "unit 4"
config BSP_USING_INPUT_CAPTURE_TMR6_5
bool "unit 5"
config BSP_USING_INPUT_CAPTURE_TMR6_6
bool "unit 6"
config BSP_USING_INPUT_CAPTURE_TMR6_7
bool "unit 7"
config BSP_USING_INPUT_CAPTURE_TMR6_8
bool "unit 8"
config BSP_USING_INPUT_CAPTURE_TMR6_9
bool "unit 9"
config BSP_USING_INPUT_CAPTURE_TMR6_10
bool "unit 10"
endif
endif
menuconfig BSP_USING_QSPI
bool "Enable QSPI BUS"
select RT_USING_QSPI
@@ -710,6 +742,7 @@ menu "On-chip Peripheral Drivers"
menuconfig BSP_USING_USB
bool "Enable USB"
default n
depends on !RT_USING_CHERRYUSB
select RT_USING_USB_DEVICE if BSP_USING_USBD
select RT_USING_USB_HOST if BSP_USING_USBH
if BSP_USING_USB

View File

@@ -118,7 +118,7 @@ void PeripheralClock_Config(void)
#if defined(RT_USING_ADC)
CLK_SetPeriClockSrc(CLK_PERIPHCLK_PCLK);
#endif
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH)
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH) || defined(RT_USING_CHERRYUSB)
CLK_SetUSBClockSrc(CLK_USBCLK_PLLQ);
#endif
}

View File

@@ -342,6 +342,36 @@ rt_err_t rt_hw_board_pwm_tmr6_init(CM_TMR6_TypeDef *TMR6x)
#endif
#endif
#if defined (BSP_USING_INPUT_CAPTURE)
rt_err_t rt_hw_board_input_capture_init(uint32_t *tmr_instance)
{
rt_err_t result = RT_EOK;
switch ((rt_uint32_t)tmr_instance)
{
#if defined (BSP_USING_INPUT_CAPTURE_TMR6_1)
case (rt_uint32_t)CM_TMR6_1:
GPIO_SetFunc(INPUT_CAPTURE_TMR6_1_PORT, INPUT_CAPTURE_TMR6_1_PIN, INPUT_CAPTURE_TMR6_1_FUNC);
break;
#endif
#if defined (BSP_USING_INPUT_CAPTURE_TMR6_2)
case (rt_uint32_t)CM_TMR6_2:
GPIO_SetFunc(INPUT_CAPTURE_TMR6_2_PORT, INPUT_CAPTURE_TMR6_2_PIN, INPUT_CAPTURE_TMR6_2_FUNC);
break;
#endif
#if defined (BSP_USING_INPUT_CAPTURE_TMR6_10)
case (rt_uint32_t)CM_TMR6_10:
GPIO_SetFunc(INPUT_CAPTURE_TMR6_10_PORT, INPUT_CAPTURE_TMR6_10_PIN, INPUT_CAPTURE_TMR6_10_FUNC);
break;
#endif
default:
result = -RT_ERROR;
break;
}
return result;
}
#endif
#ifdef RT_USING_PM
#define PLL_SRC ((CM_CMU->PLLHCFGR & CMU_PLLHCFGR_PLLSRC) >> CMU_PLLHCFGR_PLLSRC_POS)
@@ -424,3 +454,26 @@ rt_err_t rt_hw_usbfs_board_init(void)
return RT_EOK;
}
#endif
#if defined(RT_USING_CHERRYUSB)
rt_err_t rt_hw_usbfs_board_init(uint8_t devmode)
{
stc_gpio_init_t stcGpioCfg;
(void)GPIO_StructInit(&stcGpioCfg);
stcGpioCfg.u16PinAttr = PIN_ATTR_ANALOG;
(void)GPIO_Init(USBF_DM_PORT, USBF_DM_PIN, &stcGpioCfg);
(void)GPIO_Init(USBF_DP_PORT, USBF_DP_PIN, &stcGpioCfg);
if (0U != devmode)
{
/* reserved */
}
else
{
GPIO_OutputCmd(USBF_DRVVBUS_PORT, USBF_DRVVBUS_PIN, ENABLE);
GPIO_SetPins(USBF_DRVVBUS_PORT, USBF_DRVVBUS_PIN); /* DRV VBUS with GPIO funciton */
}
return RT_EOK;
}
#endif

View File

@@ -16,7 +16,9 @@
#include <rtconfig.h>
#include "hc32_ll.h"
#include "drv_config.h"
#if defined(RT_USING_CHERRYUSB)
#include "usb_config.h"
#endif
/************************* XTAL port **********************/
#define XTAL_PORT (GPIO_PORT_F)
@@ -292,6 +294,24 @@
#endif
#if defined(BSP_USING_INPUT_CAPTURE)
#if defined(BSP_USING_INPUT_CAPTURE_TMR6_1)
#define INPUT_CAPTURE_TMR6_1_PORT (GPIO_PORT_A)
#define INPUT_CAPTURE_TMR6_1_PIN (GPIO_PIN_00)
#define INPUT_CAPTURE_TMR6_1_FUNC (GPIO_FUNC_11)
#endif
#if defined(BSP_USING_INPUT_CAPTURE_TMR6_2)
#define INPUT_CAPTURE_TMR6_2_PORT (GPIO_PORT_B)
#define INPUT_CAPTURE_TMR6_2_PIN (GPIO_PIN_02)
#define INPUT_CAPTURE_TMR6_2_FUNC (GPIO_FUNC_12)
#endif
#if defined(BSP_USING_INPUT_CAPTURE_TMR6_10)
#define INPUT_CAPTURE_TMR6_10_PORT (GPIO_PORT_A)
#define INPUT_CAPTURE_TMR6_10_PIN (GPIO_PIN_12)
#define INPUT_CAPTURE_TMR6_10_FUNC (GPIO_FUNC_11)
#endif
#endif
#if defined(BSP_USING_QSPI)
#ifndef BSP_QSPI_USING_SOFT_CS
/* QSSN */
@@ -346,8 +366,15 @@
#endif /* BSP_USING_TMR6_PULSE_ENCODER */
#endif /* RT_USING_PULSE_ENCODER */
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH)
#if defined(BSP_USING_USBFS)
#if defined(RT_USING_CHERRYUSB)
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH) || \
defined(BSP_USING_USBFS) || defined(RT_USING_USB)
#error "When using CherryUSB, Please donot Enable 'On-Chip Peripheral Driver---> []Enable USB' or using USB legacy version!"
#endif
#endif
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH) || defined(RT_USING_CHERRYUSB)
#if defined(BSP_USING_USBFS) || defined(RT_USING_CHERRYUSB)
/* USBFS Core*/
#define USBF_DP_PORT (GPIO_PORT_A)
#define USBF_DP_PIN (GPIO_PIN_12)

View File

@@ -316,11 +316,28 @@ extern "C" {
#define BSP_PULSE_ENCODER_TMR6_10_UDF_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif/* BSP_USING_PULSE_ENCODER_TMR6_10 */
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH)
#if defined(BSP_USING_USBD) || defined(BSP_USING_USBH) || defined(RT_USING_CHERRYUSB)
#define BSP_USBFS_GLB_IRQ_NUM USBFS_GLB_IRQn
#define BSP_USBFS_GLB_IRQ_PRIO DDL_IRQ_PRIO_DEFAULT
#endif
#if defined(BSP_USING_INPUT_CAPTURE)
#define BSP_INPUT_CAPTURE_TMR6_1_OVF_IRQ_NUM (INT012_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_1_OVF_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_1_CAP_IRQ_NUM (INT013_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_1_CAP_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_2_OVF_IRQ_NUM (INT014_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_2_OVF_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_2_CAP_IRQ_NUM (INT015_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_2_CAP_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_10_OVF_IRQ_NUM (INT010_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_10_OVF_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#define BSP_INPUT_CAPTURE_TMR6_10_CAP_IRQ_NUM (INT011_IRQn)
#define BSP_INPUT_CAPTURE_TMR6_10_CAP_IRQ_PRIO (DDL_IRQ_PRIO_DEFAULT)
#endif/* BSP_USING_INPUT_CAPTURE */
#ifdef __cplusplus
}
#endif

Some files were not shown because too many files have changed in this diff Show More