From 39b303446d6622ebb94a71a49a4daf1b709f2831 Mon Sep 17 00:00:00 2001 From: dogeystamp Date: Sat, 6 Apr 2024 22:38:54 -0400 Subject: [PATCH] add usb serial logger --- src/bin/blinky.rs | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/src/bin/blinky.rs b/src/bin/blinky.rs index 3dd0a16..2850819 100644 --- a/src/bin/blinky.rs +++ b/src/bin/blinky.rs @@ -2,23 +2,38 @@ #![no_main] use defmt::*; +use embassy_rp::bind_interrupts; +use embassy_rp::peripherals::USB; +use embassy_rp::usb::{Driver, InterruptHandler}; use embassy_executor::Spawner; use embassy_rp::gpio; use embassy_time::Timer; use gpio::{Level, Output}; use {defmt_rtt as _, panic_probe as _}; +bind_interrupts!(struct Irqs { + USBCTRL_IRQ => InterruptHandler; +}); + +#[embassy_executor::task] +async fn logger_task(driver: Driver<'static, USB>) { + embassy_usb_logger::run!(1024, log::LevelFilter::Info, driver); +} + #[embassy_executor::main] async fn main(_spawner: Spawner) { let p = embassy_rp::init(Default::default()); let mut led = Output::new(p.PIN_25, Level::Low); + let driver = Driver::new(p.USB, Irqs); + _spawner.spawn(logger_task(driver)).unwrap(); + loop { - info!("led on!"); + log::info!("led on!"); led.set_high(); Timer::after_millis(100).await; - info!("led off!"); + log::info!("led off!"); led.set_low(); Timer::after_secs(1).await; }