Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
48ce24b303 | ||
|
|
3dc0cf09db | ||
|
|
59b8b866c7 | ||
|
|
1bb99c92f1 | ||
|
|
d41dd6a4c7 |
3
.gdbinit
3
.gdbinit
@@ -1,5 +1,8 @@
|
||||
target remote :3333
|
||||
|
||||
# print demangled symbols by default
|
||||
set print asm-demangle on
|
||||
|
||||
monitor arm semihosting enable
|
||||
|
||||
# # send captured ITM to the file itm.fifo
|
||||
|
||||
10
Cargo.toml
10
Cargo.toml
@@ -6,7 +6,7 @@ keywords = ["arm", "cortex-m", "template"]
|
||||
license = "MIT OR Apache-2.0"
|
||||
name = "cortex-m-quickstart"
|
||||
repository = "https://github.com/japaric/cortex-m-quickstart"
|
||||
version = "0.2.1"
|
||||
version = "0.2.2"
|
||||
|
||||
[dependencies]
|
||||
cortex-m = "0.3.0"
|
||||
@@ -14,7 +14,13 @@ cortex-m-semihosting = "0.2.0"
|
||||
|
||||
[dependencies.cortex-m-rt]
|
||||
features = ["abort-on-panic"]
|
||||
version = "0.3.3"
|
||||
version = "0.3.12"
|
||||
|
||||
# disable both incremental compilation and parallel codegen to reduce the chances of running into
|
||||
# rust-lang/rust#47074
|
||||
[profile.dev]
|
||||
codegen-units = 1
|
||||
incremental = false
|
||||
|
||||
[profile.release]
|
||||
debug = true
|
||||
|
||||
31
src/lib.rs
31
src/lib.rs
@@ -310,6 +310,37 @@
|
||||
//! ```
|
||||
//!
|
||||
//! Solution: Use `arm-none-eabi-gdb target/..`
|
||||
//!
|
||||
//! # Used a named piped for `itm.fifo`
|
||||
//!
|
||||
//! Error message:
|
||||
//!
|
||||
//! ``` text
|
||||
//! $ xargo run [--example ..]
|
||||
//!
|
||||
//! Reading symbols from target/thumbv7em-none-eabihf/debug/cortex-m-quickstart...done.
|
||||
//! cortex_m_rt::reset_handler ()
|
||||
//! at $REGISTRY/cortex-m-rt-0.3.12/src/lib.rs:330
|
||||
//! 330 unsafe extern "C" fn reset_handler() -> ! {
|
||||
//! semihosting is enabled
|
||||
//! Ignoring packet error, continuing...
|
||||
//! Ignoring packet error, continuing...
|
||||
//! ```
|
||||
//!
|
||||
//! Note that when you reach this point OpenOCD will become unresponsive and you'll have to kill it
|
||||
//! and start a new OpenOCD process before you can invoke `xargo run` / start GDB.
|
||||
//!
|
||||
//! Cause: You uncommented the `monitor tpiu ..` line in `.gdbinit` and are using a named pipe to
|
||||
//! receive the ITM data (i.e. you ran `mkfifo itm.fifo`). This error occurs when `itmdump -f
|
||||
//! itm.fifo` (or equivalent, e.g. `cat itm.fifo`) is not running.
|
||||
//!
|
||||
//! Solution: Run `itmdump -f itm.fifo` (or equivalently `cat itm.fifo`) *before* invoking `xargo
|
||||
//! run` / starting GDB. Note that sometimes `itmdump` will exit when the GDB session ends. In that
|
||||
//! case you'll have to run `itmdump` before you start the next GDB session.
|
||||
//!
|
||||
//! Alternative solution: Use a plain text file instead of a named pipe. In this scenario you omit
|
||||
//! the `mkfifo itm.dump` command. You can use `itmdump`'s *follow* mode (-F) to get named pipe like
|
||||
//! output.
|
||||
|
||||
#![no_std]
|
||||
|
||||
|
||||
Reference in New Issue
Block a user