rt-thread驱动篇(02)---STM32F429板卡外设驱动添加

目录

参考链接

前言

一、外设驱动

1、片上外设

2、板载外设 

二、外设驱动添加

1、配置CubeMX工程

2、修改Kconfig

​3、添加ports文件,修改SConscript

三、外设配置总结


参考链接

STM32 系列外设驱动添加指南

前言

  1. 此次制作的BSP使用的板卡我司自己开发的板卡,不方便放上来,但是是仿的正点原子阿波罗开发板,外设都差不多,单片机型号为429IGT6,大家看的时候可以参考阿波罗开发板硬件
  2. 整个驱动篇的源码可以私聊我或是从这里下载

一、外设驱动

对一个 BSP 而言,有如下三类驱动:

  • 板载外设驱动:指 MCU 之外,开发板上外设,例如 TF 卡、以太网和 LCD 等
  • 片上外设驱动:指 MCU 芯片上的外设,例如硬件定时器、ADC 和看门狗等
  • 扩展模块驱动:指可以通过扩展接口或者杜邦线连接的开发板的模块,例如 ESP8266 模块

rt-thread驱动篇(02)---STM32F429板卡外设驱动添加_第1张图片

 对于要添加的板卡,有如下外设:

1、片上外设

序号

驱动

外设

1

GPIO

DO1~DO5、DI1~DI2

2

UART

rt-thread驱动篇(02)---STM32F429板卡外设驱动添加_第2张图片

3

SPI

SPI1(扩展使用)、SPI2(串口扩展芯片使用)、SPI4(扩展使用)、SPI5(W25Q使用,SPI5_SCK不是硬件SPI引脚,需要模拟,所以CubeMX没有开启)

4

soft I2C

I2C1(扩展使用)、I2C2(DS1340)、I2C3(扩展使用)

5

TIMER

TIM11、TIM13、TIM14

6

ADC

ADC1_IN8(VI0)、ADC1_IN9(VI1)

7

RTC

设置和读取时间

8

WDT

看门狗驱动

2、板载外设 

序号

驱动

简介

1

SDIO

通过 SDIO 读写TF卡

2

ETH PHY

以太网

3

USB PHY

USB

4

LCD

显示屏

二、外设驱动添加

添加步骤:

1、配置CubeMX工程

打开 \board\CubeMX_Config 目录下的CubeMX工程,按照原理图配置对应外设的引脚,完成外设时钟使能和管脚配置的工作并生成工程。外设初始化,中断配置,DMA配置等等则由 RT-Thread 提供的驱动文件来完成。也就是说,虽然 STM32CubeMX 生成了多个文件用来初始化外设,但 RT-Thread 只使用了 STM32CubeMX 生成的 stm32fxx_hal_msp.c 文件(存放了在 CubeMX 工具中开启的外设驱动的配置代码)和 stm32fxx_hal_conf.h文件(提供的宏开关会决定 HAL 库将哪些外设驱动添加到工程中)。最后配置完成的外设有:

rt-thread驱动篇(02)---STM32F429板卡外设驱动添加_第3张图片

2、修改Kconfig

修改\board\Kconfig文件,这样就可以通过menuconfig来选择需要使用的外设了

menu "Hardware Drivers Config"

config SOC_STM32F429IG
    bool
    select SOC_SERIES_STM32F4
    select RT_USING_COMPONENTS_INIT
    select RT_USING_USER_MAIN
    default y

menu "Onboard Peripheral Drivers"

    config BSP_USING_COM1
        bool "Enable USART1"
        select BSP_USING_UART
        select BSP_USING_UART1
        default n

    config BSP_USING_COM6
        bool "Enable USART6"
        select BSP_USING_UART
        select BSP_USING_UART6
        default n

    config BSP_USING_COM7
        bool "Enable USART7"
        select BSP_USING_UART
        select BSP_USING_UART7
        default y

    config BSP_USING_SDRAM
        bool "Enable SDRAM"
        select BSP_USING_FMC
        default n

    config BSP_USING_SPI_FLASH
        bool "Enable SOFT-SPI FLASH (W25Q64)"
        select BSP_USING_SOFT_SPI
        select RT_USING_SFUD
        select RT_SFUD_USING_SFDP
        default n

	config PHY_USING_LAN8720A
        bool
		
    config BSP_USING_ETH
        bool "Enable Ethernet (ETH_RST is PH3)"
        select RT_USING_LWIP
        select PHY_USING_LAN8720A
        default n

    config BSP_USING_SDCARD
        bool "Enable SDCARD (sdio)"
        select BSP_USING_SDIO
        select RT_USING_DFS
        select RT_USING_DFS_ELMFAT
        default n
        
	config BSP_USING_LCD
        bool "Enable RGB-LCD"
        select BSP_USING_LTDC
		select BSP_USING_SDRAM
        default n
		
	config BSP_USING_TOUCH
        bool "Enable TOUCH Driver(TSC2046)"
        default n
		
endmenu

menu "On-chip Peripheral Drivers"

    config BSP_USING_GPIO
        bool "Enable GPIO"
        select RT_USING_PIN
        default y

    menuconfig BSP_USING_UART
        bool "Enable UART"
        default y
        select RT_USING_SERIAL
        if BSP_USING_UART
            config BSP_USING_UART1
                bool "Enable UART1"
                default n
            config BSP_UART1_RX_USING_DMA
                bool "Enable UART1 RX DMA"
                depends on BSP_USING_UART1 && RT_SERIAL_USING_DMA
                default n

            config BSP_USING_UART6
                bool "Enable UART6"
                default n
            config BSP_UART6_RX_USING_DMA
                bool "Enable UART6 RX DMA"
                depends on BSP_USING_UART6 && RT_SERIAL_USING_DMA
                default n
                
            config BSP_USING_UART7
                bool "Enable UART7"
                default y
            config BSP_UART7_RX_USING_DMA
                bool "Enable UART7 RX DMA"
                depends on BSP_USING_UART7 && RT_SERIAL_USING_DMA
                default n  
        endif

    config BSP_USING_ON_CHIP_FLASH
        bool "Enable on-chip FLASH"
        default n


	menuconfig BSP_USING_SOFT_SPI
        bool "Enable SOFT SPI BUS"
        default n
        select RT_USING_SOFT_SPI
        if BSP_USING_SOFT_SPI
			config BSP_USING_SOFT_SPI1
                bool "Enable SOFT SPI1:CS(PG10) SCK(PG12)  MISO(PF8) MOSI(PF9)"
                default n
		endif
				
    menuconfig BSP_USING_SPI
        bool "Enable SPI BUS"
        default n
        select RT_USING_SPI
        if BSP_USING_SPI
            config BSP_USING_SPI1
                bool "Enable SPI1 BUS(extended use!!!)"
                default n        
            config BSP_SPI1_TX_USING_DMA
                bool "Enable SPI1 TX DMA"
                depends on BSP_USING_SPI1
                default n
            config BSP_SPI1_RX_USING_DMA
                bool "Enable SPI1 RX DMA"
                depends on BSP_USING_SPI1
                select BSP_SPI1_TX_USING_DMA
                default n  
				
			config BSP_USING_SPI2
                bool "Enable SPI2 BUS(use to extend uart!!!)"
                default n        
            config BSP_SPI2_TX_USING_DMA
                bool "Enable SPI2 TX DMA"
                depends on BSP_USING_SPI2
                default n
            config BSP_SPI2_RX_USING_DMA
                bool "Enable SPI2 RX DMA"
                depends on BSP_USING_SPI2
                select BSP_SPI2_TX_USING_DMA
                default n  
				
			config BSP_USING_SPI4
                bool "Enable SPI4 BUS(extended use!!!)"
                default n        
            config BSP_SPI4_TX_USING_DMA
                bool "Enable SPI4 TX DMA"
                depends on BSP_USING_SPI4
                default n
            config BSP_SPI4_RX_USING_DMA
                bool "Enable SPI4 RX DMA"
                depends on BSP_USING_SPI4
                select BSP_SPI4_TX_USING_DMA
                default n

        endif		


    menuconfig BSP_USING_I2C1
        bool "Enable I2C1 BUS (software simulation,extended use!!!)"
        default n
        select RT_USING_I2C
        select RT_USING_I2C_BITOPS
        select RT_USING_PIN
        if BSP_USING_I2C1
            comment "Notice: PB8(SCL) --> 167; PB9(SDA) --> 168"
            config BSP_I2C1_SCL_PIN
                int "I2C1 scl pin number"
                range 1 176
                default 167
            config BSP_I2C1_SDA_PIN
                int "I2C1 sda pin number"
                range 1 176
                default 168
        endif

    menuconfig BSP_USING_I2C2
        bool "Enable I2C2 BUS (software simulation,use to RTC(DS1340))"
        default n
        select RT_USING_I2C
        select RT_USING_I2C_BITOPS
        select RT_USING_PIN
        if BSP_USING_I2C2
            comment "Notice: PH4(SCL) --> 45; PH5(SDA) --> 46"
            config BSP_I2C2_SCL_PIN
                int "I2C2 scl pin number"
                range 1 176
                default 45
            config BSP_I2C2_SDA_PIN
                int "I2C2 sda pin number"
                range 1 176
                default 46
        endif

    menuconfig BSP_USING_I2C3
        bool "Enable I2C3 BUS (software simulation,extended use!!!)"
        default n
        select RT_USING_I2C
        select RT_USING_I2C_BITOPS
        select RT_USING_PIN
        if BSP_USING_I2C3
            comment "Notice: PA8(SCL) --> 119; PH8(SDA)--> 85"
            config BSP_I2C3_SCL_PIN
                int "I2C3 scl pin number"
                range 1 176
                default 119
            config BSP_I2C3_SDA_PIN
                int "I2C3 sda pin number"
                range 1 176
                default 85
        endif

    menuconfig BSP_USING_TIM
        bool "Enable timer"
        default n
        select RT_USING_HWTIMER
        if BSP_USING_TIM
            config BSP_USING_TIM11
                bool "Enable TIM11"
                default n

            config BSP_USING_TIM13
                bool "Enable TIM13"
                default n

            config BSP_USING_TIM14
                bool "Enable TIM14"
                default n
        endif

    menuconfig BSP_USING_ADC
        bool "Enable ADC"
        default n
        select RT_USING_ADC
        if BSP_USING_ADC
            config BSP_USING_ADC1
                bool "Enable ADC1"
                default n
        endif

    menuconfig BSP_USING_ONCHIP_RTC
        bool "Enable RTC"
        select RT_USING_RTC
        select RT_USING_LIBC
        default n
        if BSP_USING_ONCHIP_RTC
            choice
                prompt "Select clock source"
                default BSP_RTC_USING_LSE

                config BSP_RTC_USING_LSE
                    bool "RTC USING LSE"

                config BSP_RTC_USING_LSI
                    bool "RTC USING LSI"
            endchoice
        endif

    config BSP_USING_WDT
        bool "Enable Watchdog Timer"
        select RT_USING_WDT
        default n

	menuconfig BSP_USING_USBH
        bool "Enable USB Host"
        select RT_USING_USB_HOST
        default n
        if BSP_USING_USBH
            menuconfig RT_USBH_MSTORAGE
                bool "Enable Udisk Drivers"
                default n
                if RT_USBH_MSTORAGE
                    config UDISK_MOUNTPOINT
                    string "Udisk mount dir"
                    default "/"
                endif
        endif
		
    config BSP_USING_SDIO
        bool "Enable SDIO"
        select RT_USING_SDIO
        select RT_USING_DFS
        default n

    config BSP_USING_FMC
        bool
        default n
		
	config BSP_USING_LTDC
        bool
        default n
		
    source "./libraries/HAL_Drivers/Kconfig"
    
endmenu

menu "Board extended module Drivers"

	menuconfig RT_STEMWIN
		bool "Enable STemWin"
		default n
		if RT_STEMWIN
			config RT_STEMWIN_DEMO
				bool "Enable STemWin Demo"
				default n
		endif
	
	menuconfig RT_TOUCHGFX
		bool "Enable TouchGFX"
		default n
		
endmenu

endmenu

rt-thread驱动篇(02)---STM32F429板卡外设驱动添加_第4张图片

rt-thread驱动篇(02)---STM32F429板卡外设驱动添加_第5张图片3、添加ports文件,修改SConscript

使用CubeMX配置完工程后,只是完成了外设时钟使能管脚配置外设初始化,中断配置,DMA配置等等则由 RT-Thread 提供的驱动文件(\libraries\HAL_Drivers目录下)来完成的,这些驱动配置有的需要根据使用情况修改配置参数,这些配置参数文件就存放在\board\ports文件夹下

rt-thread驱动篇(02)---STM32F429板卡外设驱动添加_第6张图片

 添加完后,还需要根据menuconfig开启的外设来选择需要包含的配置文件,也就是还需要修改\board\SConscript 构建脚本,这样在编译的时候才会将相应的文件加入工程进行编译

import os
import rtconfig
from building import *

Import('SDK_LIB')

cwd = GetCurrentDir()

# add general drivers
src = Split('''
board.c
CubeMX_Config/Src/stm32f4xx_hal_msp.c
''')

if GetDepend(['BSP_USING_ETH']):
    src += Glob('ports/phy_reset.c')
    
if GetDepend(['BSP_USING_SPI_FLASH']):
    src += Glob('ports/spi_flash_init.c')

if GetDepend(['BSP_USING_SDCARD']):
    src += Glob('ports/sdcard_port.c')
    
if GetDepend(['BSP_USING_AUDIO']):
    src += Glob('ports/audio/drv_wm8978.c')
    src += Glob('ports/audio/drv_sound.c')
    
if GetDepend(['BSP_USING_AUDIO_RECORD']):
    src += Glob('ports/audio/drv_mic.c')    
    
path =  [cwd]
path += [cwd + '/CubeMX_Config/Inc']
path += [cwd + '/ports']
    
if GetDepend(['BSP_USING_AUDIO']):
    path += [cwd + '/ports/audio']
    
startup_path_prefix = SDK_LIB

if rtconfig.CROSS_TOOL == 'gcc':
    src += [startup_path_prefix + '/STM32F4xx_HAL/CMSIS/Device/ST/STM32F4xx/Source/Templates/gcc/startup_stm32f429xx.s']
elif rtconfig.CROSS_TOOL == 'keil':
    src += [startup_path_prefix + '/STM32F4xx_HAL/CMSIS/Device/ST/STM32F4xx/Source/Templates/arm/startup_stm32f429xx.s']
elif rtconfig.CROSS_TOOL == 'iar':
    src += [startup_path_prefix + '/STM32F4xx_HAL/CMSIS/Device/ST/STM32F4xx/Source/Templates/iar/startup_stm32f429xx.s']

CPPDEFINES = ['STM32F429xx']
group = DefineGroup('Drivers', src, depend = [''], CPPPATH = path, CPPDEFINES = CPPDEFINES)

Return('group')

三、外设配置总结

想要在 BSP 中添加更多驱动时,需要使用 CubeMX 工具来配置这些外设。对于绝大多数驱动的配置,只需要在工具中使能相应的外设即可。但是对于一些复杂的外设,则需要更多的配置内容。下表展示了不同驱动在 CubeMX 工具配置步骤的总结:

序号

驱动

CubeMx 工程中的配置情况(加粗部分为必做步骤)

1

GPIO

无需任何操作

2

UART

开启该外设 ,然后配置所需要的引脚(或者使用默认引脚)

3

SPI

开启该外设 ,然后配置所需要的引脚(或者使用默认引脚)

4

I2C

依赖于PIN 驱动,无需任何操作

5

TIMER

使能 internal Clock 时钟 ,详细内容可参考5.3章节

7

PWM

首先使能 internal Clock 时钟,然后为 channelx 选项选择PWM Generation CHx, 最后配置所需要的引脚(或者使用默认引脚) ,详细内容可参考5.3章节

8

ADC

开启该外设,然后选择使用的通道 ,详细内容可参考5.3章节

9

RTC

开启该外设,然后在时钟树状图里将 RTC 选择为 LSE 时钟

10

Watchdog

开启该外设

11

EMAC

配置 ETH 外设的工作模式(一般为 RMII 模式)

12

SDRAM

需要根据板载的 SDRAM 型号配置片选脚,地址线,数据线等

13

SDIO

开启该外设,配置引脚(或者使用默认引脚),SDIO会改变时钟结构,故需重新配置时钟并修改board.c

你可能感兴趣的:(RT-Thread,stm32,单片机,arm,RT-Thread)