应用笔记|使用STM32CubeMX生成配置代码的文件结构

STM32单片机 2023-09-16 09:36


关键字:.extSettings,文件结构,BSP



 目录预览


1.前言

2..extSetting文件的作用

3.使用实例

4.小结



01

前言


在阅读UM1718文档的时候,发现CubeMX有个比较好的功能,可以用“.extSettings"文件一次,后续不管使用哪个IDE(只要是CubeMX支持的),都不需要再手动配置文件结构或包含头文件路径了,并且可以保持对各个IDE(只包括CubeMX支持的)配置的一致性,减少工作量。也有客户询问怎么添加工程文件的问题,考虑到可能有些同学不太了解这个功能,所以本文对这个功能进行介绍。


02

.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;


说明:是工程中的文件组名(若不存在则会自动创建);是文件路径。示例中语句的作用是,嵌套创建“Drivers/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后自动在工程中添加的预处理语句


03

使用实例


下面的实例基于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切换亮/灭状态的操作。


04

小结



使用".extSettings"文件配置工程的文件机构,可以做到一次配置,多种平台可用的效果,并可以保持配置的一致性。


注意:".extSettings"文件一定要放在.ioc文件相同的目录下



完整内容请点击“阅读原文”下载原文档。


订阅号

关注STM32

视频号


B站账号

点击“阅读原文”,可下载原文档





STM32单片机 ST MCU (产品+工具+资料+技术+市场+活动)x 您的关注x您的支持 = STM32 单片机蝴蝶乐园
评论
  • 2024年是很平淡的一年,能保住饭碗就是万幸了,公司业绩不好,跳槽又不敢跳,还有一个原因就是老板对我们这些员工还是很好的,碍于人情也不能在公司困难时去雪上加霜。在工作其间遇到的大问题没有,小问题还是有不少,这里就举一两个来说一下。第一个就是,先看下下面的这个封装,你能猜出它的引脚间距是多少吗?这种排线座比较常规的是0.6mm间距(即排线是0.3mm间距)的,而这个规格也是我们用得最多的,所以我们按惯性思维来看的话,就会认为这个座子就是0.6mm间距的,这样往往就不会去细看规格书了,所以这次的运气
    wuliangu 2025-01-21 00:15 278浏览
  • 现在为止,我们已经完成了Purple Pi OH主板的串口调试和部分配件的连接,接下来,让我们趁热打铁,完成剩余配件的连接!注:配件连接前请断开主板所有供电,避免敏感电路损坏!1.1 耳机接口主板有一路OTMP 标准四节耳机座J6,具备进行音频输出及录音功能,接入耳机后声音将优先从耳机输出,如下图所示:1.21.2 相机接口MIPI CSI 接口如上图所示,支持OV5648 和OV8858 摄像头模组。接入摄像头模组后,使用系统相机软件打开相机拍照和录像,如下图所示:1.3 以太网接口主板有一路
    Industio_触觉智能 2025-01-20 11:04 182浏览
  • 数字隔离芯片是一种实现电气隔离功能的集成电路,在工业自动化、汽车电子、光伏储能与电力通信等领域的电气系统中发挥着至关重要的作用。其不仅可令高、低压系统之间相互独立,提高低压系统的抗干扰能力,同时还可确保高、低压系统之间的安全交互,使系统稳定工作,并避免操作者遭受来自高压系统的电击伤害。典型数字隔离芯片的简化原理图值得一提的是,数字隔离芯片历经多年发展,其应用范围已十分广泛,凡涉及到在高、低压系统之间进行信号传输的场景中基本都需要应用到此种芯片。那么,电气工程师在进行电路设计时到底该如何评估选择一
    华普微HOPERF 2025-01-20 16:50 109浏览
  • 高速先生成员--黄刚这不马上就要过年了嘛,高速先生就不打算给大家上难度了,整一篇简单但很实用的文章给大伙瞧瞧好了。相信这个标题一出来,尤其对于PCB设计工程师来说,心就立马凉了半截。他们辛辛苦苦进行PCB的过孔设计,高速先生居然说设计多大的过孔他们不关心!另外估计这时候就跳出很多“挑刺”的粉丝了哈,因为翻看很多以往的文章,高速先生都表达了过孔孔径对高速性能的影响是很大的哦!咋滴,今天居然说孔径不关心了?别,别急哈,听高速先生在这篇文章中娓娓道来。首先还是要对各位设计工程师的设计表示肯定,毕竟像我
    一博科技 2025-01-21 16:17 138浏览
  •  万万没想到!科幻电影中的人形机器人,正在一步步走进我们人类的日常生活中来了。1月17日,乐聚将第100台全尺寸人形机器人交付北汽越野车,再次吹响了人形机器人疯狂进厂打工的号角。无独有尔,银河通用机器人作为一家成立不到两年时间的创业公司,在短短一年多时间内推出革命性的第一代产品Galbot G1,这是一款轮式、双臂、身体可折叠的人形机器人,得到了美团战投、经纬创投、IDG资本等众多投资方的认可。作为一家成立仅仅只有两年多时间的企业,智元机器人也把机器人从梦想带进了现实。2024年8月1
    刘旷 2025-01-21 11:15 604浏览
  • Ubuntu20.04默认情况下为root账号自动登录,本文介绍如何取消root账号自动登录,改为通过输入账号密码登录,使用触觉智能EVB3568鸿蒙开发板演示,搭载瑞芯微RK3568,四核A55处理器,主频2.0Ghz,1T算力NPU;支持OpenHarmony5.0及Linux、Android等操作系统,接口丰富,开发评估快人一步!添加新账号1、使用adduser命令来添加新用户,用户名以industio为例,系统会提示设置密码以及其他信息,您可以根据需要填写或跳过,命令如下:root@id
    Industio_触觉智能 2025-01-17 14:14 137浏览
  • 故障现象 一辆2007款日产天籁车,搭载VQ23发动机(气缸编号如图1所示,点火顺序为1-2-3-4-5-6),累计行驶里程约为21万km。车主反映,该车起步加速时偶尔抖动,且行驶中加速无力。 图1 VQ23发动机的气缸编号 故障诊断接车后试车,发动机怠速运转平稳,但只要换挡起步,稍微踩下一点加速踏板,就能感觉到车身明显抖动。用故障检测仪检测,发动机控制模块(ECM)无故障代码存储,且无失火数据流。用虹科Pico汽车示波器测量气缸1点火信号(COP点火信号)和曲轴位置传感器信
    虹科Pico汽车示波器 2025-01-23 10:46 40浏览
  • 嘿,咱来聊聊RISC-V MCU技术哈。 这RISC-V MCU技术呢,简单来说就是基于一个叫RISC-V的指令集架构做出的微控制器技术。RISC-V这个啊,2010年的时候,是加州大学伯克利分校的研究团队弄出来的,目的就是想搞个新的、开放的指令集架构,能跟上现代计算的需要。到了2015年,专门成立了个RISC-V基金会,让这个架构更标准,也更好地推广开了。这几年啊,这个RISC-V的生态系统发展得可快了,好多公司和机构都加入了RISC-V International,还推出了不少RISC-V
    丙丁先生 2025-01-21 12:10 347浏览
  • 临近春节,各方社交及应酬也变得多起来了,甚至一月份就排满了各式约见。有的是关系好的专业朋友的周末“恳谈会”,基本是关于2025年经济预判的话题,以及如何稳定工作等话题;但更多的预约是来自几个客户老板及副总裁们的见面,他们为今年的经济预判与企业发展焦虑而来。在聊天过程中,我发现今年的聊天有个很有意思的“点”,挺多人尤其关心我到底是怎么成长成现在的多领域风格的,还能掌握一些经济趋势的分析能力,到底学过哪些专业、在企业管过哪些具体事情?单单就这个一个月内,我就重复了数次“为什么”,再辅以我上次写的:《
    牛言喵语 2025-01-22 17:10 143浏览
  •     IPC-2581是基于ODB++标准、结合PCB行业特点而指定的PCB加工文件规范。    IPC-2581旨在替代CAM350格式,成为PCB加工行业的新的工业规范。    有一些免费软件,可以查看(不可修改)IPC-2581数据文件。这些软件典型用途是工艺校核。    1. Vu2581        出品:Downstream     
    电子知识打边炉 2025-01-22 11:12 115浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦