手把手带你使用VSCode搭建STM32开发环境

混说Linux 2023-03-10 11:32

点击上方蓝色“混说Linux”,选择“设为星标

第一时间看干货文章



 1

对于单片机开发,使用比较多的就是Keil,但它是一个收费软件,虽然可以Po解,但是很多公司也害怕收到**函,如果公司准备上市,那就更不能使用Keil开发了。


一直都比较喜欢VSCode的这种黑色主题,还能安装各种插件,免费又好用,于是决定搭建一个用VSCode + 开源 arm 工具链 + OpenOCD开发STM32的环境。

 

一、需要的软件和工具
1. 下载最新版 VS Code : 安装好插件,具有良好的代码补全与调试功能。
VS Code下载地址:https://code.visualstudio.com/

2. 下载 LLVM :用于代码补全,其实可以理解为 Clang。因为VS Code 中“C/C++”插件的自动补全功能不太好用。STM32中好多库函数都补全不出来。记得按照好之后,将路径添加到环境变量里。

Git下载地址:https://gitforwindows.org/

3. 下载安装 Git for Windows:提供Git支持和MINGW64指令终端。

Git下载地址:https://gitforwindows.org/
4. 下载安装 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
5. 下载 OpenOCD for Windows

一个开源的片上调试器(Open On-Chip Debugger)。

在Windows下自己编译可能有问题 。所以,我们选择编译好的。

下载后的文件不是安装包,把程序文件夹放入自己的软件安装目录下,将软件的bin文件夹路径加入用户环境变量PATH中
OpenOCD下载地址:http://gnutoolchains.com/arm-eabi/openocd/

6. STM32CubeMX:用于生成带 makefile 的工程。

这样我们就可以不用自己写MakeFile了。套用他的模板,然后修改为自己的目录就可以。

STM32CubeMX链接:http://www.stm32cube.com/

 

二、搭建编译环境

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添加下面两句。

    /* 终端在Windows上使用的shell的路径 */
    "terminal.integrated.shell.windows""D:\\Program Files\\Git\\bin\\bash.exe",
    "terminal.external.windowsExec""D:\\Program Files\\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:\\Program Files\\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文件夹下.


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


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


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

 

三、搭建调试环境

1.配置openocd

要运行openocd这个gdb server,需要配置如下几个参数:
    • 用什么仿真器?(J-link, ST-link…)

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

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


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


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


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


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

    openocd –f interface/stlink.cfg –f target/stm32f4.cfg

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


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


我们选择使用ST-link,SWD接口,目标芯片为stm32f1x。

(PS:这里注释掉了SWD接口,如果采用Jlink 则需要SWD接口)。


这样,我们连好板子上好电,直接在终端里敲openocd,即可启动。


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


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


(2) 使gdb连接上openocd

前面已经说过openocd留给gdb的TCP/IP端口是3333,因此输入:

    target remote localhost:3333


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


(3)下载代码


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

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


3. 配置openocd任务与build任务

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


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


(2). 在VSCode界面下,单击“任务”,选择“配置任务”
按 F1,选择"配置任务" .vscode目录下就会创建一个tasks.json配置文件.


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


注意上面是两个任务,一个是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配置文件。

按照下面来配置:

{
    // 使用 IntelliSense 了解相关属性。 
    // 悬停以查看现有属性的描述。
    // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
    "version""0.2.0",
    "configurations": [

        {
            "name""ARM Debug",
            "type""cppdbg",
            "request""launch",
            "program""${workspaceFolder}/Build/STM32F103RC_Template.elf",// 要调试的程序(在下面的参数中指定了,这里的没有意义)
            "args": [],
            "stopAtEntry"false,
            "cwd""${workspaceFolder}",
            "environment": [],
            "externalConsole"false// 调试时是否显示控制台窗口
            "MIMode""gdb",
            "miDebuggerPath""C:\\Program Files (x86)\\GNU Tools ARM Embedded\\5.4 2016q3\\bin\\arm-none-eabi-gdb.exe",//调试工具原始路径
            "targetArchitecture""arm"//目标架构,此参数必须要有
            "setupCommands": [// 进入GDB以后,自动执行的一些配置  
                {
                    "description""选择调试文件(.elf)到gdb",
                    "text""file E:/VScode/STM32_VSCode/stm32f103_temp/Build/STM32F103RC_Template.elf",
                    "ignoreFailures"false
                },
                {
                    "description""连接GDB Server",
                    "text""target remote localhost:3333",                                 
                    "ignoreFailures"false
                },
                {
                    "description""Reset MCU",
                    "text""monitor reset",                                              
                    "ignoreFailures"false
                },
                {
                    "description""Halt",
                    "text""monitor halt",                                                  
                    "ignoreFailures"false
                },
                {
                    "description":"下载代码到MCU",
                    "text""load" ,              
                    "ignoreFailures"false                                      
                }
            ],
            "preLaunchTask""build"// 在调试前预先执行的任务,此处是tasks.json中的
        }
    ]
}


可以看到,setupCommands里面就是我们之前试用gdb时操作过的流程:连接GDB Server——reset——halt——下载代码。


而preLaunchTask中是我们之前在tasks.json中配置的build任务。它可以让我们每次调试时都先编译一遍。


保存后,随便打几个断点,按下F5,就可以快乐调试了。可以看到功能还是很齐全的。


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


因为调试,需要连接st-link进行调试,而openocd任务是开启st-link的服务。这样客户端才能连接上。


否则会一直出现 target remote localhost:3333 的错误。


】这里有一个问题我一直没有解决,就是setupCommands里,用file选择调试用的elf文件时,必须用文件的绝对路径。我试过用${workspaceFolder}/build/xxx.elf和./build/xxx.elf都不行,都找不到文件,不知道是不是windows路径分割符是”\”导致的。具体的后续再完善。


原文:http://t.csdn.cn/89MOD

版权归原作者所有,如有侵权,请联系删除。





往期推荐

谈谈关于嵌入式软件分层框架

我写了一段代码,CPU为什么就能运行

在STM32上模拟Linux自动初始化过程

这些经常忽略的嵌入式基础知识点,你都掌握了吗?

混说Linux 百度研发工程师,分享Linux干货,和大家一起学习!
评论
  • 临近春节,各方社交及应酬也变得多起来了,甚至一月份就排满了各式约见。有的是关系好的专业朋友的周末“恳谈会”,基本是关于2025年经济预判的话题,以及如何稳定工作等话题;但更多的预约是来自几个客户老板及副总裁们的见面,他们为今年的经济预判与企业发展焦虑而来。在聊天过程中,我发现今年的聊天有个很有意思的“点”,挺多人尤其关心我到底是怎么成长成现在的多领域风格的,还能掌握一些经济趋势的分析能力,到底学过哪些专业、在企业管过哪些具体事情?单单就这个一个月内,我就重复了数次“为什么”,再辅以我上次写的:《
    牛言喵语 2025-01-22 17:10 43浏览
  •     IPC-2581是基于ODB++标准、结合PCB行业特点而指定的PCB加工文件规范。    IPC-2581旨在替代CAM350格式,成为PCB加工行业的新的工业规范。    有一些免费软件,可以查看(不可修改)IPC-2581数据文件。这些软件典型用途是工艺校核。    1. Vu2581        出品:Downstream     
    电子知识打边炉 2025-01-22 11:12 55浏览
  • 随着消费者对汽车驾乘体验的要求不断攀升,汽车照明系统作为确保道路安全、提升驾驶体验以及实现车辆与环境交互的重要组成,日益受到业界的高度重视。近日,2024 DVN(上海)国际汽车照明研讨会圆满落幕。作为照明与传感创新的全球领导者,艾迈斯欧司朗受邀参与主题演讲,并现场展示了其多项前沿技术。本届研讨会汇聚来自全球各地400余名汽车、照明、光源及Tier 2供应商的专业人士及专家共聚一堂。在研讨会第一环节中,艾迈斯欧司朗系统解决方案工程副总裁 Joachim Reill以深厚的专业素养,主持该环节多位
    艾迈斯欧司朗 2025-01-16 20:51 198浏览
  •  光伏及击穿,都可视之为 复合的逆过程,但是,复合、光伏与击穿,不单是进程的方向相反,偏置状态也不一样,复合的工况,是正偏,光伏是零偏,击穿与漂移则是反偏,光伏的能源是外来的,而击穿消耗的是结区自身和电源的能量,漂移的载流子是 客席载流子,须借外延层才能引入,客席载流子 不受反偏PN结的空乏区阻碍,能漂不能漂,只取决于反偏PN结是否处于外延层的「射程」范围,而穿通的成因,则是因耗尽层的过度扩张,致使跟 端子、外延层或其他空乏区 碰触,当耗尽层融通,耐压 (反向阻断能力) 即告彻底丧失,
    MrCU204 2025-01-17 11:30 182浏览
  • 数字隔离芯片是一种实现电气隔离功能的集成电路,在工业自动化、汽车电子、光伏储能与电力通信等领域的电气系统中发挥着至关重要的作用。其不仅可令高、低压系统之间相互独立,提高低压系统的抗干扰能力,同时还可确保高、低压系统之间的安全交互,使系统稳定工作,并避免操作者遭受来自高压系统的电击伤害。典型数字隔离芯片的简化原理图值得一提的是,数字隔离芯片历经多年发展,其应用范围已十分广泛,凡涉及到在高、低压系统之间进行信号传输的场景中基本都需要应用到此种芯片。那么,电气工程师在进行电路设计时到底该如何评估选择一
    华普微HOPERF 2025-01-20 16:50 73浏览
  • 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 122浏览
  • 日前,商务部等部门办公厅印发《手机、平板、智能手表(手环)购新补贴实施方案》明确,个人消费者购买手机、平板、智能手表(手环)3类数码产品(单件销售价格不超过6000元),可享受购新补贴。每人每类可补贴1件,每件补贴比例为减去生产、流通环节及移动运营商所有优惠后最终销售价格的15%,每件最高不超过500元。目前,京东已经做好了承接手机、平板等数码产品国补优惠的落地准备工作,未来随着各省市关于手机、平板等品类的国补开启,京东将第一时间率先上线,满足消费者的换新升级需求。为保障国补的真实有效发放,基于
    华尔街科技眼 2025-01-17 10:44 221浏览
  • 高速先生成员--黄刚这不马上就要过年了嘛,高速先生就不打算给大家上难度了,整一篇简单但很实用的文章给大伙瞧瞧好了。相信这个标题一出来,尤其对于PCB设计工程师来说,心就立马凉了半截。他们辛辛苦苦进行PCB的过孔设计,高速先生居然说设计多大的过孔他们不关心!另外估计这时候就跳出很多“挑刺”的粉丝了哈,因为翻看很多以往的文章,高速先生都表达了过孔孔径对高速性能的影响是很大的哦!咋滴,今天居然说孔径不关心了?别,别急哈,听高速先生在这篇文章中娓娓道来。首先还是要对各位设计工程师的设计表示肯定,毕竟像我
    一博科技 2025-01-21 16:17 101浏览
  • 80,000人到访的国际大展上,艾迈斯欧司朗有哪些亮点?感未来,光无限。近日,在慕尼黑electronica 2024现场,ams OSRAM通过多款创新DEMO展示,以及数场前瞻洞察分享,全面展示自身融合传感器、发射器及集成电路技术,精准捕捉并呈现环境信息的卓越能力。同时,ams OSRAM通过展会期间与客户、用户等行业人士,以及媒体朋友的深度交流,向业界传达其以光电技术为笔、以创新为墨,书写智能未来的深度思考。electronica 2024electronica 2024构建了一个高度国际
    艾迈斯欧司朗 2025-01-16 20:45 444浏览
  • 嘿,咱来聊聊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 112浏览
  • 2024年是很平淡的一年,能保住饭碗就是万幸了,公司业绩不好,跳槽又不敢跳,还有一个原因就是老板对我们这些员工还是很好的,碍于人情也不能在公司困难时去雪上加霜。在工作其间遇到的大问题没有,小问题还是有不少,这里就举一两个来说一下。第一个就是,先看下下面的这个封装,你能猜出它的引脚间距是多少吗?这种排线座比较常规的是0.6mm间距(即排线是0.3mm间距)的,而这个规格也是我们用得最多的,所以我们按惯性思维来看的话,就会认为这个座子就是0.6mm间距的,这样往往就不会去细看规格书了,所以这次的运气
    wuliangu 2025-01-21 00:15 186浏览
  • 现在为止,我们已经完成了Purple Pi OH主板的串口调试和部分配件的连接,接下来,让我们趁热打铁,完成剩余配件的连接!注:配件连接前请断开主板所有供电,避免敏感电路损坏!1.1 耳机接口主板有一路OTMP 标准四节耳机座J6,具备进行音频输出及录音功能,接入耳机后声音将优先从耳机输出,如下图所示:1.21.2 相机接口MIPI CSI 接口如上图所示,支持OV5648 和OV8858 摄像头模组。接入摄像头模组后,使用系统相机软件打开相机拍照和录像,如下图所示:1.3 以太网接口主板有一路
    Industio_触觉智能 2025-01-20 11:04 150浏览
  •  万万没想到!科幻电影中的人形机器人,正在一步步走进我们人类的日常生活中来了。1月17日,乐聚将第100台全尺寸人形机器人交付北汽越野车,再次吹响了人形机器人疯狂进厂打工的号角。无独有尔,银河通用机器人作为一家成立不到两年时间的创业公司,在短短一年多时间内推出革命性的第一代产品Galbot G1,这是一款轮式、双臂、身体可折叠的人形机器人,得到了美团战投、经纬创投、IDG资本等众多投资方的认可。作为一家成立仅仅只有两年多时间的企业,智元机器人也把机器人从梦想带进了现实。2024年8月1
    刘旷 2025-01-21 11:15 399浏览
  • 本文介绍瑞芯微开发板/主板Android配置APK默认开启性能模式方法,开启性能模式后,APK的CPU使用优先级会有所提高。触觉智能RK3562开发板演示,搭载4核A53处理器,主频高达2.0GHz;内置独立1Tops算力NPU,可应用于物联网网关、平板电脑、智能家居、教育电子、工业显示与控制等行业。源码修改修改源码根目录下文件device/rockchip/rk3562/package_performance.xml并添加以下内容,注意"+"号为添加内容,"com.tencent.mm"为AP
    Industio_触觉智能 2025-01-17 14:09 164浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦