众所周知,Keil是一款收费软件,虽然可以Po解使用,但很多公司还是有点害怕,想必有不少读者都收到过**函。
之前,开发单片机项目,可以说 Keil 是最佳选择之一,但VSCode横空问世之后,这种格局被打破。
因为 VSCode 免费且好用,可以安装各种插件,很多工程师逐渐从Keil 转向了 VSCode。而且,VSCode还能实现 Keil 不能实现的一些功能。
下面就给大家分享一下 VSCode 搭建 STM32 开发环境的一些常规且使用的功能。


我们选择使用ST-link,SWD接口,目标芯片为stm32f1x。 (PS:这里注释掉了SWD接口,如果采用Jlink 则需要SWD接口)。这样,我们连好板子上好电,直接在终端里敲openocd,即可启动。
openocd运行时,这个shell终端就被占用了,我们一会要新开一个终端。

01
需要的软件和工具VS Code下载地址:https://code.visualstudio.com/
- 下载 LLVM:用于代码补全,其实可以理解为 Clang。因为VS Code 中“C/C++”插件的自动补全功能不太好用。STM32中好多库函数都补全不出来。记得按照好之后,将路径添加到环境变量里。
LLVM下载地址:http://releases.llvm.org/download.html
- 下载安装 Git for Windows: 提供Git支持和MINGW64指令终端。
Git下载地址:https://gitforwindows.org/
-
下载安装 arm-none-eabi-gcc:选择
gcc-arm-none-eabi-5\_4-2016q3-20160926-win32.exe
(md5)这里是一个2016年的,我目前也是用的这个,好像还有其他的新版的下载,GNU Arm Embedded Toolchain。正常安装后,记得需要将软件的安装目录下的bin文件夹设置进入环境变量PATH中。
arm-none-eabi-gcc下载地址:https://launchpad.net/gcc-arm-embedded/+download
- 下载 OpenOCD for Windows:一个开源的片上调试器(Open On-Chip Debugger)。在Windows下自己编译可能有问题 。所以,我们选择编译好的。下载后的文件不是安装包,把程序文件夹放入自己的软件安装目录下,将软件的bin文件夹路径加入用户环境变量PATH中。
OpenOCD下载地址:http://gnutoolchains.com/arm-eabi/openocd/
- STM32CubeMX:用于生成带makefile的工程。这样我们就可以不用自己写MakeFile了。套用他的模板,然后修改为自己的目录就可以。
STM32CubeMX链接:http://www.stm32cube.com/
02
搭建编译环境1. 用STM32Cube创建工程。
STM32CubeMX生成的是用HAL库开发的项目,具体怎么配置这里就不介绍了,只介绍与主题有关的部分。(1)STM32CubeMx芯片包(固件库)下载,注意事项:
help -> updater settings ->Connection Parameters
设置好网络后,才能下载固件包。(2)生成工程。选择MakeFile选项。注意: 4.18.0以下的版本是没有Makefile这个选项的。最后下载一个中间版本,因为5.0以上的版本界面很乱。我选择的是 4.27.0.
2.配置VS Code
(1)打开工程所在的文件夹。在右键“用VS Code打开工程文件夹”,
.ioc
文件是STM32Cube的工程文件,Inc和Src是供用户修改的源码,Driver里是STM32和ARM CMSIS的库,最好不要修改。不过,如果你要采用标准库开发的话,就修改为标准库的Driver.(2)安装VS Code插件,需要这几样:
(3)配置VS Code内置终端
这里将我们上面安装的 Git for Windows 设置为VScode 的内置终端。文件–首选项–设置,搜索terminal,设置内置终端的Shell为Bash(安装VS Code的时候它会推荐你安装Git,里面有这个Bash)。或者打开 Settings.json添加下面两句。"terminal.integrated.shell.windows":"D:\ProgramFiles\Git\bin\bash.exe", "terminal.external.windowsExec":"D:\ProgramFiles\Git\bin\bash.exe" 然后按Ctrl+` 就可以打开终端,看到Bash了
(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:\ProgramFiles\LLVM\bin\clang-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

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

编译完成后,生成的所有文件都会放在Build文件夹下.
03
布局搭建调试环境
1.配置openocd。
要运行openocd这个gdb server,需要配置如下几个参数:首先我们打开openocd的安装目录,打开share/openocd/scripts,里面有很多提前写好的配置文件。
openocd–finterface/stlink.cfg–ftarget/stm32f4.cfg 【注】配置仿真器的参数必须在配置目标MCU的参数之前,否则将报错。如果我们不带参数启动,openocd就会自动查找当前目录下有没有名为openocd.cfg的文件,并把它作为配置文件来启动。因此,我们就在当前工程下创建一个名为openocd.cfg的文件。


2.用gdb连接上openocd
(1)直接启动gdb,参数为编译好的调试文件(.elf)
targetremotelocalhost:3333
3.配置openocd任务与build任务
为了避免每次都在终端输入 make 和 make clean ,与 openocd 。我们可以在VSCode 中,建立一个 Task 来帮我们完成这个任务,(1)在当前目录下创建build.py的文件。

(2)在VSCode界面下,单击“任务”,选择“配置任务”
按 F1,选择"配置任务" .vscode目录下就会创建一个tasks.json配置文件.
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)\GNUToolsARMEmbedded\5.42016q3\bin\arm-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,就可以快乐调试了。可以看到功能还是很齐全的。
审核编辑 :李倩
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。
举报投诉
-
单片机
+关注
关注
6044文章
44633浏览量
639559 -
STM32
+关注
关注
2274文章
10930浏览量
358123 -
vscode
+关注
关注
1文章
157浏览量
7907
原文标题:用 VS Code 搭建 STM32 开发环境。
文章出处:【微信号:All_best_xiaolong,微信公众号:大鱼机器人】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
相关推荐
如何搭建企业AI开发环境
搭建企业AI开发环境是一个复杂而细致的过程,涉及硬件选择、操作系统配置、软件安装、工具选用以及实践等多个方面。下面,AI部落小编将详细介绍如何搭建
SSM开发环境的搭建教程 SSM与Spring Boot的区别
SSM开发环境的搭建教程 SSM(Spring+SpringMVC+MyBatis)开发环境的搭建
飞凌嵌入式ElfBoard ELF 1板卡-开发环境搭建之VScode的安装及使用
VScode的下载及安装Visual Stuio Code(以下简称VSCode)是微软出的一款免费开源的轻量级编辑器。VSCode支持多平台,有 Windows、Linux和macO
发表于 09-30 09:40
PyTorch深度学习开发环境搭建指南
PyTorch作为一种流行的深度学习框架,其开发环境的搭建对于深度学习研究者和开发者来说至关重要。在Windows操作系统上
用ESP32s2的mesh组网测试一些功能,可以在window下用vscode来编译吗?
要用s2的mesh组网测试一些功能,mdf的例程比较接近,是否可以类似idf一样,可以window下用vscode来编译呢?
发表于 06-28 12:43
请问如何在32位的WIN7上搭建开发环境?
公司的电脑是32位的WIN7 在VSCode 上搭建开发环境失败(vscode IDF插件自动下载的都是64bit的软件)有没有解决方法或者
发表于 06-18 06:53
求助,通过VScode构建的集成开发环境如何更新环境下的ESP-IDF版本?
通过VScode构建的集成开发环境如何 更新 环境下的ESP-IDF版本?
通过VScode 构建开发
发表于 06-17 06:38
如何在离线环境下安装VSCode的ESP-IDF扩展插件?
出于一些原因,我的工作电脑无法连接互联网,所以需要在离线环境下安装ESP-IDF的开发环境,我使用了esp-idf-tools-setup-offline安装包配置了ESP-IDF工具
发表于 06-13 07:56
STM32中几种流行的开发环境对比
有很多初学者在问:学习STM32,该用哪款开发工具?我首先说一下我的观点:没有最好,只有适不适合,适合自己的才是最好的。开发工具很多,各有各的特点,有优点肯定也有缺点。本文就来说说当前

stm32mp135f的开发环境能不能像普遍的mp1系列去搭建呢?
我们要使用stm32mp135f芯片,它的开发环境能不能像普遍的mp1系列去搭建呢(例如stn32mp157)
发表于 03-20 06:32
评论