【STM32开发笔记】搭建基于ST官方VSCode扩展的STM32开发环境

news2024/9/24 19:25:49

搭建基于ST官方VSCode扩展的STM32开发环境

    • 一、安装软件
      • 1.1 安装VSCode
      • 1.2 安装STM32CubeMX
      • 1.3 安装STM32CubeCLT
      • 1.4 安装ST-MCU-FINDER-PC
    • 二、安装插件
      • 2.1 安装 STM32 VS Code Extension
    • 三、创建项目
      • 3.1 创建STM32CubeMX项目
      • 3.2 查阅原理图
      • 3.3 修改引脚功能
      • 3.4 生成CMake项目
    • 四、编辑/编译/下载/调试
      • 4.1 导入项目
      • 4.2 修改设置
      • 4.3 修改代码
      • 4.4 编译代码
      • 4.5 下载固件
      • 4.6 设置调试
      • 4.7 断点调试
    • 五、参考链接

本文将介绍如何在Windows系统上搭建基于ST官方VSCode扩展的STM32开发环境,相对基于VSCode+PyOCD的开发环境,基于ST官方VSCode扩展的开发环境搭建更容易一些,功能也更强大。本文部分章节以STM32H7S7L8HxH MCU为例,但全文介绍的方法适用于大部分STM32 MCU,对于其他型号的STM32 MCU,仅少量步骤调整即可。

本文将介绍如何在Windows系统上搭建基于VSCode的STM32开发环境,具体包括如下软件:

  • VS Code,用于编辑源代码文件,以及集成其他插件作为集成开发环境(IDE);
  • STM32CubeMX,用于修改配置,以及生成代码;
  • STM32CubeCLT,STM32Cube命令行工具;
  • ST-MCU-FINDER-PC,ST MCU查找工具;

此前,我也搭建过基于VSCode+PyOCD的开发环境,相比使用ST官方VSCode扩展的方式,需要下载更多软件,搭建过程更复杂。感兴趣的可以去看看,文章链接: 【STM32开发笔记】搭建VSCode+PyOCD的STM32开发环境

相对来说,基于ST官方VSCode扩展的开发环境搭建更容易一些,功能也更强大一些。

本文部分章节以STM32H7S7L8HxH MCU为例,但全文介绍的方法适用于大部分STM32 MCU,对于其他型号的STM32 MCU,仅少量步骤调整即可。

一、安装软件

1.1 安装VSCode

VSCode是一个强大且开放的代码编辑器,支持众多编程语言(C、C++、Java、Python等等),以及各种插件。VSCode的插件生态非常丰富,这也是目前VSCode非常受大家欢迎的一个重要原因。

下载页面: https://code.visualstudio.com/Download

VSCode可以直接下载,不需要注册。安装没啥难度,不再赘述。

1.2 安装STM32CubeMX

STM32CubeMX 实现了图形化方式配置STM32 MCU的引脚功能、时钟速率、中间件等等功能,并且可以一键生成整个项目的代码。STM32CubeMX 的这些功能,极大的提升了开发效率,对于产品项目的原型开发,以及DIY爱好者进行电子制作非常有吸引力。

下载页面: https://www.st.com.cn/zh/development-tools/stm32cubemx.html

ST官网需要注册之后,才能下载。安装没啥难度,不再赘述。

1.3 安装STM32CubeCLT

STM32CubeCLT官方的介绍是:

Toolset for third-party integrated development environment (IDE) providers, allowing the use of STMicroelectronics proprietary tools within their own IDE frameworks.

面向第三方集成开发环境(IDE)提供商的工具集,允许在其自己的IDE框架中使用STMicroelectronics的专有工具。

下载页面: https://www.st.com.cn/zh/development-tools/stm32cubeclt.html

ST官网需要注册之后,才能下载。安装没啥难度,不再赘述。

这里补充说明一下,本人安装之后发现,STM32CubeCLT安装目录内包含了一下软件:

  • CMake,跨平台构建工具,用于支持STM32CubeMX生成CMake项目的编译构建;
  • Ninja,一种轻量级的构建工具,用于支持STM32CubeMX生成CMake项目的编译构建;
  • GNU ARM交叉编译工具链(arm-none-eabi-gcc),用于将C/C++源代码编译为STM32平台的二进制代码;
  • STLink USB驱动,用于支持ST-Link调试器,安装之后系统才可以正常识别ST-Link;
  • STLink-gdb-server,用于支持通过ST-Link调试STM32 MCU;
  • STM32 Programmer CLI,命令行界面的STM32下载工具,用于将固件下载到STM32 MCU的内部flash中;

其中,前三个工具(CMake、Ninja、arm-none-eabi-gcc)用于支持编译,中间两个(STLink USB驱动,STLink-gdb-server)用于支持调试,最后一个(STM32_Programmer_CLI)用于支持下载。

1.4 安装ST-MCU-FINDER-PC

ST-MCU-FINDER-PC是 用于个人电脑的STM32和STM8产品查找工具。

下载页面:https://www.st.com.cn/zh/development-tools/st-mcu-finder-pc.html

ST官网需要注册之后,才能下载。安装没啥难度,不再赘述。

二、安装插件

安装完以上软件后,还需要安装一些VSCode插件,具体有:

  • STM32 VS Code Extension

2.1 安装 STM32 VS Code Extension

VSCode需要安装的插件STM32 VS Code Extension,直接在插件栏搜索即可找到,安装即可。

需要注意的是,这个插件本身依赖另外几个插件,如下图所示:

image-20240810205603812

这几个插件的作用分别为:

  • C/C++ Extension Pack,用于支持C/C++语法高亮、代码提示;
  • Arm Assembly,用于支持ARM汇编的语法高亮、代码提示;
  • LinkerScript,用于支持链接脚本的语法高亮、代码提示;
  • GNU Linker Map files,用于支持生成的.map文件的代码高亮;
  • Hex Editor,用于支持以十六进制显示并编辑二进制文件;
  • Cortex-Debug,用于支持Arm Cortex-M内核MCU的调试;

完成以上软件和插件的安装,基于ST官方VSCode扩展的STM32开发环境已经搭建完成了!

三、创建项目

接下来,我们创建一个简单的点灯程序,验证一下刚刚搭建的开发环境是可以正常使用的。

3.1 创建STM32CubeMX项目

  1. 首先打开STM32CubeMX,通过菜单File→New Project打开新建项目窗口,在弹出的界面中选择“Board Selector”标签页:

    image-20240810214948065

    • 在Commercial Part Number栏中输入H7S7,并回车;
    • 在MCUs/MPUs List下方选中Board列有STM32H7S78-DK的一行;
    • 点击右上角Start Project按钮;
    • 弹出MPU设置的话框,选择Yes;
  2. 然后STM32CubeMX进入配置界面,切换到Clock Configuration标签页,将To CPU Clocks修改为600并回车,CubeMX软件将会自动计算其他参数:

    image-20240810215519566

  3. 按Ctrol+S保存,选择适当的位置保存ioc文件。

这样CubeMX项目就创建好了。

3.2 查阅原理图

STM32H7S78-DK开发板原理图,下载链接为: st.com.cn/resource/en/schematic_pack/mb1736-h7s7l8-d01-schematic.pdf

打开原理图后,可以在Sheet 15: Peripherals页面找到如下LED部分:

image-20240810220101570

图中,可以看到四个LED的控制引脚分别为:

  • GREEN: PO1
  • ORANGE: PO5
  • RED: PM2
  • BLUE: PM3

另外,查阅用户手册,可以知道这几个LED位于开发板正面的屏幕的左下角:

image-20240810220250369

3.3 修改引脚功能

找到以上LED引脚后,在STM32CubeMX软件的Pinout View中,可以通过搜索框,找到以上几个引脚,并通过下拉菜单将其设置为GPIO_Output功能:

image-20240810221011283

四个LED控制引脚设置完成后,通过左侧的Categories->System Core->GPIO也可以看到:

image-20240810221236340

图中,左侧System Core下方有三列复选框Boot、Application、ExtMemLoader,用于为相应的子项目(Boot、Appli、ExtMemLoader)生成外设初始化代码。

为了后续编写代码时,方便区分哪个Pin控制了哪个LED,可以为以上几个Pin设置User Label(用户标签)。设置User Label后,例如给PO1设置User Label为LD1,生成的代码中将会生成相应的宏定义,编写代码时更方便。

对于以上四个LED控制引脚,需要将Pin Context Assignment修改为Boot,User Label修改为和板子丝印对应的: LD1、LD2、LD3、LD4,如下图:

image-20240810221958081

Pin Context Assignment修改为Boot是因为——为了简单起见,我们暂时只生成一个Boot子项目(虽然bootflash不大,但是点灯的代码也够用了)。

3.4 生成CMake项目

CubeMX中完成引脚功能修改后,切换到Project Manager标签页,Project设置部分,取消Appli Project复选框,Toolchain/IDE选择CMake,如下图:

image-20240810223022846

接着,切换到Code Generator设置,选中Generate peripheral initialization as a pair of ‘.c/.h’ per peripheral,如下图:

image-20240810223136153

此时,点击CubeMX界面右上角位置的“GENERATE CODE”,将开始生成代码到项目目录内,并显示进度:

image-20240810223354263

生成完成后,将会弹出对话框提示:

image-20240810223417765

点击Open Folder打开目录,可以看到生成的文件和目录如下图:

image-20240810223527721

到这里,使用CubeMX创建项目完成了。

四、编辑/编译/下载/调试

接下来就要使用VS Code和STM32 VS Code Extension插件,进行开发体验了。通常我们开发过程中,需要不断重复的几个动作是: 编辑代码、编译构建、下载固件、断点调试。

4.1 导入项目

打开VSCode,侧边栏点击STM32 VS Code Extension插件图标,可以看到插件的项目管理(Project Manager)菜单:

image-20240810224005693

选择Import CMake project菜单,在弹出的文件目录浏览对话框中,选择刚刚CubeMX生成的目录,如下图:

image-20240810224129475

此时,点击“选择文件夹”,VSCode中将会弹出确认导入的对话框:

image-20240810224329631

此时,点击Import project,VSCode右下角弹出确认对话框:

image-20240810224458649

选择Open in this window,在当前VS Code窗口中打开项目。

此时,弹出配置预设选择对话框,选择Debug即可:

image-20240810224607767

选择配置预设类型之后,可以看到输出栏有如下输出:

image-20240810224759824

这些输出表示,已经根据CMake文件(CMakeLists.txt)生成了Ninja构建构建规则文件(build.ninja),具体位于build/Debug子目录。

导入完成后,项目目录内会生成.vscode目录,里面会有一些配置文件。

4.2 修改设置

默认情况下,导入的VS Code代码之后,打开C代码会有一些红线:

image-20240810230447432

例如,这里的 “main.h” 显示红线。

这个问题是VS Code的C/C++插件的智能提示(IntelliSense)没有成功找到main.h。

这个问题不只是会显示红线,而且会影响VS Code的代码提示。因此,如果不解决这个问题,使用VS Code编写代码的效率会大打折扣!

打开 c_cpp_properties.json (或者图形化修改C/C++配置),将其内容修改为:

{
    "version": 4,
    "configurations": [
        {
            "name": "STM32",
            "configurationProvider": "ms-vscode.cmake-tools",
            "intelliSenseMode": "windows-gcc-arm",
            "compilerPath": "D:/ST/STM32CubeCLT_1.16.0/GNU-tools-for-STM32/bin/arm-none-eabi-gcc.exe",
            "includePath": [
                "${workspaceFolder}/Boot/Core/Inc",
                "${workspaceFolder}/Drivers/STM32H7RSxx_HAL_Driver/Inc",
                "${workspaceFolder}/Drivers/STM32H7RSxx_HAL_Driver/Inc/Legacy",
                "${workspaceFolder}/Drivers/CMSIS/Device/ST/STM32H7RSxx/Include",
                "${workspaceFolder}/Drivers/CMSIS/Include"
            ]
        }
    ]
}

其中,compilerPath 使用STM32CubeCLT安装目录下的arm-none-eabi-gcc,includePath 列表内容需要 参考 Boot\mx-generated.cmake 文件中的 target_include_directories 的内容。

4.3 修改代码

打开Boot\Core\Src\main.c文件,文件开头Private includes下方修改为:

image-20240810231601992

找到其中的main函数中的while循环,将其修改为:

image-20240810232211496

以上两处代码修改,实现了控制四个LED的闪烁。

4.4 编译代码

完成以上代码修改后,点击VS Code的CMake Tools插件图标,在项目大纲中点击”生成“按钮,将会开始编译构建:

image-20240810232828510

生成完成后,可以在输出视图看到生成了elf文件,以及RAM和Flash占用情况:

image-20240810233137567

4.5 下载固件

编译完成后,就可以准备下载固件了。

还是在VS Code的CMake Tools插件菜单,找到 固定的命令-> 运行任务 右侧的运行命令图标,点击该图标:

image-20240810233350191

将会弹出”选择要运行的任务“对话框,选择CubeProg: Flash Boot即可开始下载固件:

image-20240810233428944

下载完成,可以在输出区域看到下载过程耗时:

image-20240810233820037

4.6 设置调试

默认导入的项目已经创建了调试配置文件,位于.vscode/launch.json,但生成的是外置存储启动的调试设置,不适用于我们现在的Boot项目。

因此需要手动添加一个调试设置,接下来描述如何添加调试设置。

首先在VSCode中打开 .vscode/launch.json 文件,点击右下角的”添加配置“按钮,将会生成配置选择列表:

image-20240811000051935

选择Cortex Debug: ST-LINK,将会生成新的配置代码段:

image-20240811000127056

接着,将这个配置代码段修改为:

        {
            "cwd": "${workspaceFolder}",
            "executable": "${command:STM32VSCodeExtension.bootFlashBootTarget}",
            "name": "Debug Boot Project with ST-Link",
            "device": "STM32H7S7L8HxH", //MCU used
            "svdFile": "${config:STM32VSCodeExtension.cubeCLT.path}/STMicroelectronics_CMSIS_SVD/STM32H7S.svd",
            "serverpath": "${config:STM32VSCodeExtension.cubeCLT.path}/STLink-gdb-server/bin/ST-LINK_gdbserver",
            "stm32cubeprogrammer":"${config:STM32VSCodeExtension.cubeCLT.path}/STM32CubeProgrammer/bin",
            "stlinkPath": "${config:STM32VSCodeExtension.cubeCLT.path}/STLink-gdb-server/bin/ST-LINK_gdbserver",   
            "armToolchainPath": "${config:STM32VSCodeExtension.cubeCLT.path}/GNU-tools-for-STM32/bin",
            "gdbPath":"${config:STM32VSCodeExtension.cubeCLT.path}/GNU-tools-for-STM32/bin/arm-none-eabi-gdb",
            "v1": false,               //Change it depending on ST Link version
            "serverArgs": [
                "-m","1",
            ],
            "request": "launch",
            "type": "cortex-debug",
            "runToEntryPoint": "main",
            "showDevDebugOutput": "none",
            "servertype": "stlink"
        },

4.7 断点调试

打开main.c文件, 在循环内添加断点:

image-20240811000918618

切换到VS Code的调试标签,确认调试配置是刚刚添加的,如果不是可以通过下拉菜单选择;然后点击”开始调试“即可启动调试:

image-20240811001109334

稍等片刻,可以看到已经成功启动调试了:

image-20240811001355123

按下F5,可以跳转到刚刚打下的断点处:

image-20240811001458175

通过顶部的几个悬浮按钮,就可以进行断点调试的常用操作了。

五、参考链接

  1. STM32 公众号推文《全新STM32 VS Code扩展V2.1.0发布》: https://mp.weixin.qq.com/s/rP4aHoTdbVL5ZaArqYosdA
  2. ST官网文章《使用面向VS Code的STM32扩展简化您的开发过程》: https://www.st.com.cn/content/st_com/zh/campaigns/stm32-vs-code-extension-z11.html
  3. STM32CubeMX下载页面: https://www.st.com.cn/zh/development-tools/stm32cubemx.html
  4. STM32CubeCLT下载页面: https://www.st.com.cn/zh/development-tools/stm32cubeclt.html
  5. ST-MCU-FINDER-PC下载页面:https://www.st.com.cn/zh/development-tools/st-mcu-finder-pc.html
  6. VSCode下载页面: https://code.visualstudio.com/Download

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2070878.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

完成单位信息宣传工作考核投稿别输在投稿方法上

在信息化迅速发展的今天,弘扬社会正能量已经成为各个企事业单位的重要使命。作为单位的信息宣传员,我深知信息宣传工作的重要性和复杂性。每个月,我们都肩负着信息宣传考核的任务,需要在指定的媒体上投稿发表文章。然而,刚接触这一工作时,我却经历了一段艰辛而焦虑的历程。 我一…

ubuntu install Miniconda3(轻量级conda)

ubuntu install Miniconda3(轻量级conda) Miniconda3 是一个包含 conda 和 Python 的小型发行版,适合需要灵活定制python环境的用户。 一、下载Miniconda3 sudo apt-get update wget https://repo.anaconda.com/miniconda/Miniconda3-latest…

elasticsearch快照存储到linux本地路径或分布式存储系统mioio

一、使用linux本地目录做快照存储 1.编辑 elasticsearch.yml 文件,添加以下配置: path.repo: ["/path/to/your/backup/dir"]2.创建一个文件系统类型的快照仓库 PUT /_snapshot/my_local_repository {"type": "fs",&quo…

WIN 10 注册表损坏怎么办

系统修复功能 打开“设置”-“更新和安全”-“恢复”-“立即重新启动” 然后就会进入到恢复模式,在里面点“疑难解答”-“高级选项”-“启动修复” SFC工具 在电脑搜索框中输入“命令提示符”,右键点击“命令提示符”选择“以管理员身份运行”。随后在…

前端算法 === 计数排序

目录 计数排序算法的起源 算法的基本原理 算法的实现 代码示例 算法的优势与局限性 计数排序的应用场景 计数排序是一种简单而高效的排序算法,特别适合于处理一定范围内的整数排序问题。它的核心思想是利用额外的存储空间来记录数组中每个元素出现的次数&…

Ansible远程自动化运维

目录 概念 安装ansible modules模块和语法 命令行语法 模块 1. command 基础模块 常用的参数 2. shell模块 3. cron定时任务模块 4. user用户管理模块 参数 5. copy复制模块 参数 6. file模块 设置文件属性 参数 实验:批量创建目录 7…

staticHeader(静态标头)

<!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>staticHeader(静态标头)</title> </head…

C语言函数介绍(上)

函数概念库函数标准库和头文件库函数的使用方法头文件包含库函数文档的一般格式 自定义函数函数的语法形式函数例子 形参和实参实参形参实参和形参的关系 return 语句数组做函数参数 函数概念 数学中我们其实就见过函数的概念&#xff0c;比如&#xff1a;一次函数 ykxb &…

msvcp120.dll丢失是怎么回事?几种靠谱修复msvcp120.dll的方法

在使用基于Windows的计算机进行日常工作或娱乐时&#xff0c;您可能会遇到一个错误消息&#xff1a;“无法启动此程序&#xff0c;因为计算机中丢失msvcp120.dll。”这样的提示通常在尝试启动某些程序或游戏时弹出&#xff0c;导致应用无法正常运行。这个问题通常与系统中的某个…

redis是什么?看着一篇就够了

目录 介绍一下 redis 数据库&#xff1f; redis数据类型与应用场景 redis 为什么更快&#xff1f; redis 怎么实现持久化的&#xff1f; AOF 日志是如何实现的&#xff1f; RDB 快照是如何实现的呢&#xff1f; 混合持久化 redis 单线程在多核机器里使用会不会浪费…

LABVIEW数据保存文件

这里推荐选用CSV文件&#xff1f;为什么&#xff1f; 下表是格式差异造成的容量差异。 具体原因&#xff0c;总结为以下两点&#xff1a; 首先&#xff0c;CSV文件能使用EXCEL打开&#xff0c;方便查阅和借助EXCEL工具进一步处理。 第二&#xff0c;相对来说&#xff0c;CSV…

Web自动化测试:selenium使用详解

&#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 说到自动化测试&#xff0c;就不得不提大名鼎鼎的Selenium。Selenium 是如今最常用的自动化测试工具之一&#xff0c;支持快速开发自动化测试框架&#xff0c;…

深信服上半年亏损5.92亿,营收同比降低2.3亿

吉祥知识星球http://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247485367&idx1&sn837891059c360ad60db7e9ac980a3321&chksmc0e47eebf793f7fdb8fcd7eed8ce29160cf79ba303b59858ba3a6660c6dac536774afb2a6330#rd 《网安面试指南》http://mp.weixin.qq.com/s?…

Qt:玩转QPainter序列二

前言 接着序列一开始序列二。 正文 继续先看源码&#xff0c;下面是分析 1. Q_FLAG(RenderHint) Q_FLAG是Qt宏&#xff0c;用于向Qt的元对象系统&#xff08;Meta-Object System&#xff09;注册枚举值&#xff0c;以便可以在Qt的元对象系统中使用这些枚举值。例如&#…

SD 卡无法读取?这十大方法助你轻松修复!

在我们的日常生活中&#xff0c;SD 卡被广泛应用于各种设备&#xff0c;如数码相机、手机、平板电脑等。然而&#xff0c;有时我们可能会遇到 SD 卡无法读取的情况&#xff0c;这让人十分苦恼。别担心&#xff0c;下面为你介绍多种修复 SD 卡无法读取问题的方法。 一、检查硬件…

如何知道当前网卡连接的下位机的IP,通过工具实现

要确定当前网卡连接的下位机的 IP 地址&#xff0c;可以使用以下几种工具和方法来实现。 1. 使用 arp-scan 工具 arp-scan 是一个强大的网络扫描工具&#xff0c;可以用于扫描网络上的设备并显示它们的 IP 和 MAC 地址。 安装 arp-scan&#xff1a; sudo apt update sudo a…

合宙LuatOS开发板使用说明——Air700ECQ

EVB-Air700ECQ-IO 开发板是合宙通信推出的基于 Air700ECQ 模组所开发的&#xff0c;包含电 源&#xff0c; SIM 卡&#xff0c;USB &#xff0c;天 线&#xff0c; 全 IO 引 出的最 小硬 件系 统。以 方便 用户 在设 计前期 对 Air700ECQ 模块进行性能评估&#xff0c;功能调试…

AutoMapperSQL

AutoMapperSQL--Mybatis实用小工具&#xff1a;根据数据模型、数据访问接口自动生成 mysql、sql server、oracle 三种数据源类型的表脚本及mybatis接口类对应的mapper-xml文件。 1、指定数据访问接口 mapper interface 目录路径&#xff1b; 2、指定数据模型目录路径&#xff1…

机器学习-OpenCV运用(1)

文章目录 一、OpenCV介绍二、OpenCV运用1.读取保存图片2.读取视频3.图像切片 一、OpenCV介绍 OpenCV&#xff08;Open Source Computer Vision Library&#xff09;是一个开源的计算机视觉和机器学习软件库&#xff0c;它主要用于实时的图像处理和计算机视觉任务。虽然OpenCV本…

ARM架构与ARM内核

参考&#xff1a;https://blog.csdn.net/qq_34160841/article/details/105611131 到底什么是Cortex、ARMv8、arm架构、ARM指令集、soc&#xff1f;一文帮你梳理基础概念 认识ARM、Cortex-M内核&#xff0c;以及ARMv8-M架构 ARM架构 ARM的架构指的是ARM的指令集架构。ARM指令集…