Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 10 additions & 8 deletions bsp/hc32/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -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 系列** | |

Expand All @@ -23,4 +26,3 @@ HC32 系列 BSP 目前支持情况如下表所示:
| [外设驱动介绍](docs/HC32系列驱动介绍.md) | 讲解 HC32 系列 BSP 驱动的支持情况,以及如何利用驱动框架开发应用程序 |
| **BSP 制作与提交** | **简介** |
| [BSP 制作教程](docs/HC32系列BSP制作教程.md) | 讲解 HC32 系列 BSP 的制作方法 |

136 changes: 133 additions & 3 deletions bsp/hc32/ev_hc32f334_lqfp64/.ci/attachconfig/ci.attachconfig.yml
Original file line number Diff line number Diff line change
@@ -1,7 +1,137 @@
# ------ 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:
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.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
102 changes: 40 additions & 62 deletions bsp/hc32/ev_hc32f334_lqfp64/README.md
Original file line number Diff line number Diff line change
@@ -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 (板级支持包) 说明。

主要内容如下:

Expand All @@ -14,79 +14,63 @@

## 开发板介绍

EV_F334_LQ64_Rev1.0 是 XHSC 官方推出的开发板,搭载 HC32F334MCTI 芯片,基于 ARM Cortex-M4 内核,最高主频 200 MHz,具有丰富的板载资源,可以充分发挥 HC32F334MCTI 的芯片性能。
EV_F334_LQ64 是 XHSC 官方推出的开发板,搭载 HC32F334KATI 芯片,基于 ARM Cortex-M4 内核,最高主频 120 MHz,具有丰富的板载资源,可以充分发挥 HC32F334KATI 的芯片性能。

开发板外观如下图所示:

![board](figures/board.png)

EV_F334_LQ64_Rev1.0 开发板常用 **板载资源** 如下:

- **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

开发板更多详细信息请参考小华半导体半导体[EV_F334_LQ64_Rev1.0](https://www.xhsc.com.cn)
EV_F334_LQ64 开发板常用 **板载资源** 如下:

- 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](https://www.xhsc.com.cn)

## 外设支持

本 BSP 目前对外设的支持情况如下:

| **板载外设** | **支持情况** | **备注** |
|:-------- |:--------:|:--------:|
| USB 转串口 | 支持 | 使用 UART2 |
| LED | 支持 | LED1~4 |

| **片上外设** | **支持情况** | **备注** |
|:------------- |:--------:|:------------------------------------------:|
| 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使用 |
| **板载外设** | **支持情况** | **备注** |
| :------------ | :-----------: | :-----------------------------------: |
| USB 转串口 | 支持 | 使用 UART2 |

| **片上外设** | **支持情况** | **备注** |
| :------------ | :-----------: | :-----------------------------------: |
| 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 开发环境为例,介绍如何将系统运行起来。
Expand All @@ -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 >
```
Expand All @@ -127,12 +111,6 @@ msh >

4. 输入`scons --target=mdk5/iar` 命令重新生成工程。

## 注意事项

| 板载外设 | 模式 | 注意事项 |
| ---- | ---- | ------------------------------------------------------------------------------------------------------ |
| USB | host | 若配置为U盘主机模式,出现部分U盘无法识别或者写入失败时,可以尝试将RTT抽象层中rt_udisk_run()函数的rt_usbh_storage_reset()操作注释掉,测试是否可以获得更好的兼容性。 |

## 联系人信息

维护人:
Expand Down
Loading