aboutsummaryrefslogtreecommitdiff
path: root/examples/rp/src/bin
diff options
context:
space:
mode:
authorbors[bot] <26634292+bors[bot]@users.noreply.github.com>2022-11-21 22:52:58 +0000
committerGitHub <[email protected]>2022-11-21 22:52:58 +0000
commit15b4ed2c672a853cf9bb5cfb8aae323430de0c67 (patch)
treee10b7748e433b6b4b776cfe178b3676f49ebcf06 /examples/rp/src/bin
parentbbfb7861390ac00d9a54d6f0f1ed41e74ed4a86d (diff)
parent06fb3e425198609131e149c39a2db25aaa8c273c (diff)
Merge #1060
1060: feat: embassy-usb-logger and example for rpi pico r=Dirbaio a=lulf * Add embassy-usb-logger which allows logging over USB for any device implementing embassy-usb * Add example using logger for rpi pico Co-authored-by: Ulf Lilleengen <[email protected]>
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}