onyx/.vscode
Edward Shen 3778b54ee5
used quickstart
2020-01-25 15:49:11 -05:00
..
README.md used quickstart 2020-01-25 15:49:11 -05:00
launch.json used quickstart 2020-01-25 15:49:11 -05:00
tasks.json used quickstart 2020-01-25 15:49:11 -05:00

README.md

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.

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.

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.

Note: When you open the project in the editor, you must open an *.rs file to trigger the Rust Language Server. Failure to do so will cause a failure to find the build task.

  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 .gitignored 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.

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 repository.

Device

Some configurations use this to automatically find the SVD file.
Replace this with the part number for your device.

"device": "STM32F303VCT6",

OpenOCD Config Files

The configFiles property specifies a list of files to pass to OpenOCD.

"configFiles": [
    "interface/stlink-v2-1.cfg",
    "target/stm32f3x.cfg"
],

See the OpenOCD config docs for more information and the OpenOCD repository for available configuration files.

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.
Download the stm32f3 SVD pack, and copy the STM32F303.svd file into .vscode/.
This line of the config tells the Cortex-Debug plug in where to find the file.

"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.

"cpuFrequency": 8000000,

Other GDB Servers

For information on setting up GDB servers other than OpenOCD, see the Cortex-Debug repository.