aboutsummaryrefslogtreecommitdiff
path: root/examples/rp/src/bin
diff options
context:
space:
mode:
authorUlf Lilleengen <[email protected]>2022-11-17 09:26:15 +0100
committerUlf Lilleengen <[email protected]>2022-11-18 11:22:58 +0100
commita444a65ebfcea674e74dcedc7f26a7aa37f59c69 (patch)
tree49ed7bb77196dcba8ca5a4ebab9fb555d1877a7a /examples/rp/src/bin
parent2528f451387e6c7b27c3140cd87d47521d1971a2 (diff)
feat: embassy-usb-logger and example for rpi pico
* Add embassy-usb-logger which allows logging over USB for any device implementing embassy-usb * Add example using logger for rpi pico.
Diffstat (limited to 'examples/rp/src/bin')
-rw-r--r--examples/rp/src/bin/usb_logger.rs30
1 files changed, 30 insertions, 0 deletions
diff --git a/examples/rp/src/bin/usb_logger.rs b/examples/rp/src/bin/usb_logger.rs
new file mode 100644
index 000000000..52417a02e
--- /dev/null
+++ b/examples/rp/src/bin/usb_logger.rs
@@ -0,0 +1,30 @@
1#![no_std]
2#![no_main]
3#![feature(type_alias_impl_trait)]
4
5use embassy_executor::Spawner;
6use embassy_rp::interrupt;
7use embassy_rp::peripherals::USB;
8use embassy_rp::usb::Driver;
9use embassy_time::{Duration, Timer};
10use {defmt_rtt as _, panic_probe as _};
11
12#[embassy_executor::task]
13async fn logger_task(driver: Driver<'static, USB>) {
14 embassy_usb_logger::run!(1024, log::LevelFilter::Info, driver);
15}
16
17#[embassy_executor::main]
18async fn main(spawner: Spawner) {
19 let p = embassy_rp::init(Default::default());
20 let irq = interrupt::take!(USBCTRL_IRQ);
21 let driver = Driver::new(p.USB, irq);
22 spawner.spawn(logger_task(driver)).unwrap();
23
24 let mut counter = 0;
25 loop {
26 counter += 1;
27 log::info!("Tick {}", counter);
28 Timer::after(Duration::from_secs(1)).await;
29 }
30}