基于VSCode搭建STM32开发环境

发布者:真瓷堂最新更新时间:2024-03-05 来源: elecfans关键字:VSCode  STM32  开发环境 手机看文章 扫描二维码
随时随地手机看文章

众所周知,Keil是一款收费软件,虽然可以Po解使用,但很多公司还是有点害怕,想必有不少读者都收到过**函。

之前,开发单片机项目,可以说 Keil 是最佳选择之一,但VSCode横空问世之后,这种格局被打破。

因为 VSCode 免费且好用,可以安装各种插件,很多工程师逐渐从Keil 转向了 VSCode。而且,VSCode还能实现 Keil 不能实现的一些功能。

81fe780e-5ba8-11ee-939d-92fbcf53809c.png


下面就给大家分享一下 VSCode 搭建 STM32 开发环境的一些常规且使用的功能。


一、需要的软件和工具



  1. 下载最新版VS Code: 安装好插件,具有良好的代码补全与调试功能。



下载 LLVM:用于代码补全,其实可以理解为 Clang。因为VS Code 中“C/C++”插件的自动补全功能不太好用。STM32中好多库函数都补全不出来。记得按照好之后,将路径
添加到环境变量里。
下载安装 Git for Windows: 提供Git支持和MINGW64指令终端。


下载安装 arm-none-eabi-gcc:选择gcc-arm-none-eabi-5_4-2016q3-20160926-win32.exe(md5)这里是一个2016年的,我目前也是用的这个,好像还有其他的新版的下载,GNU Arm Embedded Toolchain。正常安装后,记得需要将软件的安装目录下的bin文件夹设置进入环境变量PATH中。

下载 OpenOCD for Windows:一个开源的片上调试器(Open On-Chip Debugger)。在Windows下自己编译可能有问题 。所以,我们选择编译好的。下载后的文件不是安装包,把程序文件夹放入自己的软件安装目录下,将软件的bin文件夹路径加入用户环境变量PATH中。


STM32CubeMX:用于生成带makefile的工程。这样我们就可以不用自己写MakeFile了。套用他的模板,然后修改为自己的目录就可以。



二、搭建编译环境


1. 用STM32Cube创建工程。



STM32CubeMX生成的是用HAL库开发的项目,具体怎么配置这里就不介绍了,只介绍与主题有关的部分。
(1)STM32CubeMx芯片包(固件库)下载,注意事项:

82079dc6-5ba8-11ee-939d-92fbcf53809c.png



需要选择help -> updater settings ->Connection Parameters设置好网络后,才能下载固件包。

(2)生成工程。选择MakeFile选项。
注意: 4.18.0以下的版本是没有Makefile这个选项的。最后下载一个中间版本,因为5.0以上的版本界面很乱。我选择的是 4.27.0.

8225023a-5ba8-11ee-939d-92fbcf53809c.png



2.配置VS Code




(1)打开工程所在的文件夹。在右键“用VS Code打开工程文件夹”,

824295a2-5ba8-11ee-939d-92fbcf53809c.png



你将会看到这样的目录结构

824fa1a2-5ba8-11ee-939d-92fbcf53809c.png




.ioc文件是STM32Cube的工程文件,Inc和Src是供用户修改的源码,Driver里是STM32和ARM CMSIS的库,最好不要修改。

不过,如果你要采用标准库开发的话,就修改为标准库的Driver.


(2)安装VS Code插件,需要这几样:

8258a8ba-5ba8-11ee-939d-92fbcf53809c.png826aecbe-5ba8-11ee-939d-92fbcf53809c.png



(3)配置VS Code内置终端


这里将我们上面安装的 Git for Windows 设置为VScode 的内置终端。

文件–首选项–设置,搜索terminal,设置内置终端的Shell为Bash(安装VS Code的时候它会推荐你安装Git,里面有这个Bash)。或者打开 Settings.json添加下面两句。


"terminal.integrated.shell.windows":"D:ProgramFilesGitbinbash.exe", "terminal.external.windowsExec":"D:ProgramFilesGitbinbash.exe"
然后按Ctrl+` 就可以打开终端,看到Bash了

8283d576-5ba8-11ee-939d-92fbcf53809c.png



(4)配置智能补全、智能感知插件。



前面我们安装了 LLVM 用它来实现智能补全,与纠错,自然就需要一个路径去寻找这些文件。因此我们需要一个。c_cpp_properties.json文件的配置文件。
我们在当前目录的.vscode文件夹下创建c_cpp_properties.json配置文件,用来告诉VS Code我们定义的宏与文件的路径。


{ "configurations":[ { "name":"Win32", "browse":{ "path":[ "${workspaceFolder}/", "${workspaceFolder}/Drivers/CMSIS", "${workspaceFolder}/Drivers/FWlib/inc", "${workspaceFolder}/Drivers/CMSIS/startup", "${workspaceFolder}/User/inc", "${workspaceFolder}/User", "${workspaceFolder}/ThirdParty/crclib/include" ], "limitSymbolsToIncludedHeaders":true }, "includePath":[ "${workspaceFolder}/", "${workspaceFolder}/", "${workspaceFolder}/Drivers/CMSIS", "${workspaceFolder}/Drivers/FWlib/inc", "${workspaceFolder}/Drivers/CMSIS/startup", "${workspaceFolder}/User/inc", "${workspaceFolder}/User", "${workspaceFolder}/ThirdParty/crclib/include" ], "defines":[ "_DEBUG", "UNICODE", "_UNICODE", "__CC_ARM", "USE_STDPERIPH_DRIVER", "STM32F10X_HD" ], "compilerPath":"C:ProgramFilesLLVMbinclang-format.exe", "cStandard":"c11", "cppStandard":"c++17", "intelliSenseMode":"clang-x64" } ], "version":4 }

注意:如果提示variable “uint32_t” is not a type name不是一个type类型。

则需要 添加宏定义__CC_ARM,如果没有该宏定义,则uint32_t类型会报错。并且结构体中使用了uint32_t定义的成员,也会补全不了。



(5)编译程序



gcc下编译过程如下图所示:
  • .c文件 经过arm-none-eabi-gcc编译成.o文件



  • .s文件 经过arm-none-eabi-as编译成.o文件



  • .o文件 和.a文件 经过arm-none-eabi-ld链接成.elf文件



  • .elf文件 经过arm-none-eabi-objcopy和arm-none-eabi-objdump转换成 hex文件/dis文件




  • arm-none-eabi-gdb使用.elf文件 进行debug

829011d8-5ba8-11ee-939d-92fbcf53809c.png






在Terminal下输入make指令,即会开始build程序



82ac7b20-5ba8-11ee-939d-92fbcf53809c.png



编译完成后,生成的所有文件都会放在Build文件夹下.




82c07f1c-5ba8-11ee-939d-92fbcf53809c.png



注意: 由于我安装了 Qt. Qt中自带了 mingw32-make.exe。我把这个文件复制了一份,重命名为make.exe。并且添加进了环境变量中。因此我可以直接使用 make。

如果你没有 make 的环境。可以下载一个choco包管理器,它类似于linux下的apt,只不过是windows下使用的。然后用choco安装make即可:

82c65306-5ba8-11ee-939d-92fbcf53809c.png



如果改了source code,需要重新编译程序,那就得先执行make clean指令去删除之前build好的所有东西。然后重新执行make指令即可。



三、布局



搭建调试环境



1.配置openocd。


要运行openocd这个gdb server,需要配置如下几个参数:


  • 用什么仿真器?(J-link, ST-link…)



  • 用什么接口?(JTAG, SWD…)



  • 目标芯片是什么?(STM32F4x, tm4c123g…)



首先我们打开openocd的安装目录,打开share/openocd/scripts,里面有很多提前写好的配置文件。

82cf88c2-5ba8-11ee-939d-92fbcf53809c.png



target里存放目标芯片的配置文件,例如stm32f4.cfg

interface里存放仿真器相关的配置文件,例如jlink.cfg,stlink.cfg.

当我们启动openocd时,可以用-f参数来指定一个配置文件。例如:


openocd–finterface/stlink.cfg–ftarget/stm32f4.cfg

【注】配置仿真器的参数必须在配置目标MCU的参数之前,否则将报错。

如果我们不带参数启动,openocd就会自动查找当前目录下有没有名为openocd.cfg的文件,并把它作为配置文件来启动。因此,我们就在当前工程下创建一个名为openocd.cfg的文件。82d650b2-5ba8-11ee-939d-92fbcf53809c.png


我们选择使用ST-link,SWD接口,目标芯片为stm32f1x。 (PS:这里注释掉了SWD接口,如果采用Jlink 则需要SWD接口)。

这样,我们连好板子上好电,直接在终端里敲openocd,即可启动。82f6347c-5ba8-11ee-939d-92fbcf53809c.png



openocd运行时,这个shell终端就被占用了,我们一会要新开一个终端。



2.用gdb连接上openocd



(1)直接启动gdb,参数为编译好的调试文件(.elf)

82ff8158-5ba8-11ee-939d-92fbcf53809c.png



(2)使gdb连接上openocd 前面已经说过openocd留给gdb的TCP/IP端口是3333,因此输入:


targetremotelocalhost:3333

8312bd18-5ba8-11ee-939d-92fbcf53809c.png




注意,在连接openocd的时候,一定需要先运行 openocd 服务才能通信上,否则一直出现 taget remote 错误。
(3)下载代码.

8321c510-5ba8-11ee-939d-92fbcf53809c.png




后面就和普通的gdb一样操作了,加断点,单步运行什么的,网上可以搜到很多教程。

【注】 最后记得输入q来退出gdb,以免影响后面的配置。



3.配置openocd任务与build任务



为了避免每次都在终端输入 make 和 make clean ,与 openocd 。我们可以在VSCode 中,建立一个 Task 来帮我们完成这个任务,



(1)在当前目录下创建build.py的文件。

833ced0e-5ba8-11ee-939d-92fbcf53809c.png




(2)在VSCode界面下,单击“任务”,选择“配置任务”



按 F1,选择"配置任务" .vscode目录下就会创建一个tasks.json配置文件.

834424f2-5ba8-11ee-939d-92fbcf53809c.png

打开 tasks.json ,修改内容如下:

834b8d46-5ba8-11ee-939d-92fbcf53809c.png



注意上面是两个任务,一个是openocd.用于连接st-link调试。一个是 build 用于编译。
它相当于是创建了一个名为build的任务,任务的内容是在shell里面执行 python build.py这个命令。只是不用我们手动输入而已。


4.配置VS Code的调试功能


使用VS Code,肯定是图方便,图好看。所以我肯定不会让大家靠敲命令来调试,这样岂不是开倒车,还不如用keil。因此,这里要配置VS Code的调试功能,相当于对gdb的一个图形化吧。
在VS Code内选择debug(就是左边那个‍‍虫子图标),选择“添加配置”,类型为GDB。就会在.vscode文件夹下生成launch.json配置文件。 按照下面来配置:


{ "version":"0.2.0", "configurations":[ { "name":"ARMDebug", "type":"cppdbg", "request":"launch", "program":"${workspaceFolder}/Build/STM32F103RC_Template.elf", "args":[], "stopAtEntry":false, "cwd":"${workspaceFolder}", "environment":[], "externalConsole":false, "MIMode":"gdb", "miDebuggerPath":"C:ProgramFiles(x86)GNUToolsARMEmbedded5.42016q3binarm-none-eabi-gdb.exe", "targetArchitecture":"arm", "setupCommands":[ { "description":"选择调试文件(.elf)到gdb", "text":"fileE:/VScode/STM32_VSCode/stm32f103_temp/Build/STM32F103RC_Template.elf", "ignoreFailures":false }, { "description":"连接GDBServer", "text":"targetremotelocalhost:3333", "ignoreFailures":false }, { "description":"ResetMCU", "text":"monitorreset", "ignoreFailures":false }, { "description":"Halt", "text":"monitorhalt", "ignoreFailures":false }, { "description":"下载代码到MCU", "text":"load", "ignoreFailures":false } ], "preLaunchTask":"build", } ] }
可以看到,setupCommands里面就是我们之前试用gdb时操作过的流程:连接GDB Server——reset——halt——下载代码。
而preLaunchTask中是我们之前在tasks.json中配置的build任务。它可以让我们每次调试时都先编译一遍。
保存后,随便打几个断点,按下F5,就可以快乐调试了。可以看到功能还是很齐全的。

835e9756-5ba8-11ee-939d-92fbcf53809c.png




【注意】:在进行调试的时候,需要先 按 F1 --> 任务:运行任务里选择 openocd 任务运行。

836ce928-5ba8-11ee-939d-92fbcf53809c.png




因为调试,需要连接st-link进行调试,而openocd任务是开启st-link的服务。这样客户端才能连接上。
否则会一直出现 target remote localhost:3333 的错误。



看到这里,基本就差不多了,开发STM32完全没问题了。


关键字:VSCode  STM32  开发环境 引用地址:基于VSCode搭建STM32开发环境

上一篇:基于STM32中串口通信的实例分析
下一篇:STM32F1低功耗模式

推荐阅读最新更新时间:2024-11-11 18:21

一文详解stm32 spi nss相关知识
1.概述 目前网络上使用stm32 spi的nss,基本上都使用的是nss的软件管理模式。对于nss的硬件管理模式,程序的配置以及对nss的软件管理模式与硬件管理模式的说明,真的少之又少。这可能跟stm32官方文档对nss的描述不清也有很大关系吧,下面就带大家理解理解nss,当然了这篇文章是笔者阅读了stm32 spi官方文档再结合网友的一些文章,最终以自己个人对nss理解来编写的,如果有错误之处,还请指正。 2.nss的管理模式 nss的管理模式分为:硬件管理和软件管理。nss的管理模式由SSM决定。 nss其实分为外部引脚和内部引脚的。外部nss引脚就是芯片上肉眼可见的与GPIO复用的引脚;内部nss引脚就是stm32芯片
[单片机]
一文详解<font color='red'>stm32</font> spi nss相关知识
STM32 SPI调试之HAL库的调试
uint8_t aTxBuffer __attribute__((at(0x20000200))) = {0xaa, 0x00, 0x00}; 在没有上面的__attribute__((at(0x20000200))的时候,程序会进入Hardfault,进入的原因是程序不能从奇地址读取数据。 这个原因非常难找,我也是无语。对其的原因 API在中断里和应用程序里不同同时使用,否则会陷入死机。 中断和应用程序不能用同一资源。 void SPI_RF_WriteByte(uint8_t *WriteBuff, uint16_t Size) { HAL_StatusTypeDef status = HAL_ERROR; //
[单片机]
基于STM32的虚拟多线程(TI_BLE协议栈_ZStack协议栈)
基于STM32的虚拟多线程,可以很好的用于裸机程序中,用于模拟小型操作系统的多线程概念。本实例参考了参考TI_BLE协议栈_ZStack协议栈。 #include Hal_Led/Hal_Led.h #include Hal_delay/delay.h #include Hal_Key/Hal_Key.h #include ringbuffer.h #define APP_LED2_BLINK_EVENT 0x0001 #define HAL_LED1_BLINK_EVENT 0x0001 #define TASK_NO_TASK_RUNNING 0xFF unsigned short Hal_ProcessE
[单片机]
基于<font color='red'>STM32</font>的虚拟多线程(TI_BLE协议栈_ZStack协议栈)
Stm32入门——Systick定时器
Systick定时器是什么? 从原理上来说,Systick定时器和开发板上的通用定时器没有区别。从功能上来说,Systick定时器主要是用来用来进行延时的(就是让CPU一直重复计数这件事),而通用或者高级定时器往往用来进行PWM输出、输入捕获等功能。至于为什么不用通用定时器或者高级定时器来完成延时功能,则是考虑到节省MCU的资源来做更重要的事。 Systick定时器相关寄存器 CTRL Systick控制和状态寄存器(存放使能位、中断位、时钟源选择位等) LOAD Systick自动重装载值寄存器 VAL Systick当前值寄存器 (这里插一句,建议大家在学习的时候直接对寄存器进行操作,不要用库函数,这样前期虽然会有困难,但
[单片机]
STM32运行RTC时死机
阿莫论坛中有个帖子,15楼对死机的原因作出了正确解释, http://www.ourdev.cn/bbs/bbs_content.jsp?bbs_sn=3589802&bbs_page_no=12&bbs_id=9999 引用如下: 我也碰到这个问题了,只要设置时间,就停在了RTC_WaitForLastTask(); 发现是由于RTC配置的问题。 在RTC初始化程序中,我们一般要查看BKP寄存器中的数据,判断后备电源是否掉电过。 如果掉电过,则初始化。没有在不执行。 但要设置时钟的话,必需允许PWR和BKP时钟,并允许读取BKP。 而如果仅电源掉电而后备电池不掉电的话,PWR和BKP时钟是没有开放的。 这样就等不
[单片机]
详细图文剖析STM32单片机串口一键下载电路与操作方法
在此介绍STM32单片机串口一键下载电路与操作方法详解。 STM32三种启动模式对应的存储介质均是芯片内置的,它们是: 1)用户闪存 = 芯片内置的Flash。 2)SRAM = 芯片内置的RAM区,就是内存啦。 3)系统存储器 = 芯片内部一块特定的区域,芯片出厂时在这个区域预置了一段Bootloader,就是通常说的ISP程序。这个区域的内容在芯片出厂后没有人能够修改或擦除,即它是一个ROM区。 要了解STM32的几种启动模式. BOOT0接GND,BOOT1接GND.那就是正常的启动模式,从flash加载代码. 而BOOT0接V3.3,BOOT1接GND.则是ISP模式,也就是串口更新代码. 其次,你要了解STM32I
[单片机]
详细图文剖析<font color='red'>STM32</font>单片机串口一键下载电路与操作方法
STM32 GPIO的配置
1STM32的输入输出管脚有下面8种可能的配置:(4输入+2输出+2复用输出) ① 浮空输入_IN_FLOATING ② 带上拉输入_IPU ③ 带下拉输入_IPD ④ 模拟输入_AIN ⑤ 开漏输出_OUT_OD ⑥ 推挽输出_OUT_PP ⑦ 复用功能的推挽输出_AF_PP ⑧ 复用功能的开漏输出_AF_OD 1.1I/O口的输出模式下,有3种输出速度可选(2MHz、10MHz和50MHz),这个速度是指I/O口驱动电路的响应速度而不是输出信号的速度,输出信号的速度与程序有关(芯片内部在I/O口的输出部分安排了多个响应速度不同的输出驱动电路,用户可以根据自己的需要选择合适的驱动
[单片机]
分享STM32代码读保护个人解决方案
简介:这个加载代码读保护功能的步骤可能对有些人来说还是比较麻烦的,毕竟产品多的时候,写入之后还要按一下写保护命令,对于产线操作员来说,可能一时疏忽忘记其中一个,就会造成代码的外泄,是不是应该还有更简单的办法一键写入呢,答案是肯定的! 具体做法,就是要在生成HEX文件之前,要多几个步骤 1.首先,加载: C:KeilARMBoardsKeilMCBSTM32Blinky文件夹中的一个STM32F10xOPT.s文件 2.修改下面两个值为1 3.生成HEX文件之前务必进行一下此配置 这样的话,就简单的一个HEX文件就会使你的产品流入市场之后,即便是被抄板成功,也不会是代码流出了 当然,必须保证自己公司的员工不
[单片机]
分享<font color='red'>STM32</font>代码读保护个人解决方案
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
随便看看

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved