Add Webee stuff
This commit is contained in:
@@ -1,5 +1,6 @@
|
|||||||
[build]
|
[build]
|
||||||
target = "avr-specs/avr-atmega2560.json"
|
target = "avr-specs/avr-atmega2560.json"
|
||||||
|
rustc-wrapper = "./rustc-wrapper.sh"
|
||||||
|
|
||||||
[target.'cfg(target_arch = "avr")']
|
[target.'cfg(target_arch = "avr")']
|
||||||
runner = "ravedude mega2560 -cb 57600"
|
runner = "ravedude mega2560 -cb 57600"
|
||||||
|
|||||||
5
Cargo.lock
generated
5
Cargo.lock
generated
@@ -69,6 +69,7 @@ name = "avr-webee"
|
|||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"arduino-hal",
|
"arduino-hal",
|
||||||
|
"avr-device",
|
||||||
"embedded-hal",
|
"embedded-hal",
|
||||||
"nb 0.1.3",
|
"nb 0.1.3",
|
||||||
"panic-halt",
|
"panic-halt",
|
||||||
@@ -153,9 +154,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "quote"
|
name = "quote"
|
||||||
version = "1.0.32"
|
version = "1.0.33"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "50f3b39ccfb720540debaa0164757101c08ecb8d326b15358ce76a62c7e85965"
|
checksum = "5267fca4496028628a95160fc423a33e8b2e6af8a5302579e322e4b520293cae"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ version = "0.1.0"
|
|||||||
authors = ["Adrian Marquis <adrian@marquis.site>"]
|
authors = ["Adrian Marquis <adrian@marquis.site>"]
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
license = "MIT OR Apache-2.0"
|
license = "MIT OR Apache-2.0"
|
||||||
|
publish = false
|
||||||
|
|
||||||
[[bin]]
|
[[bin]]
|
||||||
name = "avr-webee"
|
name = "avr-webee"
|
||||||
@@ -15,6 +16,7 @@ panic-halt = "0.2.0"
|
|||||||
ufmt = "0.1.0"
|
ufmt = "0.1.0"
|
||||||
nb = "0.1.2"
|
nb = "0.1.2"
|
||||||
embedded-hal = "0.2.3"
|
embedded-hal = "0.2.3"
|
||||||
|
avr-device = "0.5.1"
|
||||||
|
|
||||||
[dependencies.arduino-hal]
|
[dependencies.arduino-hal]
|
||||||
git = "https://github.com/rahix/avr-hal"
|
git = "https://github.com/rahix/avr-hal"
|
||||||
|
|||||||
37
rustc-wrapper.sh
Executable file
37
rustc-wrapper.sh
Executable file
@@ -0,0 +1,37 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# rustc-wrapper
|
||||||
|
#
|
||||||
|
# Use this script in the `[build]`,`rustc-wrapper` section of your
|
||||||
|
# `.cargo/config.toml` configuration file to correctly set the
|
||||||
|
# `RUST_TARGET_PATH` environment variable before running rustc.
|
||||||
|
#
|
||||||
|
# This is to workaround a bug whereby `rustc --print cfg` fails when you
|
||||||
|
# use a custom `target.json` file, unless `RUST_TARGET_PATH` is set to the
|
||||||
|
# directory containing the target description.
|
||||||
|
|
||||||
|
# `cargo` passes "rustc " as the first parameter to the wrapper; pop it off
|
||||||
|
shift
|
||||||
|
|
||||||
|
# Extract the target config JSON from the `config.toml`
|
||||||
|
#
|
||||||
|
# NOTE: We assume that this wrapper script is in the root of your project, and
|
||||||
|
# that the `build.target` value is relative to the location of the same.
|
||||||
|
#
|
||||||
|
|
||||||
|
TARGET_JSON_FILE=$(cargo config -Z unstable-options get --format json-value build.target 2>/dev/null || echo "")
|
||||||
|
|
||||||
|
if [ ! -z "${TARGET_JSON_FILE}" ]; then
|
||||||
|
TARGET_JSON_DIR=$(dirname "${TARGET_JSON_FILE//\"/}")
|
||||||
|
|
||||||
|
# Work out where we are and which rustup we're wrapping
|
||||||
|
BASEDIR=$(dirname "$0")
|
||||||
|
|
||||||
|
|
||||||
|
# Set the env variable
|
||||||
|
export RUST_TARGET_PATH="${BASEDIR}/${TARGET_JSON_DIR}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
RUSTC=$(rustup which rustc)
|
||||||
|
|
||||||
|
# Now let rustc do its thing
|
||||||
|
"${RUSTC}" $@
|
||||||
122
src/main.rs
122
src/main.rs
@@ -1,27 +1,123 @@
|
|||||||
#![no_std]
|
#![no_std]
|
||||||
#![no_main]
|
#![no_main]
|
||||||
|
|
||||||
|
mod webee;
|
||||||
|
use webee::{Webee, Vector};
|
||||||
|
|
||||||
|
use arduino_hal::Peripherals;
|
||||||
|
use arduino_hal::prelude::*;
|
||||||
use panic_halt as _;
|
use panic_halt as _;
|
||||||
|
|
||||||
|
|
||||||
#[arduino_hal::entry]
|
#[arduino_hal::entry]
|
||||||
fn main() -> ! {
|
fn main() -> ! {
|
||||||
let dp = arduino_hal::Peripherals::take().unwrap();
|
let dp = Peripherals::take().unwrap();
|
||||||
let pins = arduino_hal::pins!(dp);
|
let pins = arduino_hal::pins!(dp);
|
||||||
|
let status = pins.d13.into_output();
|
||||||
|
let mut serial = arduino_hal::default_serial!(dp, pins, 57600);
|
||||||
|
let rx = pins.d2;
|
||||||
|
|
||||||
/*
|
let mut test = Webee::new(
|
||||||
* For examples (and inspiration), head to
|
dp.USART1,
|
||||||
*
|
pins.d19,
|
||||||
* https://github.com/Rahix/avr-hal/tree/main/examples
|
pins.d18.into_output()
|
||||||
*
|
);
|
||||||
* NOTE: Not all examples were ported to all boards! There is a good chance though, that code
|
|
||||||
* for a different board can be adapted for yours. The Arduino Uno currently has the most
|
|
||||||
* examples available.
|
|
||||||
*/
|
|
||||||
|
|
||||||
let mut led = pins.d13.into_output();
|
// let mut webee = Usart::new(
|
||||||
|
// dp.USART1,
|
||||||
|
// pins.d19,
|
||||||
|
// pins.d18.into_output(),
|
||||||
|
// 38400.into_baudrate(),
|
||||||
|
// );
|
||||||
|
|
||||||
|
// ufmt::uwriteln!(&mut serial, "Hello, World!").void_unwrap();
|
||||||
|
// ufmt::uwriteln!(&mut serial, "RX ready: {}", rx.is_high()).void_unwrap();
|
||||||
|
// delay_ms(1000);
|
||||||
|
// ufmt::uwriteln!(&mut serial, "RX ready: {}", rx.is_high()).void_unwrap();
|
||||||
|
|
||||||
|
// let webee = Webee::new(dp.USART1, pins.d19, pins.d18);
|
||||||
|
|
||||||
|
|
||||||
|
// let mut test = webee.write(0xFF);
|
||||||
|
// while let Err(_) = test {
|
||||||
|
// test = webee.write(0xFF);
|
||||||
|
// ufmt::uwriteln!(&mut serial, "initializing..").void_unwrap();
|
||||||
|
// delay_ms(500);
|
||||||
|
// }
|
||||||
|
ufmt::uwriteln!(&mut serial, "Webee initialized!").void_unwrap();
|
||||||
|
// delay_ms(1000);
|
||||||
|
|
||||||
|
// let mut init = true;
|
||||||
|
// while init {
|
||||||
|
// match webee.write(0) {
|
||||||
|
// Ok(_) => {
|
||||||
|
// webee.flush();
|
||||||
|
// ufmt::uwriteln!(&mut serial, "Webee initialized!").void_unwrap();
|
||||||
|
// init = false;
|
||||||
|
// }
|
||||||
|
// Err(_) => {
|
||||||
|
// ufmt::uwriteln!(&mut serial, "initializing..").void_unwrap();
|
||||||
|
// delay_ms(500);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
// ufmt::uwriteln!(&mut serial, "RX ready: {}", rx.is_high()).void_unwrap();
|
||||||
|
let role : Vector<u8> = test.send(vector!([0x5a, 0xaa, 0xb1]));
|
||||||
|
ufmt::uwriteln!(&mut serial, "Role: {}", role);
|
||||||
|
|
||||||
|
// for byte in [0x5a, 0xaa, 0xb1].iter() {
|
||||||
|
// webee.write_byte(*byte);
|
||||||
|
// ufmt::uwriteln!(&mut serial, "Wrote byte: {:X}", *byte).void_unwrap();
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// ufmt::uwrite!(&mut serial, "Role:").void_unwrap();
|
||||||
|
// let mut result: u8 = webee.read_byte();
|
||||||
|
//
|
||||||
|
// while result != 0xFF {
|
||||||
|
// ufmt::uwrite!(&mut serial, " {:02X}", result).void_unwrap();
|
||||||
|
// result = webee.read_byte();
|
||||||
|
// }
|
||||||
|
|
||||||
loop {
|
loop {
|
||||||
led.toggle();
|
let b = nb::block!(serial.read()).void_unwrap();
|
||||||
arduino_hal::delay_ms(1000);
|
|
||||||
|
ufmt::uwriteln!(&mut serial, "Got {:X}!", b).void_unwrap();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// fn readBytesUntil()
|
||||||
|
|
||||||
|
// struct Webee<USART, RX, TX> {
|
||||||
|
// serial: Usart<USART, RX, TX>,
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// impl<USART, RX, TX> Webee<USART, RX, TX> {
|
||||||
|
// pub fn new(usart: USART, rx: RX, tx: TX) -> Self {
|
||||||
|
// Webee {
|
||||||
|
// serial: crate::Usart::new(usart, rx, tx, Baudrate::new(38400)),
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
|
||||||
|
// struct Webee<'a> {
|
||||||
|
// serial: &'a usart
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// impl Webee {
|
||||||
|
// fn new(serial: usart) -> Self {
|
||||||
|
// Self {
|
||||||
|
// serial
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// fn send_cmd(&mut self, cmd: u8) -> ! {
|
||||||
|
// let frame: [u8; 3] = [0x55, 0xAA, cmd];
|
||||||
|
// self.serial.write(&frame)
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// fn recv(&mut self) -> ! {
|
||||||
|
// self.serial.read()
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|||||||
44
src/webee.rs
Normal file
44
src/webee.rs
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
use arduino_hal::Usart;
|
||||||
|
use arduino_hal::usart::UsartOps;
|
||||||
|
use arduino_hal::prelude::*;
|
||||||
|
use embedded_hal::serial::{Read};
|
||||||
|
|
||||||
|
mod vector;
|
||||||
|
pub use vector::Vector;
|
||||||
|
|
||||||
|
pub struct Webee<USART, RX, TX> {
|
||||||
|
webee: Usart<USART, RX, TX>,
|
||||||
|
}
|
||||||
|
|
||||||
|
enum SEND_CMD {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<USART, RX, TX> Webee<USART, RX, TX> {
|
||||||
|
const STOP : u8 = 0xFF;
|
||||||
|
|
||||||
|
pub fn new(device: USART, rx: RX, tx: TX) -> Self {
|
||||||
|
Self {
|
||||||
|
webee: Usart::new(device, rx, tx, 38400.into_baudrate())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn send(&mut self, data: Vector<u8>) -> Vector<u8> {
|
||||||
|
for byte in data {
|
||||||
|
self.webee.write_byte(byte);
|
||||||
|
}
|
||||||
|
|
||||||
|
return self.recv();
|
||||||
|
}
|
||||||
|
|
||||||
|
fn recv(&mut self) -> Vector<u8> {
|
||||||
|
const buffer : Vector<u8> = Vector::new(0, &[]);
|
||||||
|
let byte : u8 = self.webee.read_byte();
|
||||||
|
|
||||||
|
while byte != self.STOP {
|
||||||
|
buffer.push(byte);
|
||||||
|
}
|
||||||
|
|
||||||
|
return buffer;
|
||||||
|
}
|
||||||
|
}
|
||||||
19
src/webee/vector.rs
Normal file
19
src/webee/vector.rs
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
pub struct Vector<'a, T> {
|
||||||
|
size: u16,
|
||||||
|
array: &'a [T]
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a, T> Vector<'a, T> {
|
||||||
|
pub fn new(size: u16, array: &[T]) -> Self {
|
||||||
|
Self {
|
||||||
|
size, array
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[macro_export]
|
||||||
|
macro_rules! vector {
|
||||||
|
($array:expr) => {
|
||||||
|
Vector::new($array.len(), $array);
|
||||||
|
};
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user