Added new param to examples and created a pico plus 2 w example
This commit is contained in:
		
							parent
							
								
									dd31ffadfb
								
							
						
					
					
						commit
						8243a8a389
					
				| @ -7,7 +7,7 @@ | ||||
| 
 | ||||
| use core::str::from_utf8; | ||||
| 
 | ||||
| use cyw43_pio::PioSpi; | ||||
| use cyw43_pio::{PioSpi, DEFAULT_CLOCK_DIVIDER}; | ||||
| use defmt::*; | ||||
| use embassy_executor::Spawner; | ||||
| use embassy_net::tcp::TcpSocket; | ||||
| @ -57,7 +57,16 @@ async fn main(spawner: Spawner) { | ||||
|     let pwr = Output::new(p.PIN_23, Level::Low); | ||||
|     let cs = Output::new(p.PIN_25, Level::High); | ||||
|     let mut pio = Pio::new(p.PIO0, Irqs); | ||||
|     let spi = PioSpi::new(&mut pio.common, pio.sm0, pio.irq0, cs, p.PIN_24, p.PIN_29, p.DMA_CH0); | ||||
|     let spi = PioSpi::new( | ||||
|         &mut pio.common, | ||||
|         pio.sm0, | ||||
|         DEFAULT_CLOCK_DIVIDER, | ||||
|         pio.irq0, | ||||
|         cs, | ||||
|         p.PIN_24, | ||||
|         p.PIN_29, | ||||
|         p.DMA_CH0, | ||||
|     ); | ||||
| 
 | ||||
|     static STATE: StaticCell<cyw43::State> = StaticCell::new(); | ||||
|     let state = STATE.init(cyw43::State::new()); | ||||
|  | ||||
| @ -5,7 +5,7 @@ | ||||
| #![no_std] | ||||
| #![no_main] | ||||
| 
 | ||||
| use cyw43_pio::PioSpi; | ||||
| use cyw43_pio::{PioSpi, DEFAULT_CLOCK_DIVIDER}; | ||||
| use defmt::*; | ||||
| use embassy_executor::Spawner; | ||||
| use embassy_rp::bind_interrupts; | ||||
| @ -41,7 +41,16 @@ async fn main(spawner: Spawner) { | ||||
|     let pwr = Output::new(p.PIN_23, Level::Low); | ||||
|     let cs = Output::new(p.PIN_25, Level::High); | ||||
|     let mut pio = Pio::new(p.PIO0, Irqs); | ||||
|     let spi = PioSpi::new(&mut pio.common, pio.sm0, pio.irq0, cs, p.PIN_24, p.PIN_29, p.DMA_CH0); | ||||
|     let spi = PioSpi::new( | ||||
|         &mut pio.common, | ||||
|         pio.sm0, | ||||
|         DEFAULT_CLOCK_DIVIDER, | ||||
|         pio.irq0, | ||||
|         cs, | ||||
|         p.PIN_24, | ||||
|         p.PIN_29, | ||||
|         p.DMA_CH0, | ||||
|     ); | ||||
| 
 | ||||
|     static STATE: StaticCell<cyw43::State> = StaticCell::new(); | ||||
|     let state = STATE.init(cyw43::State::new()); | ||||
|  | ||||
| @ -7,7 +7,7 @@ | ||||
| 
 | ||||
| use core::str; | ||||
| 
 | ||||
| use cyw43_pio::PioSpi; | ||||
| use cyw43_pio::{PioSpi, DEFAULT_CLOCK_DIVIDER}; | ||||
| use defmt::*; | ||||
| use embassy_executor::Spawner; | ||||
| use embassy_rp::bind_interrupts; | ||||
| @ -45,7 +45,16 @@ async fn main(spawner: Spawner) { | ||||
|     let pwr = Output::new(p.PIN_23, Level::Low); | ||||
|     let cs = Output::new(p.PIN_25, Level::High); | ||||
|     let mut pio = Pio::new(p.PIO0, Irqs); | ||||
|     let spi = PioSpi::new(&mut pio.common, pio.sm0, pio.irq0, cs, p.PIN_24, p.PIN_29, p.DMA_CH0); | ||||
|     let spi = PioSpi::new( | ||||
|         &mut pio.common, | ||||
|         pio.sm0, | ||||
|         DEFAULT_CLOCK_DIVIDER, | ||||
|         pio.irq0, | ||||
|         cs, | ||||
|         p.PIN_24, | ||||
|         p.PIN_29, | ||||
|         p.DMA_CH0, | ||||
|     ); | ||||
| 
 | ||||
|     static STATE: StaticCell<cyw43::State> = StaticCell::new(); | ||||
|     let state = STATE.init(cyw43::State::new()); | ||||
|  | ||||
| @ -8,7 +8,7 @@ | ||||
| use core::str::from_utf8; | ||||
| 
 | ||||
| use cyw43::JoinOptions; | ||||
| use cyw43_pio::PioSpi; | ||||
| use cyw43_pio::{PioSpi, DEFAULT_CLOCK_DIVIDER}; | ||||
| use defmt::*; | ||||
| use embassy_executor::Spawner; | ||||
| use embassy_net::tcp::TcpSocket; | ||||
| @ -61,7 +61,16 @@ async fn main(spawner: Spawner) { | ||||
|     let pwr = Output::new(p.PIN_23, Level::Low); | ||||
|     let cs = Output::new(p.PIN_25, Level::High); | ||||
|     let mut pio = Pio::new(p.PIO0, Irqs); | ||||
|     let spi = PioSpi::new(&mut pio.common, pio.sm0, pio.irq0, cs, p.PIN_24, p.PIN_29, p.DMA_CH0); | ||||
|     let spi = PioSpi::new( | ||||
|         &mut pio.common, | ||||
|         pio.sm0, | ||||
|         DEFAULT_CLOCK_DIVIDER, | ||||
|         pio.irq0, | ||||
|         cs, | ||||
|         p.PIN_24, | ||||
|         p.PIN_29, | ||||
|         p.DMA_CH0, | ||||
|     ); | ||||
| 
 | ||||
|     static STATE: StaticCell<cyw43::State> = StaticCell::new(); | ||||
|     let state = STATE.init(cyw43::State::new()); | ||||
|  | ||||
| @ -8,7 +8,7 @@ | ||||
| use core::str::from_utf8; | ||||
| 
 | ||||
| use cyw43::JoinOptions; | ||||
| use cyw43_pio::PioSpi; | ||||
| use cyw43_pio::{PioSpi, DEFAULT_CLOCK_DIVIDER}; | ||||
| use defmt::*; | ||||
| use embassy_executor::Spawner; | ||||
| use embassy_net::dns::DnsSocket; | ||||
| @ -63,7 +63,16 @@ async fn main(spawner: Spawner) { | ||||
|     let pwr = Output::new(p.PIN_23, Level::Low); | ||||
|     let cs = Output::new(p.PIN_25, Level::High); | ||||
|     let mut pio = Pio::new(p.PIO0, Irqs); | ||||
|     let spi = PioSpi::new(&mut pio.common, pio.sm0, pio.irq0, cs, p.PIN_24, p.PIN_29, p.DMA_CH0); | ||||
|     let spi = PioSpi::new( | ||||
|         &mut pio.common, | ||||
|         pio.sm0, | ||||
|         DEFAULT_CLOCK_DIVIDER, | ||||
|         pio.irq0, | ||||
|         cs, | ||||
|         p.PIN_24, | ||||
|         p.PIN_29, | ||||
|         p.DMA_CH0, | ||||
|     ); | ||||
| 
 | ||||
|     static STATE: StaticCell<cyw43::State> = StaticCell::new(); | ||||
|     let state = STATE.init(cyw43::State::new()); | ||||
|  | ||||
							
								
								
									
										94
									
								
								examples/rp23/src/bin/wifi_blinky_pico_plus_2.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								examples/rp23/src/bin/wifi_blinky_pico_plus_2.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,94 @@ | ||||
| //! This example test the Pimoroni Pico Plus 2 on board LED.
 | ||||
| //!
 | ||||
| //! It does not work with the RP Pico board. See blinky.rs.
 | ||||
| 
 | ||||
| #![no_std] | ||||
| #![no_main] | ||||
| 
 | ||||
| use cyw43_pio::{PioSpi, RM2_CLOCK_DIVIDER}; | ||||
| use defmt::*; | ||||
| use embassy_executor::Spawner; | ||||
| use embassy_rp::block::ImageDef; | ||||
| use embassy_rp::gpio; | ||||
| use embassy_rp::peripherals::{DMA_CH0, PIO0}; | ||||
| use embassy_rp::pio::Pio; | ||||
| use embassy_rp::{bind_interrupts, pio::InterruptHandler}; | ||||
| use embassy_time::{Duration, Timer}; | ||||
| use gpio::{Level, Output}; | ||||
| use static_cell::StaticCell; | ||||
| use {defmt_rtt as _, panic_probe as _}; | ||||
| 
 | ||||
| #[link_section = ".start_block"] | ||||
| #[used] | ||||
| pub static IMAGE_DEF: ImageDef = ImageDef::secure_exe(); | ||||
| 
 | ||||
| // Program metadata for `picotool info`.
 | ||||
| // This isn't needed, but it's recomended to have these minimal entries.
 | ||||
| #[link_section = ".bi_entries"] | ||||
| #[used] | ||||
| pub static PICOTOOL_ENTRIES: [embassy_rp::binary_info::EntryAddr; 4] = [ | ||||
|     embassy_rp::binary_info::rp_program_name!(c"Blinky Example"), | ||||
|     embassy_rp::binary_info::rp_program_description!( | ||||
|         c"This example tests the RP Pico on board LED, connected to gpio 25" | ||||
|     ), | ||||
|     embassy_rp::binary_info::rp_cargo_version!(), | ||||
|     embassy_rp::binary_info::rp_program_build_attribute!(), | ||||
| ]; | ||||
| 
 | ||||
| bind_interrupts!(struct Irqs { | ||||
|     PIO0_IRQ_0 => InterruptHandler<PIO0>; | ||||
| }); | ||||
| 
 | ||||
| #[embassy_executor::task] | ||||
| async fn cyw43_task(runner: cyw43::Runner<'static, Output<'static>, PioSpi<'static, PIO0, 0, DMA_CH0>>) -> ! { | ||||
|     runner.run().await | ||||
| } | ||||
| 
 | ||||
| #[embassy_executor::main] | ||||
| async fn main(spawner: Spawner) { | ||||
|     let p = embassy_rp::init(Default::default()); | ||||
|     let fw = include_bytes!("../../../../cyw43-firmware/43439A0.bin"); | ||||
|     let clm = include_bytes!("../../../../cyw43-firmware/43439A0_clm.bin"); | ||||
| 
 | ||||
|     // To make flashing faster for development, you may want to flash the firmwares independently
 | ||||
|     // at hardcoded addresses, instead of baking them into the program with `include_bytes!`:
 | ||||
|     //     probe-rs download ../../cyw43-firmware/43439A0.bin --binary-format bin --chip RP2040 --base-address 0x10100000
 | ||||
|     //     probe-rs download ../../cyw43-firmware/43439A0_clm.bin --binary-format bin --chip RP2040 --base-address 0x10140000
 | ||||
|     //let fw = unsafe { core::slice::from_raw_parts(0x10100000 as *const u8, 230321) };
 | ||||
|     //let clm = unsafe { core::slice::from_raw_parts(0x10140000 as *const u8, 4752) };
 | ||||
| 
 | ||||
|     let pwr = Output::new(p.PIN_23, Level::Low); | ||||
|     let cs = Output::new(p.PIN_25, Level::High); | ||||
|     let mut pio = Pio::new(p.PIO0, Irqs); | ||||
|     let spi = PioSpi::new( | ||||
|         &mut pio.common, | ||||
|         pio.sm0, | ||||
|         RM2_CLOCK_DIVIDER, | ||||
|         pio.irq0, | ||||
|         cs, | ||||
|         p.PIN_24, | ||||
|         p.PIN_29, | ||||
|         p.DMA_CH0, | ||||
|     ); | ||||
| 
 | ||||
|     static STATE: StaticCell<cyw43::State> = StaticCell::new(); | ||||
|     let state = STATE.init(cyw43::State::new()); | ||||
|     let (_net_device, mut control, runner) = cyw43::new(state, pwr, spi, fw).await; | ||||
|     unwrap!(spawner.spawn(cyw43_task(runner))); | ||||
| 
 | ||||
|     control.init(clm).await; | ||||
|     control | ||||
|         .set_power_management(cyw43::PowerManagementMode::PowerSave) | ||||
|         .await; | ||||
| 
 | ||||
|     let delay = Duration::from_secs(1); | ||||
|     loop { | ||||
|         info!("led on!"); | ||||
|         control.gpio_set(0, true).await; | ||||
|         Timer::after(delay).await; | ||||
| 
 | ||||
|         info!("led off!"); | ||||
|         control.gpio_set(0, false).await; | ||||
|         Timer::after(delay).await; | ||||
|     } | ||||
| } | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user