Update probe-rs tools to 0.19 (#64)

* Update probe-rs tools to 0.19

* Restore rp2040_boot2 line

* Update runner to use probe-rs run 0.19 syntax

* Update vscode launch command for probe-rs debugger

* Add note about removing older installation of cargo-embed

If you had previously installed cargo-embed separately, it will conflict with the new way probe-rs installs multiple binaries at once.

* Update README.md

Co-authored-by: 9names <60134748+9names@users.noreply.github.com>

---------

Co-authored-by: Jan Niehusmann <jan@gondor.com>
This commit is contained in:
9names 2023-07-27 07:45:43 +10:00 committed by GitHub
parent 4db7b897e6
commit de42e40358
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 19 additions and 22 deletions

View File

@ -2,10 +2,10 @@
# Choose a default "cargo run" tool: # Choose a default "cargo run" tool:
# - probe-run provides flashing and defmt via a hardware debugger, and stack unwind on panic # - probe-run provides flashing and defmt via a hardware debugger, and stack unwind on panic
# - elf2uf2-rs loads firmware over USB when the rp2040 is in boot mode # - elf2uf2-rs loads firmware over USB when the rp2040 is in boot mode
# - "probe-rs-cli run" is similar to probe-run but it uses the latest probe-rs lib crate # - "probe-rs run" is similar to probe-run but it uses the latest probe-rs lib crate
runner = "probe-run --chip RP2040" runner = "probe-run --chip RP2040"
# runner = "elf2uf2-rs -d" # runner = "elf2uf2-rs -d"
# runner = "probe-rs-cli run --chip RP2040 --protocol swd" # runner = "probe-rs run --chip RP2040 --protocol swd"
rustflags = [ rustflags = [
"-C", "linker=flip-link", "-C", "linker=flip-link",

4
.vscode/launch.json vendored
View File

@ -12,9 +12,9 @@
// RP2040 doesn't support connectUnderReset // RP2040 doesn't support connectUnderReset
"connectUnderReset": false, "connectUnderReset": false,
"speed": 4000, "speed": 4000,
"runtimeExecutable": "probe-rs-debugger", "runtimeExecutable": "probe-rs",
"runtimeArgs": [ "runtimeArgs": [
"debug" "dap-server"
], ],
"flashingConfig": { "flashingConfig": {
"flashingEnabled": true, "flashingEnabled": true,

View File

@ -61,7 +61,10 @@ cargo install flip-link
cargo install probe-run --locked cargo install probe-run --locked
# If you want to use elf2uf2-rs instead of probe-run, instead do... # If you want to use elf2uf2-rs instead of probe-run, instead do...
cargo install elf2uf2-rs --locked cargo install elf2uf2-rs --locked
# If you want to use any of the probe-rs tools (probe-rs run, cargo-embed, probe-rs-debugger)
cargo install probe-rs --features=cli --locked
``` ```
If you get the error ``binary `cargo-embed` already exists`` during installation of probe-rs, run `cargo uninstall cargo-embed` to uninstall your older version of cargo-embed before trying again.
</details> </details>
@ -129,15 +132,15 @@ If you don't have a debug probe or if you want to do interactive debugging you c
Some of the options for your `runner` are listed below: Some of the options for your `runner` are listed below:
* **cargo embed** * **cargo embed**
*Step 1* - Install [`cargo embed`](https://github.com/probe-rs/probe-rs/blob/master/cargo-embed): *Step 1* - Install cargo-embed. This is part of the [`probe-rs`](https://crates.io/crates/probe-rs) crate:
```console ```console
$ cargo install --locked cargo-embed $ cargo install probe-rs --features=cli --locked
``` ```
*Step 2* - Update settings in [Embed.toml](./Embed.toml) *Step 2* - Update settings in [Embed.toml](./Embed.toml)
- The defaults are to flash, reset, and start a defmt logging session - The defaults are to flash, reset, and start a defmt logging session
You can find all the settings and their meanings [in the cargo-embed repo](https://github.com/probe-rs/probe-rs/blob/master/cargo-embed/src/config/default.toml) You can find all the settings and their meanings [in the probe-rs repo](https://github.com/probe-rs/probe-rs/blob/c0610e98008cbb34d0dc056fcddff0f2d4f50ad5/probe-rs/src/bin/probe-rs/cmd/cargo_embed/config/default.toml)
*Step 3* - Use the command `cargo embed`, which will compile the code, flash the device *Step 3* - Use the command `cargo embed`, which will compile the code, flash the device
and start running the configuration specified in Embed.toml and start running the configuration specified in Embed.toml
@ -147,35 +150,31 @@ Some of the options for your `runner` are listed below:
``` ```
* **probe-rs-debugger** * **probe-rs-debugger**
*Step 1* - Install Visual Studio Code from https://code.visualstudio.com/
*Step 1* - Download [`probe-rs-debugger VSCode plugin 0.4.0`](https://github.com/probe-rs/vscode/releases/download/v0.4.0/probe-rs-debugger-0.4.0.vsix) *Step 2* - Install `probe-rs`
*Step 2* - Install `probe-rs-debugger VSCode plugin`
```console ```console
$ code --install-extension probe-rs-debugger-0.4.0.vsix $ cargo install probe-rs --features=cli --locked
``` ```
*Step 3* - Install `probe-rs-debugger` *Step 3* - Open this project in VSCode
```console
$ cargo install probe-rs-debugger
```
*Step 4* - Open this project in VSCode *Step 4* - Install `debugger for probe-rs` via the VSCode extensions menu (View > Extensions)
*Step 5* - Launch a debug session by choosing `Run`>`Start Debugging` (or press F5) *Step 5* - Launch a debug session by choosing `Run`>`Start Debugging` (or press F5)
* **probe-rs-cli** * **probe-rs run**
*Step 1* - Install [`probe-rs-cli`](https://crates.io/crates/probe-rs-cli): *Step 1* - Install [`probe-rs`](https://crates.io/crates/probe-rs-cli):
```console ```console
$ cargo install probe-rs-cli $ cargo install probe-rs --features=cli --locked
``` ```
*Step 2* - Make sure your .cargo/config contains the following *Step 2* - Make sure your .cargo/config contains the following
```toml ```toml
[target.thumbv6m-none-eabi] [target.thumbv6m-none-eabi]
runner = "probe-rs-cli run --chip RP2040 --protocol swd" runner = "probe-rs run --chip RP2040 --protocol swd"
``` ```
*Step 3* - Use `cargo run`, which will compile the code and start the *Step 3* - Use `cargo run`, which will compile the code and start the
@ -230,8 +229,6 @@ Some of the options for your `runner` are listed below:
information in the ELF file in a way that `picotool info` can read it out, are information in the ELF file in a way that `picotool info` can read it out, are
not supported in Rust. An alternative is TBC. not supported in Rust. An alternative is TBC.
</details>
</details> </details>
<!-- Notes on using rp2040_hal and rp2040_boot2 --> <!-- Notes on using rp2040_hal and rp2040_boot2 -->
<details open="open"> <details open="open">