目录预览
1.前言
2..extSetting文件的作用
3.使用实例
4.小结
在阅读UM1718文档的时候,发现CubeMX有个比较好的功能,可以用“.extSettings"文件一次,后续不管使用哪个IDE(只要是CubeMX支持的),都不需要再手动配置文件结构或包含头文件路径了,并且可以保持对各个IDE(只包括CubeMX支持的)配置的一致性,减少工作量。也有客户询问怎么添加工程文件的问题,考虑到可能有些同学不太了解这个功能,所以本文对这个功能进行介绍。
.extSettings文件的作用
".extSettings"文件是对CubeMX配置的补充,是在CubeMX配置的基础上进行的额外配置,不是替换CubeMX的配置,这点需要注意。
总体来说,".extSettings"文件中的配置包含三部分,分别是[ProjectFiles],[Groups]和[Others],下面分别对这三个部分的功能进行介绍。
2.1. [ProjectFiles]
[ProjectFiles]这个部分主要是用来包含一些目录,例如头文件存放的目录。
语法:HeaderPath=
示例:HeaderPath=../BSP/STM32H735G-DK
说明:这里的路径是相对于“*.cproject”或 “*.project”文件(如果生成的是CubeIDE的工程代码的话)的相对路径。如果生成的是其他IDE的工程代码,则这个路径是相对于其他工程文件的相对路径,例如“*.eww”文件(IAR)或“*.uvprojx”文件(KEIL)
效果:在".extSettings"文件中添加示例中的内容,重新生成代码后,效果如图1,红框部分是通过".extSettings"文件包含的目录,可以看到已经被包含到工程中。
图1 配置[ProjectFiles]后CubeIDE工程包含的目录
2.2. [Groups]
这个部分主要是用来在工程中创建文件组并且将文件添加到文件组中,用来组织工程的文件结构。
语法:
示例:Drivers/BSP/STM32H735G-DK=.. /BSP/STM32H735G-DK /stm32h735g_discovery.c;
说明:
效果:在".extSettings"文件中添加示例中的内容,重新生成代码后,效果如图2。
图2 配置[Groups]后CubeIDE工程的文件结构
2.3. [Others]
[Others]这个部分主要是用来使能一些HAL模板和添加一些预处理定义语句。
2.3.1. 添加HAL模板
语法:HALModule=
示例:HALModule=SPI;ADC;
效果:在".extSettings"文件中添加示例中的内容,重新生成代码后,如果使用H7系列的芯片创建的工程,则会自动在“stm32h7xx_hal_conf.h”文件(如果是其他系列的芯片的话,名字会略有区别)中添加”HAL_SPI_MODULE_ENABLED"和“HAL_ADC_MODULE_ENABLED"这两个宏定义,作用是在这个文件中包含SPI与ADC的头文件。如图3所示:
图3 配置[Other]的HALModule后HAL的配置文件中自动添加的内容
2.3.2. 添加预处理定义语句
语法:Define=
示例:Define=TEST_STM32H735G_DEMO
效果:在".extSettings"文件中添加示例中的内容,重新生成代码后,可以看到".extSettings"文件中配置的预定义语句已经被添加到工程中了。
图4 配置[Other]的Define后自动在工程中添加的预处理语句
下面的实例基于STM32H735G-DK板,使用“STM32Cube_FW_H7_V1.10.0”中的BSP驱动。要达到的目的是使板子上的LED1每隔0.5S切换一次亮/灭状态。下面是实现的步骤:
3.1.1. 创建CubeMX配置文件
使用STM32CubeMX创建STM32H735IGK6(STM32H735G-DK)的工程,其他配置都使用默认值即可,并保存这个配置文件。如图5所示:
图5 保存CubeMX产生的配置文件
3.1.2. 添加BSP文件
将“STM32Cube_FW_H7_V1.10.0/Drivers”路径下的“BSP”目录及其文件都复制到工程目录下(这里是复制到.ioc文件相同目录下,您也可以根据自己需要复制到其他地方,只要在".extSettings"文件中包含即可)。如图6所示:
图6 复制“BSP”到工程目录下
修改BSP中 “stm32h735g_discovery_conf_template.h"文件的文件名,修改为“stm32h735g_discovery_conf.h”
图7 添加BSP的配置文件
3.1.3. 创建.extSettings文件
在.ioc文件同级目录下创建".extSettings"文件。如下图所示:
图8 添加.extSettings文件
注意:.extSettings文件一定要放在.ioc文件的同一目录下
3.1.4. 修改.extSettings文件的内容
(1)因为要对GPIO进行操作,BSP文件是基于HAL库的,所以需要使用GPIO的HAL库(避免GPIO模块尚未使能,这里使能GPIO模块)。在[Others]部分需要添加的内容为:HALModule=GPIO
(2)添加BSP中需要包含的目录。所以在[ProjectFiles]中需要添加的内容为:HeaderPath=../BSP/STM32H735G-DK
(3)将BSP中的文件添加到工程中,因为只需要操作LED,所以需要添加“stm32h735g_discovery.c”文件即可,并创建文件组“STM32H735G-DK”。所以在[Groups]中需要添加的内容为:Drivers/BSP/STM32H735G-DK=../BSP/STM32H735G-DK /stm32h735g_discovery.c;
综合上面三点,在.extSettings文件中需要添加的内容为:
3.1.5. 使用CubeMX生成适用不同IDE的工程代码
使用CubeMX生成代码(GENERAGE CODE),分别生成CubeIDE,IAR和KEIL的工程代码。
图9 使用CubeMX生成代码
生成代码后,可以看到不同IDE的工程文件结构如下图:
图10 STM32CubeIDE
图11 IAR
图12 KEIL
可以从上面图中看到,“stm32h735g_discovery.c”文件已经被添加到工程中,BSP的目录也已经被包含到工程中。
3.1.6. 添加代码实现功能
1.包含“stm32h735g_discovery.h”头文件。
图13 包含“stm32h735g_discovery.h”
2.使用BSP初始化LED1的配置。
图14 使用BSP初始化LED1的配置
3.添加LED1的翻转操作。
图15 添加LED的翻转操作
结果:使用这三种IDE进行编译下载后都可以实现LED1每隔0.5S切换亮/灭状态的操作。
使用".extSettings"文件配置工程的文件机构,可以做到一次配置,多种平台可用的效果,并可以保持配置的一致性。
注意:".extSettings"文件一定要放在.ioc文件相同的目录下
关注STM32
▽点击“阅读原文”,可下载原文档