mirror of
https://github.com/rust-embedded/awesome-embedded-rust.git
synced 2025-03-02 09:01:00 +00:00
Merge pull request #469 from rust-embedded/fix/dont-panic
feat: ✨ Add panic handling section
This commit is contained in:
commit
9ea991515b
1 changed files with 32 additions and 3 deletions
35
README.md
35
README.md
|
@ -85,6 +85,7 @@ This project is developed and maintained by the [Resources team][team].
|
|||
- [WIP](#wip)
|
||||
- [no-std crates](#no-std-crates)
|
||||
- [WIP](#wip-1)
|
||||
- [Panic handling](#panic-handling)
|
||||
- [Firmware projects](#firmware-projects)
|
||||
- [Old books, blogs, and training materials](#old-books-blogs-and-training-materials)
|
||||
- [License](#license)
|
||||
|
@ -1277,7 +1278,6 @@ Work in progress drivers. Help the authors make these crates awesome!
|
|||
1. [nom](https://crates.io/crates/nom): parser combinator framework - [data:image/s3,"s3://crabby-images/5c031/5c031b3bb2f95b363239216a5da3af5ad4545e14" alt="crates.io"](https://crates.io/crates/nom)
|
||||
1. [null-terminated](https://crates.io/crates/null-terminated): generic null-terminated arrays - [data:image/s3,"s3://crabby-images/967e4/967e4bc4f8789f67f4016f5dc9d60f51e74afa66" alt="crates.io"](https://crates.io/crates/null-terminated)
|
||||
1. [num-format](https://crates.io/crates/num-format): Crate for producing string representations of numbers, formatted according to international standards, e.g. "1,000,000" for US English - [data:image/s3,"s3://crabby-images/730b0/730b0fcd7ca1f57d0f6f8f65e1290fd2213eeca6" alt="crates.io"](https://crates.io/crates/num-format)
|
||||
1. [`panic-persist`]: A panic handler crate inspired by `panic-ramdump` that logs panic messages to a region of RAM defined by the user, allowing for discovery of panic messages post-mortem using normal program control flow. - [data:image/s3,"s3://crabby-images/20358/203589b6952719c021c14492e88f1f39152a95d5" alt="crates.io"](https://crates.io/crates/panic-persist)
|
||||
1. [pc-keyboard]: A PS/2 keyboard protocol driver. Transport (bit-banging or SPI) agnostic, but can convert Set 2 Scancodes into Unicode. [data:image/s3,"s3://crabby-images/464cb/464cb195a65d9e4da01b5144729a9bf46cd5ab6a" alt="crates.io"](https://crates.io/crates/pc-keyboard)
|
||||
1. [qei](https://crates.io/crates/qei) : A qei wrapper that allows you to extend your qei timers from a 16-bit integer to a 64-bit integer. - [data:image/s3,"s3://crabby-images/c373f/c373f5650ada929c8b3d14d40d9c7555b909427e" alt="crates.io"](https://crates.io/crates/qei)
|
||||
1. [qemu-exit]: Quit a running QEMU session with user-defined exit code. Useful for unit or integration tests using QEMU. - [data:image/s3,"s3://crabby-images/5002d/5002d81adbbf7e36ba8dfd66f3c57fc68ae5ceb6" alt="crates.io"](https://crates.io/crates/qemu-exit)
|
||||
|
@ -1299,8 +1299,8 @@ Work in progress drivers. Help the authors make these crates awesome!
|
|||
1. [adafruit-bluefruit-protocol]: A `no_std` parser for the [Adafruit Bluefruit LE Connect controller protocol]. - [data:image/s3,"s3://crabby-images/e263f/e263fb3543009f90e8fae12d985691a021fbf71a" alt="crates.io"](https://crates.io/crates/adafruit-bluefruit-protocol)
|
||||
1. [wtx](https://github.com/c410-f3r/wtx): Among other things, provides implementations to interact with HTTP, WebSockets and Databases.
|
||||
|
||||
[no-std-category]: https://crates.io/categories/no-std
|
||||
[`cmim`]: https://crates.io/crates/cmim
|
||||
[`panic-persist`]: https://crates.io/crates/panic-persist
|
||||
[bitmatch]: https://crates.io/crates/bitmatch
|
||||
[biquad]: https://crates.io/crates/biquad
|
||||
[embassy]: https://github.com/akiles/embassy
|
||||
|
@ -1326,7 +1326,36 @@ Work in progress crates. Help the authors make these crates awesome!
|
|||
- [OxCC](https://github.com/jonlamb-gh/oxcc): A port of Open Source Car Control written in Rust
|
||||
- [Rubble](https://github.com/jonas-schievink/rubble): A pure-Rust embedded BLE stack [data:image/s3,"s3://crabby-images/9b43b/9b43bd8aa02c88e3b8927a0690e207717957fb8e" alt="crates.io"](https://crates.io/crates/rubble)
|
||||
|
||||
[no-std-category]: https://crates.io/categories/no-std
|
||||
## Panic handling
|
||||
|
||||
There are many ways to handle panics in embedded devices, these crates provide helpful variants.
|
||||
|
||||
1. [`dont_panic`] + [`dont_panic_slice`]: panic!()-like macro that causes linking error instead of panicking. May be used to statically ensure some code won't panic. [data:image/s3,"s3://crabby-images/55779/55779e17471a67d0647246a61e3800dc60701653" alt="crates.io"](https://crates.io/crates/dont_panic) + [data:image/s3,"s3://crabby-images/492de/492dea7e7d9a6c16bef0d1e1885a1fe58a3ec5bc" alt="crates.io"](https://crates.io/crates/dont_panic_slice)
|
||||
1. [`no-panic`]: Attribute macro to require that the compiler prove a function can't ever panic. [data:image/s3,"s3://crabby-images/7e9b8/7e9b852d574ca9ba15dd6097b9dbe8a53e0a0e1e" alt="crates.io"](https://crates.io/crates/no-panic)
|
||||
1. [`panic-abort`]: Causes an abort on panics (nightly-only) [data:image/s3,"s3://crabby-images/8f91a/8f91a503ee4e71a7ea94fa18bd45e7079af923cb" alt="crates.io"](https://crates.io/crates/panic-abort)
|
||||
1. [`panic-halt`]: Halts the processor on panics [data:image/s3,"s3://crabby-images/8aa24/8aa242b716eace7b9635dcaa9b2925d0db1a1d26" alt="crates.io"](https://crates.io/crates/panic-halt)
|
||||
1. [`panic-itm`]: Prints the panic through the chip's ITM to a debugger attached to the SWO pin (Cortex-M with ITM only)
|
||||
1. [`panic-never`]: This crate guarantees that your application is free of panicking branches. [data:image/s3,"s3://crabby-images/90e7a/90e7a6adec7ffd18cc3054ccbc9d1a2b137a8e7e" alt="crates.io"](https://crates.io/crates/panic-never)
|
||||
1. [`panic-persist`]: A panic handler crate inspired by `panic-ramdump` that logs panic messages to a region of RAM defined by the user, allowing for discovery of panic messages post-mortem using normal program control flow. - [data:image/s3,"s3://crabby-images/20358/203589b6952719c021c14492e88f1f39152a95d5" alt="crates.io"](https://crates.io/crates/panic-persist)
|
||||
1. [`panic-probe`]: A panic handler that exits `probe-run` with an error code. [data:image/s3,"s3://crabby-images/e0816/e081643961ebb140a40cbffad8d81efc6ecca911" alt="crates.io"](https://crates.io/crates/panic-probe)
|
||||
1. [`panic-ramdump`]: Writes the panic message into the beginning of RAM and enters an infinite loop; the message can be extracted by attaching a debugger (Cortex-M only) [data:image/s3,"s3://crabby-images/c792c/c792c52241662c6d071b392ba5a1a26bfdc50331" alt="crates.io"](https://crates.io/crates/panic-ramdump)
|
||||
1. [`panic-rtt`]: Set the panicking behavior to log to a JLINK debugger and loop. [data:image/s3,"s3://crabby-images/6f64a/6f64ad9d018d0c73273486629246436fe2f1fe44" alt="crates.io"](https://crates.io/crates/panic_rtt)
|
||||
1. [`panic-rtt-target`]: Logs panic messages over RTT. Uses `rtt-target`. [data:image/s3,"s3://crabby-images/122e5/122e5b6722e996182334ec517f02c9203b32a168" alt="crates.io"](https://crates.io/crates/panic-rtt-target)
|
||||
1. [`panic-semihosting`]: Prints the panic message via semihosting to an attached debugger (Cortex-M only)
|
||||
|
||||
[`dont_panic_slice`]: https://crates.io/crates/dont_panic_slice
|
||||
[`dont_panic`]: https://crates.io/crates/dont_panic
|
||||
[`no-panic`]: https://crates.io/crates/no-panic
|
||||
[`panic-abort`]: https://crates.io/crates/panic-abort
|
||||
[`panic-halt`]: https://crates.io/crates/panic-halt
|
||||
[`panic-itm`]: https://github.com/rust-embedded/cortex-m/tree/master/panic-itm
|
||||
[`panic-never`]: https://crates.io/crates/panic-never
|
||||
[`panic-persist`]: https://crates.io/crates/panic-persist
|
||||
[`panic-probe`]: https://crates.io/crates/panic-probe
|
||||
[`panic-ramdump`]: https://crates.io/crates/panic-ramdump
|
||||
[`panic-rtt`]: https://crates.io/crates/panic_rtt
|
||||
[`panic-rtt-target`]: https://crates.io/crates/panic-rtt-target
|
||||
[`panic-semihosting`]: https://github.com/rust-embedded/panic-semihosting
|
||||
|
||||
## Firmware projects
|
||||
|
||||
|
|
Loading…
Reference in a new issue