mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2026-02-06 09:02:20 +08:00
Update bsp drivers for F334.
This commit is contained in:
@@ -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 的制作方法 |
|
||||
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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 的芯片性能。
|
||||
|
||||
开发板外观如下图所示:
|
||||
|
||||

|
||||
|
||||
EV_F334_LQ64_Rev1.0 开发板常用 **板载资源** 如下:
|
||||
EV_F334_LQ64 开发板常用 **板载资源** 如下:
|
||||
|
||||
- **MCU**
|
||||
- HC32F334MCTI
|
||||
- 主频200MHz
|
||||
- 256KB FLASH
|
||||
- 68KB RAM
|
||||
- **外部Memory**
|
||||
- BL24C256(EEPROM, 256Kbits)
|
||||
- W25Q64(SPI NOR,64MB)
|
||||
- IS62WV51216(SRAM, 1MB)
|
||||
- **常用外设**
|
||||
- LED: 4 个,User LED(LED0,LED1,LED2,LED3)。
|
||||
- 按键: 5 个,矩阵键盘(K1~K4), WAKEUP(K5),RESET(K0)
|
||||
- **常用接口**
|
||||
- USB转串口
|
||||
- CAN DB9接口 * 2
|
||||
- TFT接口
|
||||
- SmartCard接口
|
||||
- I2C/USART/SPI接口
|
||||
- **调试接口**
|
||||
- 板载DAP调试器
|
||||
- 标准JTAG/SWD/Trace
|
||||
- MCU:HC32F334KATI,主频120MHz,128KB FLASH,36KB RAM
|
||||
- 常用外设
|
||||
- LED:2 个,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支持EEPROM(BL24C256) |
|
||||
| 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 | 支持 | PA0,PA1...PF3 ---> PIN:0,1...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()操作注释掉,测试是否可以获得更好的兼容性。 |
|
||||
|
||||
## 联系人信息
|
||||
|
||||
维护人:
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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;
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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
|
||||
|
||||
|
||||
@@ -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, \
|
||||
}
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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*/
|
||||
|
||||
@@ -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 */
|
||||
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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###*/
|
||||
|
||||
/*******************************************************************************
|
||||
|
||||
91
bsp/hc32/ev_hc32f334_lqfp64/bsp_compile_ci.bat
Normal file
91
bsp/hc32/ev_hc32f334_lqfp64/bsp_compile_ci.bat
Normal 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 |
@@ -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>
|
||||
|
||||
@@ -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>
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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 的芯片性能。
|
||||
|
||||
开发板外观如下图所示:
|
||||
|
||||

|
||||
|
||||
EV_F448_LQ80_Rev1.0 开发板常用 **板载资源** 如下:
|
||||
EV_F448_LQ80 开发板常用 **板载资源** 如下:
|
||||
|
||||
- **MCU**
|
||||
- HC32F448MCTI
|
||||
- 主频200MHz
|
||||
- 256KB FLASH
|
||||
- 68KB RAM
|
||||
- **外部Memory**
|
||||
- BL24C256(EEPROM, 256Kbits)
|
||||
- W25Q64(SPI NOR,64MB)
|
||||
- IS62WV51216(SRAM, 1MB)
|
||||
- **常用外设**
|
||||
- LED: 4 个,User LED(LED0,LED1,LED2,LED3)。
|
||||
- 按键: 5 个,矩阵键盘(K1~K4), WAKEUP(K5),RESET(K0)
|
||||
- **常用接口**
|
||||
- USB转串口
|
||||
- CAN DB9接口 * 2
|
||||
- TFT接口
|
||||
- SmartCard接口
|
||||
- I2C/USART/SPI接口
|
||||
- **调试接口**
|
||||
- 板载DAP调试器
|
||||
- 标准JTAG/SWD/Trace
|
||||
- MCU:HC32F448MCTI,主频200MHz,256KB FLASH,68KB RAM
|
||||
- 外部RAM:IS61LV6416(SRAM, 128KB)
|
||||
- 常用外设
|
||||
- LED:3 个,User LED(LED0、LED1、LED2)
|
||||
- 按键:6个,矩阵键盘(K1~K4), WAKEUP(K5),RESET(K0)
|
||||
- 常用接口: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支持EEPROM(BL24C256) |
|
||||
| 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,HASH,RNG |
|
||||
| DAC | 支持 | |
|
||||
| FLASH | 支持 | |
|
||||
| GPIO | 支持 | PA0,PA1...PH2 ---> PIN:0,1...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()操作注释掉,测试是否可以获得更好的兼容性。 |
|
||||
|
||||
## 联系人信息
|
||||
|
||||
维护人:
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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)
|
||||
|
||||
@@ -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 */
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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__ */
|
||||
@@ -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
|
||||
}
|
||||
|
||||
@@ -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###*/
|
||||
|
||||
/*******************************************************************************
|
||||
|
||||
96
bsp/hc32/ev_hc32f448_lqfp80/bsp_compile_ci.bat
Normal file
96
bsp/hc32/ev_hc32f448_lqfp80/bsp_compile_ci.bat
Normal 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
|
||||
@@ -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>
|
||||
|
||||
@@ -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>
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -22,12 +22,12 @@ EV_F460_LQ100_V2 是 XHSC 官方推出的开发板,搭载 HC32F460PETB 芯片
|
||||
|
||||
EV_F460_LQ100_V2 开发板常用 **板载资源** 如下:
|
||||
|
||||
- MCU: HC32F460PETB,主频200MHz,512KB FLASH,192KB RAM
|
||||
- MCU:HC32F460PETB,主频200MHz,512KB FLASH,192KB RAM
|
||||
- 常用外设
|
||||
- LED: 4 个,User LED(LED0,LED1,LED2,LED3)。
|
||||
- 按键: 11 个,矩阵键盘(K1~K9), WAKEUP(K10), RESET(K11)
|
||||
- 常用接口: USB转串口、SD卡接口、USB FS、3.5mm耳机接口、Line in接口、喇叭接口
|
||||
- 调试接口: 板载DAP调试器、标准JTAG/SWD
|
||||
- LED:4 个,User LED(LED0、LED1、LED2、LED3)。
|
||||
- 按键: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 | 支持 | CRC,HASH,RNG |
|
||||
| FLASH | 支持 | |
|
||||
| GPIO | 支持 | PA0,PA1... PH2 ---> PIN:0,1...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]等) |
|
||||
|
||||
## 联系人信息
|
||||
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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
|
||||
}
|
||||
|
||||
@@ -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)
|
||||
{
|
||||
|
||||
@@ -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)
|
||||
|
||||
@@ -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 */
|
||||
|
||||
@@ -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###*/
|
||||
|
||||
/*******************************************************************************
|
||||
|
||||
@@ -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
|
||||
|
||||
307
bsp/hc32/ev_hc32f460_lqfp100_v2/board/ports/usb_config.h
Normal file
307
bsp/hc32/ev_hc32f460_lqfp100_v2/board/ports/usb_config.h
Normal 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
|
||||
112
bsp/hc32/ev_hc32f460_lqfp100_v2/bsp_compile_ci.bat
Normal file
112
bsp/hc32/ev_hc32f460_lqfp100_v2/bsp_compile_ci.bat
Normal 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
|
||||
@@ -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>
|
||||
|
||||
@@ -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>
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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 的芯片性能。
|
||||
|
||||
开发板外观如下图所示:
|
||||
|
||||

|
||||
|
||||
EV_F472_LQ80_Rev1.0 开发板常用 **板载资源** 如下:
|
||||
EV_F472_LQ100 开发板常用 **板载资源** 如下:
|
||||
|
||||
- **MCU**
|
||||
- HC32F472PETI
|
||||
- 主频200MHz
|
||||
- 256KB FLASH
|
||||
- 68KB RAM
|
||||
- **外部Memory**
|
||||
- BL24C256(EEPROM, 256Kbits)
|
||||
- W25Q64(SPI NOR,64MB)
|
||||
- IS62WV51216(SRAM, 1MB)
|
||||
- **常用外设**
|
||||
- LED: 4 个,User LED(LED0,LED1,LED2,LED3)。
|
||||
- 按键: 5 个,矩阵键盘(K1~K4), WAKEUP(K5),RESET(K0)
|
||||
- **常用接口**
|
||||
- USB转串口
|
||||
- CAN DB9接口 * 2
|
||||
- TFT接口
|
||||
- SmartCard接口
|
||||
- I2C/USART/SPI接口
|
||||
- **调试接口**
|
||||
- 板载DAP调试器
|
||||
- 标准JTAG/SWD/Trace
|
||||
- MCU:HC32F472PETI,主频200MHz,256KB FLASH,68KB RAM
|
||||
- 外部RAM:IS62WV51216(SRAM,1MB)
|
||||
- 常用外设
|
||||
- LED:3 个,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支持EEPROM(BL24C256) |
|
||||
| Hwtimer | 支持 | Hwtimer1~5 |
|
||||
| SPI | 支持 | SPI1~3<br>SPI1支持W25Q |
|
||||
| UART | 支持 | UART1~6<br>UART2为console使用 |
|
||||
| **片上外设** | **支持情况** | **备注** |
|
||||
| :------------ | :-----------: | :-----------------------------------: |
|
||||
| ADC | 支持 | |
|
||||
| CAN | 支持 | |
|
||||
| Crypto | 支持 | AES,CRC,HASH,RNG |
|
||||
| DAC | 支持 | |
|
||||
| FLASH | 支持 | |
|
||||
| GPIO | 支持 | PA0,PA1... PF8 ---> PIN:0,1...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]等) |
|
||||
|
||||
## 联系人信息
|
||||
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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
|
||||
}
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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)
|
||||
|
||||
@@ -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
Reference in New Issue
Block a user