i2c shell
This commit is contained in:
parent
16cd6d2546
commit
24e5c7ccd9
3 changed files with 81 additions and 6 deletions
1
controller/Cargo.lock
generated
1
controller/Cargo.lock
generated
|
@ -294,6 +294,7 @@ dependencies = [
|
||||||
"fixed",
|
"fixed",
|
||||||
"fixed-macro",
|
"fixed-macro",
|
||||||
"heapless 0.8.0",
|
"heapless 0.8.0",
|
||||||
|
"hex",
|
||||||
"log",
|
"log",
|
||||||
"panic-probe",
|
"panic-probe",
|
||||||
"pio",
|
"pio",
|
||||||
|
|
|
@ -58,6 +58,7 @@ rand = { version = "0.8.5", default-features = false }
|
||||||
embedded-sdmmc = "0.7.0"
|
embedded-sdmmc = "0.7.0"
|
||||||
|
|
||||||
bt-hci = { version = "0.1.0", default-features = false, features = ["defmt"] }
|
bt-hci = { version = "0.1.0", default-features = false, features = ["defmt"] }
|
||||||
|
hex = { version = "0.4.3", default-features=false}
|
||||||
|
|
||||||
[profile.release]
|
[profile.release]
|
||||||
debug = 2
|
debug = 2
|
||||||
|
|
|
@ -5,28 +5,40 @@
|
||||||
#![no_main]
|
#![no_main]
|
||||||
#![allow(async_fn_in_trait)]
|
#![allow(async_fn_in_trait)]
|
||||||
|
|
||||||
|
use core::fmt::Formatter;
|
||||||
use core::str::from_utf8;
|
use core::str::from_utf8;
|
||||||
|
|
||||||
|
use bt_hci::cmd::info;
|
||||||
use cyw43_pio::PioSpi;
|
use cyw43_pio::PioSpi;
|
||||||
use defmt::*;
|
use log::*;
|
||||||
|
//use embassy_rp::i2c::InterruptHandler;
|
||||||
use embassy_executor::Spawner;
|
use embassy_executor::Spawner;
|
||||||
use embassy_net::tcp::TcpSocket;
|
use embassy_net::tcp::TcpSocket;
|
||||||
use embassy_net::{Config, StackResources};
|
use embassy_net::{Config, StackResources};
|
||||||
use embassy_rp::bind_interrupts;
|
use embassy_rp::bind_interrupts;
|
||||||
use embassy_rp::clocks::RoscRng;
|
use embassy_rp::clocks::RoscRng;
|
||||||
use embassy_rp::gpio::{Level, Output};
|
use embassy_rp::gpio::{Level, Output};
|
||||||
use embassy_rp::peripherals::{DMA_CH0, PIO0};
|
use embassy_rp::peripherals::{DMA_CH0, PIO0, USB};
|
||||||
use embassy_rp::pio::{InterruptHandler, Pio};
|
use embassy_rp::pio::{InterruptHandler, Pio};
|
||||||
use embassy_time::Duration;
|
use embassy_rp::usb::Driver;
|
||||||
|
use embassy_time::{Duration, Timer};
|
||||||
use embedded_io_async::Write;
|
use embedded_io_async::Write;
|
||||||
use rand::RngCore;
|
use rand::RngCore;
|
||||||
|
use reqwless::response;
|
||||||
use static_cell::StaticCell;
|
use static_cell::StaticCell;
|
||||||
use {defmt_rtt as _, panic_probe as _};
|
use {defmt_rtt as _, panic_probe as _};
|
||||||
|
|
||||||
bind_interrupts!(struct Irqs {
|
bind_interrupts!(struct Irqs {
|
||||||
PIO0_IRQ_0 => InterruptHandler<PIO0>;
|
PIO0_IRQ_0 => InterruptHandler<PIO0>;
|
||||||
|
I2C1_IRQ => embassy_rp::i2c::InterruptHandler<embassy_rp::peripherals::I2C1>;
|
||||||
|
USBCTRL_IRQ => embassy_rp::usb::InterruptHandler<USB>;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
#[embassy_executor::task]
|
||||||
|
async fn logger_task(driver: Driver<'static, USB>) {
|
||||||
|
embassy_usb_logger::run!(1024, log::LevelFilter::Debug, driver);
|
||||||
|
}
|
||||||
|
|
||||||
#[embassy_executor::task]
|
#[embassy_executor::task]
|
||||||
async fn cyw43_task(runner: cyw43::Runner<'static, Output<'static>, PioSpi<'static, PIO0, 0, DMA_CH0>>) -> ! {
|
async fn cyw43_task(runner: cyw43::Runner<'static, Output<'static>, PioSpi<'static, PIO0, 0, DMA_CH0>>) -> ! {
|
||||||
runner.run().await
|
runner.run().await
|
||||||
|
@ -44,6 +56,14 @@ async fn main(spawner: Spawner) {
|
||||||
let p = embassy_rp::init(Default::default());
|
let p = embassy_rp::init(Default::default());
|
||||||
let mut rng = RoscRng;
|
let mut rng = RoscRng;
|
||||||
|
|
||||||
|
let driver = Driver::new(p.USB, Irqs);
|
||||||
|
spawner.spawn(logger_task(driver)).unwrap();
|
||||||
|
|
||||||
|
let sda = p.PIN_26;
|
||||||
|
let scl = p.PIN_27;
|
||||||
|
let config = embassy_rp::i2c::Config::default();
|
||||||
|
let mut bus = embassy_rp::i2c::I2c::new_async(p.I2C1, scl, sda, Irqs, config);
|
||||||
|
|
||||||
let fw = include_bytes!("../../cyw43-firmware/43439A0.bin");
|
let fw = include_bytes!("../../cyw43-firmware/43439A0.bin");
|
||||||
let clm = include_bytes!("../../cyw43-firmware/43439A0_clm.bin");
|
let clm = include_bytes!("../../cyw43-firmware/43439A0_clm.bin");
|
||||||
|
|
||||||
|
@ -62,7 +82,7 @@ async fn main(spawner: Spawner) {
|
||||||
static STATE: StaticCell<cyw43::State> = StaticCell::new();
|
static STATE: StaticCell<cyw43::State> = StaticCell::new();
|
||||||
let state = STATE.init(cyw43::State::new());
|
let state = STATE.init(cyw43::State::new());
|
||||||
let (net_device, mut control, runner) = cyw43::new(state, pwr, spi, fw).await;
|
let (net_device, mut control, runner) = cyw43::new(state, pwr, spi, fw).await;
|
||||||
unwrap!(spawner.spawn(cyw43_task(runner)));
|
defmt::unwrap!(spawner.spawn(cyw43_task(runner)));
|
||||||
|
|
||||||
control.init(clm).await;
|
control.init(clm).await;
|
||||||
control
|
control
|
||||||
|
@ -83,7 +103,7 @@ async fn main(spawner: Spawner) {
|
||||||
static RESOURCES: StaticCell<StackResources<3>> = StaticCell::new();
|
static RESOURCES: StaticCell<StackResources<3>> = StaticCell::new();
|
||||||
let (stack, runner) = embassy_net::new(net_device, config, RESOURCES.init(StackResources::new()), seed);
|
let (stack, runner) = embassy_net::new(net_device, config, RESOURCES.init(StackResources::new()), seed);
|
||||||
|
|
||||||
unwrap!(spawner.spawn(net_task(runner)));
|
defmt::unwrap!(spawner.spawn(net_task(runner)));
|
||||||
|
|
||||||
//control.start_ap_open("cyw43", 5).await;
|
//control.start_ap_open("cyw43", 5).await;
|
||||||
control.start_ap_wpa2("cyw43", "password", 5).await;
|
control.start_ap_wpa2("cyw43", "password", 5).await;
|
||||||
|
@ -94,6 +114,17 @@ async fn main(spawner: Spawner) {
|
||||||
let mut tx_buffer = [0; 4096];
|
let mut tx_buffer = [0; 4096];
|
||||||
let mut buf = [0; 4096];
|
let mut buf = [0; 4096];
|
||||||
|
|
||||||
|
//embassy_time::Timer::after_millis(7000).await;
|
||||||
|
|
||||||
|
//let _ = bus.write_async(0x88u16, [0x00]).await;
|
||||||
|
//let _ = bus.write_async(0x80u16, [0x01]).await;
|
||||||
|
//let _ = bus.write_async(0xFFu16, [0x01]).await;
|
||||||
|
//let _ = bus.write_async(0x00u16, [0x00]).await;
|
||||||
|
//let _ = bus.write_async(0x00u16, [0x01]).await;
|
||||||
|
//let _ = bus.write_async(0xFFu16, [0x00]).await;
|
||||||
|
//let _ = bus.write_async(0x80u16, [0x00]).await;
|
||||||
|
|
||||||
|
|
||||||
loop {
|
loop {
|
||||||
let mut socket = TcpSocket::new(stack, &mut rx_buffer, &mut tx_buffer);
|
let mut socket = TcpSocket::new(stack, &mut rx_buffer, &mut tx_buffer);
|
||||||
socket.set_timeout(Some(Duration::from_secs(10)));
|
socket.set_timeout(Some(Duration::from_secs(10)));
|
||||||
|
@ -109,7 +140,7 @@ async fn main(spawner: Spawner) {
|
||||||
control.gpio_set(0, true).await;
|
control.gpio_set(0, true).await;
|
||||||
|
|
||||||
loop {
|
loop {
|
||||||
let n = match socket.read(&mut buf).await {
|
let mut n = match socket.read(&mut buf).await {
|
||||||
Ok(0) => {
|
Ok(0) => {
|
||||||
warn!("read EOF");
|
warn!("read EOF");
|
||||||
break;
|
break;
|
||||||
|
@ -120,8 +151,50 @@ async fn main(spawner: Spawner) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
info!("rxd {}", from_utf8(&buf[..n]).unwrap());
|
info!("rxd {}", from_utf8(&buf[..n]).unwrap());
|
||||||
|
Timer::after_millis(30).await;
|
||||||
|
|
||||||
|
let mut segs = buf[..n].split(|c| *c == ' ' as u8);
|
||||||
|
|
||||||
|
match char::from_u32(segs.next().unwrap()[0] as u32).unwrap() {
|
||||||
|
'W' => {
|
||||||
|
let addr: [u8;1] = hex::FromHex::from_hex(segs.next().unwrap()).unwrap();
|
||||||
|
let reg: [u8;1] = hex::FromHex::from_hex(segs.next().unwrap()).unwrap();
|
||||||
|
let data: [u8;1] = hex::FromHex::from_hex(segs.next().unwrap()).unwrap();
|
||||||
|
info!("writing {:?}", reg);
|
||||||
|
Timer::after_millis(30).await;
|
||||||
|
|
||||||
|
bus.write_async(addr[0] as u16, [reg[0], data[0]]).await.unwrap();
|
||||||
|
|
||||||
|
buf[0] = b"O"[0];
|
||||||
|
buf[1] = b"K"[0];
|
||||||
|
n=2;
|
||||||
|
},
|
||||||
|
'R' => {
|
||||||
|
let addr: [u8;1] = hex::FromHex::from_hex(segs.next().unwrap()).unwrap();
|
||||||
|
let reg: [u8;1] = hex::FromHex::from_hex(segs.next().unwrap()).unwrap();
|
||||||
|
info!("writing {:?}, addr {addr:?}", reg);
|
||||||
|
|
||||||
|
let mut response: [u8;2] = [0;2];
|
||||||
|
|
||||||
|
let _ = bus.write_read_async(addr[0] as u16, reg, &mut response).await;
|
||||||
|
info!("recd {:?}", response);
|
||||||
|
info!("recd {:#02x}", response[0]);
|
||||||
|
let _ = hex::encode_to_slice(response, &mut buf);
|
||||||
|
n = 4;
|
||||||
|
|
||||||
|
|
||||||
|
},
|
||||||
|
_ => {}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
//let mut response: [u8;2] = [0;2];
|
||||||
|
|
||||||
|
//let _ = bus.read_async(0xC0u16, &mut response).await;
|
||||||
|
//let _ = hex::encode_to_slice(response, &mut buf);
|
||||||
|
|
||||||
match socket.write_all(&buf[..n]).await {
|
match socket.write_all(&buf[..n]).await {
|
||||||
Ok(()) => {}
|
Ok(()) => {}
|
||||||
|
|
Loading…
Reference in a new issue