# VS Code Configuration
Example configurations for debugging programs in-editor with VS Code.
This directory contains configurations for two platforms:
- `LM3S6965EVB` on QEMU
- `STM32F303x` via OpenOCD
## Required Extensions
If you have the `code` command in your path, you can run the following commands to install the necessary extensions.
```sh
code --install-extension rust-lang.rust
code --install-extension marus25.cortex-debug
```
Otherwise, you can use the Extensions view to search for and install them, or go directly to their marketplace pages and click the "Install" button.
- [Rust Language Server (RLS)](https://marketplace.visualstudio.com/items?itemName=rust-lang.rust)
- [Cortex-Debug](https://marketplace.visualstudio.com/items?itemName=marus25.cortex-debug)
## Use
The quickstart comes with two debug configurations.
Both are configured to build the project, using the default settings from `.cargo/config`, prior to starting a debug session.
1. QEMU: Starts a debug session using an emulation of the `LM3S6965EVB` mcu.
- This works on a fresh `cargo generate` without modification of any of the settings described above.
- Semihosting output will be written to the Output view `Adapter Output`.
- `ITM` logging does not work with QEMU emulation.
2. OpenOCD: Starts a debug session for a `STM32F3DISCOVERY` board (or any `STM32F303x` running at 8MHz).
- Follow the instructions above for configuring the build with `.cargo/config` and the `memory.x` linker script.
- `ITM` output will be written to the Output view `SWO: ITM [port: 0, type: console]` output.
### Git
Files in the `.vscode/` directory are `.gitignore`d by default because many files that may end up in the `.vscode/` directory should not be committed and shared.
If you would like to save this debug configuration to your repository and share it with your team, you'll need to explicitly `git add` the files to your repository.
```sh
git add -f .vscode/launch.json
git add -f .vscode/tasks.json
git add -f .vscode/*.svd
```
## Customizing for other targets
For full documentation, see the [Cortex-Debug][cortex-debug] repository.
### Device
Some configurations use this to automatically find the SVD file.
Replace this with the part number for your device.
```json
"device": "STM32F303VCT6",
```
### OpenOCD Config Files
The `configFiles` property specifies a list of files to pass to OpenOCD.
```json
"configFiles": [
"interface/stlink-v2-1.cfg",
"target/stm32f3x.cfg"
],
```
See the [OpenOCD config docs][openocd-config] for more information and the [OpenOCD repository for available configuration files][openocd-repo].
### SVD
The SVD file is a standard way of describing all registers and peripherals of an ARM Cortex-M mCU.
Cortex-Debug needs this file to display the current register values for the peripherals on the device.
You can probably find the SVD for your device on the vendor's website.
For example, the STM32F3DISCOVERY board uses an mcu from the `STM32F303x` line of processors.
All the SVD files for the STM32F3 series are available on [ST's Website][stm32f3].
Download the [stm32f3 SVD pack][stm32f3-svd], and copy the `STM32F303.svd` file into `.vscode/`.
This line of the config tells the Cortex-Debug plug in where to find the file.
```json
"svdFile": "${workspaceRoot}/.vscode/STM32F303.svd",
```
For other processors, simply copy the correct `*.svd` file into the project and update the config accordingly.
### CPU Frequency
If your device is running at a frequency other than 8MHz, you'll need to modify this line of `launch.json` for the `ITM` output to work correctly.
```json
"cpuFrequency": 8000000,
```
### Other GDB Servers
For information on setting up GDB servers other than OpenOCD, see the [Cortex-Debug repository][cortex-debug].
[cortex-debug]: https://github.com/Marus/cortex-debug
[stm32f3]: https://www.st.com/content/st_com/en/products/microcontrollers-microprocessors/stm32-32-bit-arm-cortex-mcus/stm32-mainstream-mcus/stm32f3-series.html#resource
[stm32f3-svd]: https://www.st.com/resource/en/svd/stm32f3_svd.zip
[openocd-config]: http://openocd.org/doc/html/Config-File-Guidelines.html
[openocd-repo]: https://sourceforge.net/p/openocd/code/ci/master/tree/tcl/
![avatar](https://profile-avatar.csdnimg.cn/default.jpg!1)
快撑死的鱼
- 粉丝: 2w+
- 资源: 9155
最新资源
- COMSOL模拟下的二氧化碳驱替瓦斯技术研究,利用COMSOL模拟分析二氧化碳驱替瓦斯的技术研究,comsol注二氧化碳驱替瓦斯 ,COMSOL; 注二氧化碳; 驱替; 瓦斯,COMSOL模拟:二氧化
- Simulink仿真:单电感双向电池均衡电路的设计与实现-基于Buck-Boost变换器与开关矩阵的高效均衡策略(涉及CSCD,EI,CSTPCD技术),基于MATLAB Simulink的单电感双
- 基于模糊控制的扰动观察法:光伏MPPT改进算法的仿真研究与分析,基于模糊控制的改进型扰动观察法在光伏MPPT中的仿真研究,Simulink仿真:基于扰动观察法的光伏MPPT改进算法 参考文献:基于扰动
- Axhub 谷歌(Chrome)浏览器插件
- 大华摄像头IE浏览器插件webplugin.exe(Web视频播放控件-v2.0.1.7)
- 深度探究:一阶与二阶自抗扰模型的构建及其实现在自己搭建的Simulink仿真模型中的封装与应用,一阶二阶自抗扰模型解析及其在自主搭建Simulink仿真模型中的应用,已封装,简捷调参,一阶 二阶自抗扰
- 办公自动化中Word与WPS接入DeepSeek R1
- 小费数据集,包含餐厅顾客的小费数据,包括账单总金额、给出的小费金额、顾客的人口统计信息以及用餐详情
- 【网页制作期末/课程设计】家乡网站
- 房屋租售系统spring+jsp+mysql
- 帕尔默企鹅数据集.zip
- AutoCAD ObjectArx2016
- AVPro Video-Editions
- 三相并网虚拟同步机VSG模型的有功功率突变过程仿真及系统稳定性研究,三相并网虚拟同步机VSG模型仿真:有功功率突变下的系统稳定性分析与原理学习,同步机(VSG)三相并网仿真模型 有功功率从20k突变到
- 基于JavaWeb(JSP)+MySQL图书销售管理系统(网上书店)源码
- Delphi 12 控件之sfk189.7z
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
![feedback](https://img-home.csdnimg.cn/images/20220527035711.png)
![feedback](https://img-home.csdnimg.cn/images/20220527035711.png)
![feedback-tip](https://img-home.csdnimg.cn/images/20220527035111.png)