2018-12-25 16:16:31 +08:00
|
|
|
|
# STM32 系列外设驱动添加指南
|
|
|
|
|
|
|
|
|
|
## 1. 简介
|
|
|
|
|
|
|
|
|
|
本文档是为需要给现有的 STM32 BSP 添加更多外设驱动的开发者准备的。通过阅读本文,开发者可以按照自己的实际情况给现有 BSP 添加自己需要的驱动。
|
|
|
|
|
|
|
|
|
|
## 2. 前提要求
|
|
|
|
|
|
2023-04-18 15:52:45 +08:00
|
|
|
|
- 熟练使用 ENV 工具,参考:[RT-Thread env 工具用户手册](https://www.rt-thread.org/document/site/#/development-tools/env/env)
|
2018-12-25 16:16:31 +08:00
|
|
|
|
- 熟悉 Kconfig 语法
|
|
|
|
|
- 熟悉 STM32CubeMX 工具
|
|
|
|
|
- 对 RT-Thread 设备驱动框架有一定了解
|
|
|
|
|
|
|
|
|
|
## 3. 如何添加更多的外设驱动选项
|
|
|
|
|
|
|
|
|
|
本章节以添加片上外设驱动为例,讲解如何为 BSP 添加更多可用驱动。如果想使用的片上外设是 `片上外设配置菜单` 里没有的,就需要开发者自己添加了。下面我们将演示如何为 stm32f429-atk-apollo BSP 添加 SPI3 驱动。
|
|
|
|
|
|
|
|
|
|
> 没有安装 stm32cubemx 软件的可以访问 STM32cube中文网:<http://www.stm32cube.com/> ,在 `资源下载` 里下载 stm32cubemx 软件。
|
|
|
|
|
|
|
|
|
|
阿波罗 BSP 默认只支持 SPI1、SPI2 和 SPI5,是不支持 SPI3 的。开发者如果需要使用 SPI3,则需要自己添加。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/736fa/736fa0624cfb330bf9ef00a604e424adb00effb4" alt="spi_config"
|
|
|
|
|
|
|
|
|
|
添加 SPI3 的外设支持需要以下几步:
|
|
|
|
|
|
|
|
|
|
### 1)打开 STM32CubeMX 工程
|
|
|
|
|
|
|
|
|
|
打开 BSP 的 STM32CubeMX 配置文件。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5d412/5d4127bf850f03238bd600c8cea05365663e297a" alt="1543486779576"
|
|
|
|
|
|
|
|
|
|
### 2)按原理图配置 SPI3 的引脚,并生成代码
|
|
|
|
|
|
|
|
|
|
按图示顺序配置 SPI3,并生成代码。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/26b01/26b01b78d50e317c53923a461f4ed106b02ee3df" alt="1543487684698"
|
|
|
|
|
|
|
|
|
|
> 为 BSP 添加驱动时,STM32CubeMX 工具可以快速的完成**使能外设**和**配置管脚**的工作。而外设初始化,中断配置,DMA配置等等则由 RT-Thread 提供的驱动文件来完成。也就是说,虽然 STM32CubeMX 生成了多个文件用来初始化外设,但 RT-Thread 只使用了 STM32CubeMX 生成的 `stm32fxx_hal_msp.c` 文件和 `stm32fxx_hal_conf.h` 文件。
|
|
|
|
|
>
|
2019-01-14 16:31:01 +08:00
|
|
|
|
> 对于不同的外设驱动,通过 STM32CubeMX 工具配置的内容也不一样。开发者可以参考本文档的附录 CubeMX 配置说明章节来了解不同外设的配置方法。
|
2018-12-25 16:16:31 +08:00
|
|
|
|
|
|
|
|
|
### 3)修改 Kconfig 文件
|
|
|
|
|
|
|
|
|
|
打开 board 文件夹下的 Konfig 文件,拷贝 SPI2 的配置项,并重命名 SPI2 为 SPI3。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f3c24/f3c24724e5953f08e6b04eb8d0c5fd7bb50f2e4b" alt="1543542657074"
|
|
|
|
|
|
|
|
|
|
### 4)重新配置工程
|
|
|
|
|
|
|
|
|
|
经过上一步的修改,此时重新打开 ENV 工具,在 menuconfig 中就会出现添加的 SPI3 的配置项。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/59890/5989041b8e3514c74e78e1698b0ca8afda4ca14b" alt="1543543081284"
|
|
|
|
|
|
|
|
|
|
### 5)生成工程,检查驱动文件
|
|
|
|
|
|
|
|
|
|
使用 ENV 重新生成工程并打开,检查原有驱动文件是否支持新添加的驱动(查看是否有新驱动的配置文件,中断函数,DMA配置和中断函数等等),如不支持,需参考现有驱动添加相关的代码。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/3443d/3443debfad3ac30665ddca52a1ee5096c6a64a29" alt="spi_code"
|
|
|
|
|
|
|
|
|
|
### 6)编译下载
|
|
|
|
|
|
|
|
|
|
检查完工程后,编译下载到开发板,程序会自动开始运行。输入 `list_device` 命令,可以看到 spi3 总线已经注册到内核,说明驱动已经添加成功。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/08052/080526e103397722f70b553052d0005680373d53" alt="1543543446786"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## 4. 注意事项
|
|
|
|
|
|
|
|
|
|
- 部分驱动如果没有适配 BSP 所属的 STM32 系列,请等待 RT-Thread 团队更新。
|
|
|
|
|
- 驱动文件对 STM32 系列的支持情况可以查看 [STM32系列驱动介绍文档](STM32系列驱动介绍文档.md)。
|
|
|
|
|
- 对于驱动文件或文档说明,有任何建议或者意见,欢迎反馈到 [RT_Thread GitHub](https://github.com/RT-Thread/rt-thread) 网站或 [RT-Thread 官方论坛](https://www.rt-thread.org/qa/forum.php)。
|
2021-08-26 21:09:40 +08:00
|
|
|
|
- 在生成代码时,不要勾选以下选项(即:不让其生成单独的 .c/.h 驱动文件,直接全部更新到 rt-thread 要使用的 stm32xxx_hal_msp.c 文件中)
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a7f33/a7f336dacdd090bc831bf3b66a72364982f0fbc5" alt="generate-code"
|
2018-12-25 16:16:31 +08:00
|
|
|
|
|
|
|
|
|
## 5. 附录
|
|
|
|
|
|
|
|
|
|
### 5.1 CubeMX配置说明
|
|
|
|
|
|
|
|
|
|
本小节介绍 stm32 系列的 BSP 是如何利用 CubeMX 工具对 BSP 进行配置的。
|
|
|
|
|
|
|
|
|
|
就像文档中提到的那样,stm32 系列的 BSP 只利用了 CubeMX 工具生成的 `stm32XXxx_hal_conf.h` 和 `stm32XXxx_hal_msp.c` 文件。在 HAL 库中, `stm32XXxx_hal_conf.h` 文件里提供的宏开关会决定 HAL 库将哪些外设驱动添加到工程中。 而`stm32XXxx_hal_msp.c` 文件中则存放了在 CubeMX 工具中开启的外设驱动的配置代码。
|
|
|
|
|
|
|
|
|
|
### 5.2 外设配置总结
|
|
|
|
|
|
|
|
|
|
当开发者想要在 BSP 中添加更多驱动时,需要使用 CubeMX 工具来配置这些外设。对于绝大多数驱动的配置,只需要在工具中使能相应的外设即可。但是对于一些复杂的外设,则需要更多的配置内容。下表展示了不同驱动在 CubeMX 工具配置步骤的总结:
|
|
|
|
|
|
|
|
|
|
| 序号 | 驱动 | CubeMx 工程中的配置情况(**加粗部分为必做步骤**) |
|
|
|
|
|
| :--: | :------- | :----------------------------------------------------------- |
|
|
|
|
|
| 1 | GPIO | 无需任何操作 |
|
|
|
|
|
| 2 | UART | **开启该外设** ,然后配置所需要的引脚(或者使用默认引脚) |
|
|
|
|
|
| 3 | SPI | **开启该外设** ,然后配置所需要的引脚(或者使用默认引脚) |
|
2019-02-18 13:49:42 +08:00
|
|
|
|
| 4 | I2C | 依赖于PIN 驱动,无需任何操作 |
|
|
|
|
|
| 5 | TIMER | **使能 internal Clock 时钟** ,详细内容可参考5.3章节 |
|
|
|
|
|
| 7 | PWM | **首先使能 internal Clock 时钟,然后为 channelx 选项选择PWM Generation CHx,** 最后配置所需要的引脚(或者使用默认引脚) ,详细内容可参考5.3章节 |
|
|
|
|
|
| 8 | ADC | **开启该外设,然后选择使用的通道** ,详细内容可参考5.3章节 |
|
2018-12-25 16:16:31 +08:00
|
|
|
|
| 9 | RTC | **开启该外设,然后在时钟树状图里将 RTC 选择为 LSE 时钟** |
|
2019-02-18 13:49:42 +08:00
|
|
|
|
| 10 | Watchdog | **开启该外设** |
|
2018-12-25 16:16:31 +08:00
|
|
|
|
| 11 | EMAC | **配置 ETH 外设的工作模式(一般为 RMII 模式)** |
|
|
|
|
|
| 12 | SDRAM | **需要根据板载的 SDRAM 型号配置片选脚,地址线,数据线等** |
|
2019-12-10 23:04:25 +08:00
|
|
|
|
| 13 | SDIO | **开启该外设,配置引脚(或者使用默认引脚),SDIO会改变时钟结构,故需重新配置时钟并修改board.c** |
|
2018-12-25 16:16:31 +08:00
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
### 5.3 复杂外设配置说明
|
2019-02-18 13:03:00 +08:00
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
本章节着重介绍配置步骤较为复杂的驱动。
|
2019-02-18 13:03:00 +08:00
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
#### 5.3.1 TIMER 外设驱动添加说明
|
2019-02-18 13:03:00 +08:00
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
1. 打开 STM32CubeMX 工程,设置 timer 在 Cube 里的选项,如下图所示:
|
2019-02-18 13:03:00 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/cc491/cc4912f81847b1c00e2c239321b46c56d6605392" alt="timer CubeMX 配置"
|
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
2. 打开 stm32/stm32f429-atk-apollo/board/Kconfig ,添加 Kconfig 选项。选中自己添加的选项后,生成一遍工程,如下图所示:
|
2019-02-18 13:03:00 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/eeab2/eeab2ec0ff1826183c05b9f16b0419f5f370510b" alt="timer Kconfig 配置"
|
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
3. 打开工程进行编译,工程会提示 TIM11_CONFIG 未定义。 可以在 stm32/libraries/HAL_Drivers/config/f4/tim_config.h 中进行定义,如下图所示:
|
2019-02-18 13:03:00 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/52fe6/52fe66f05496a2ffdc9a36ba95ec481329d7eaf6" alt="timer 编译"
|
|
|
|
|
data:image/s3,"s3://crabby-images/599d1/599d19f0638687c73a9f95f63e4df5e260b6cb1c" alt="timer 编译"
|
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
#### 5.3.2 PWM 外设驱动添加说明
|
2019-02-18 11:46:07 +08:00
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
1. 打开 STM32CubeMX 工程,设置 PWM 在 Cube 里的选项,如下图所示:
|
2019-02-18 11:46:07 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1310e/1310e7b281559f08a97943d1db0ec3b476e9ea22" alt="pwm CubeMX 配置"
|
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
2. 打开 stm32/stm32f429-atk-apollo/board/Kconfig ,添加 Kconfig 选项。选中自己添加的选项后,生成一遍工程,如下图所示:
|
2019-02-18 11:46:07 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/44426/4442625aece18803ee95a619717078867959998e" alt="pwm Kconfig 配置"
|
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
3. 打开工程进行编译,工程会提示 PWM2_CONFIG 未定义。 可以在 stm32/libraries/HAL_Drivers/config/f4/pwm_config.h 中进行定义,如下图所示:
|
2019-02-18 13:03:00 +08:00
|
|
|
|
|
2019-02-18 11:46:07 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/efd32/efd329b12ab0128fb9bb9d58bea468f62c50c433" alt="pwm 编译"
|
|
|
|
|
data:image/s3,"s3://crabby-images/f33fb/f33fb58d383fc96b6d525017c7e8df0cb7c28ab1" alt="pwm 编译"
|
2019-02-18 13:03:00 +08:00
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
#### 5.3.3 ADC 外设驱动添加说明
|
2019-02-18 13:44:08 +08:00
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
1. 打开 STM32CubeMX 工程,设置 ADC 在 Cube 里的选项,如下图所示:
|
2019-02-18 13:44:08 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/da4a7/da4a7e70f91ffe74893f0d1829a088c9003c2e16" alt="adc CubeMX 配置"
|
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
2. 打开 stm32/stm32f429-atk-apollo/board/Kconfig ,添加 Kconfig 选项。选中自己添加的选项后,生成一遍工程,如下图所示:
|
2019-02-18 13:44:08 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/646d4/646d4b935c9f259b4ccca5ef179c7fc676f73c1a" alt="adc Kconfig 配置"
|
|
|
|
|
|
2019-02-18 13:49:42 +08:00
|
|
|
|
3. 打开工程进行编译,工程会提示 ADC1_CONFIG 未定义。 可以在 stm32/libraries/HAL_Drivers/config/f4/adc_config.h 中进行定义,如下图所示:
|
2019-02-18 13:44:08 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/79b15/79b1529ef2afd9e3eb324f7ac560ba9cd1e43b94" alt="adc 编译"
|
2019-02-18 13:49:42 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/33c8c/33c8c9a84ff7938e4093d902ce72b851b177c6bc" alt="adc 编译"
|
2019-11-07 14:30:35 +08:00
|
|
|
|
|
|
|
|
|
#### 5.3.4 编码器外设驱动添加说明
|
|
|
|
|
|
|
|
|
|
1. 打开 STM32CubeMX 工程,设置 TIMER 在 Cube 里的选项,如下图所示:
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c73e7/c73e7268e60ae7cab04804742ee2566b7fdbc807" alt="pulse_encoder CubeMX 配置"
|
|
|
|
|
|
|
|
|
|
2. 打开 stm32/stm32f407-atk-explorer/board/Kconfig ,添加 Kconfig 选项。选中自己添加的选项后,生成一遍工程,如下图所示:
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e8949/e8949147acc37c79dd768d0abef30a460bb04afb" alt="pulse_encoder Kconfig 配置"
|
|
|
|
|
|
|
|
|
|
3. 打开工程进行编译,工程会提示 PULSE_ENCODER4_CONFIG 未定义。 可以在 stm32/libraries/HAL_Drivers/config/f4/pulse_encoder_config.h 中进行定义,如下图所示:
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f2835/f2835ad19b1f9235cd15dc6d876855558a08a248" alt="pulse_encoder 编译"
|
|
|
|
|
data:image/s3,"s3://crabby-images/0cd39/0cd3982e3658bb6c91dd97c4226f2d95571f48a4" alt="pulse_encoder 编译"
|