Provides print!
, println!
and dbg!
implementations for various Espressif devices.
esp-hal
, one optional dependency is log
, another is critical-section
)no-op
features turns printing into a no-opThe cli utility should work for flashing and showing RTT logs on ESP32-C3 by using it's run
command.
You need to use the direct-boot
feature of the HAL to flash via probe-rs.
In your Cargo.toml
, under [dependencies]
, add:
esp-println = { version = "0.3.1", features = ["esp32"] }
Choose a recent version and your chipset.
Then in your program:
use esp_println::println;
You can now println!("Hello world")
as usual.
With the feature log
activated you can initialize a simple logger like this
rust
init_logger(log::LevelFilter::Info);
There is a default feature colors
which enables colored log output.
Additionally you can use
rust
init_logger_from_env();
In this case the following environment variables are used:
- ESP_LOGLEVEL
sets the log level, use values like trace
, info
etc.
- ESP_LOGTARGETS
if set you should provide the crate names of crates (optionally with a path e.g. esp_wifi::compat::common
) which should get logged, separated by ,
and no additional whitespace between
If this simple logger implementation isn't sufficient for your needs you can implement your own logger on top of esp-println
- see https://docs.rs/log/0.4.17/log/#implementing-a-logger
Licensed under either of:
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.