mirror of
https://github.com/ferrous-systems/embedded-trainings-2020.git
synced 2025-01-25 07:18:08 +00:00
convert all beginner code snippets
This commit is contained in:
parent
6bbd0c1e45
commit
e0ed95dcc4
11 changed files with 73 additions and 56 deletions
|
@ -5,7 +5,8 @@
|
|||
use cortex_m_rt::entry;
|
||||
use dk::ieee802154::{Channel, Packet};
|
||||
use heapless::{consts, LinearMap};
|
||||
use panic_log as _; // the panicking behavior
|
||||
// this imports `beginner/apps/lib.rs` to retrieve our global logger + panicking-behavior
|
||||
use apps as _;
|
||||
|
||||
const TEN_MS: u32 = 10_000;
|
||||
|
||||
|
@ -36,16 +37,18 @@ fn main() -> ! {
|
|||
// TODO insert the key-value pair
|
||||
// dict.insert(/* ? */, /* ? */).expect("dictionary full");
|
||||
} else {
|
||||
log::error!("response packet was not a single byte");
|
||||
defmt::error!("response packet was not a single byte");
|
||||
dk::exit()
|
||||
}
|
||||
} else {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
}
|
||||
|
||||
log::info!("{:?}", dict);
|
||||
defmt::info!("{:?}", defmt::Debug2Format(&dict));
|
||||
// ^^^^^^^^^^^^^^^^^^^ this adapter iscurrently needed to log `heapless`
|
||||
// data structures (like `LinearMap` here) with `defmt`
|
||||
|
||||
dk::exit()
|
||||
}
|
||||
|
|
|
@ -6,7 +6,8 @@ use core::str;
|
|||
|
||||
use cortex_m_rt::entry;
|
||||
use heapless::{consts, Vec};
|
||||
use panic_log as _; // the panicking behavior
|
||||
// this imports `beginner/apps/lib.rs` to retrieve our global logger + panicking-behavior
|
||||
use apps as _;
|
||||
|
||||
#[entry]
|
||||
fn main() -> ! {
|
||||
|
@ -21,10 +22,13 @@ fn main() -> ! {
|
|||
buffer.push(b'i').expect("buffer full");
|
||||
|
||||
// look into the contents so far
|
||||
log::info!("{:?}", buffer);
|
||||
defmt::info!("{:?}", defmt::Debug2Format(&buffer));
|
||||
// ^^^^^^^^^^^^^^^^^^^ this adapter iscurrently needed to log `heapless`
|
||||
// data structures (like `Vec` here) with `defmt`
|
||||
|
||||
// or more readable
|
||||
// NOTE as long as you only push bytes in the ASCII range (0..=127) the conversion should work
|
||||
log::info!(
|
||||
// NOTE utf-8 conversion works as long as you only push bytes in the ASCII range (0..=127)
|
||||
defmt::info!(
|
||||
"{}",
|
||||
str::from_utf8(&buffer).expect("content was not UTF-8")
|
||||
);
|
||||
|
|
|
@ -7,7 +7,8 @@ use core::str;
|
|||
use cortex_m_rt::entry;
|
||||
use dk::ieee802154::{Channel, Packet};
|
||||
use heapless::{consts, Vec};
|
||||
use panic_log as _; // the panicking behavior
|
||||
// this imports `beginner/apps/lib.rs` to retrieve our global logger + panicking-behavior
|
||||
use apps as _;
|
||||
|
||||
const TEN_MS: u32 = 10_000;
|
||||
|
||||
|
@ -27,11 +28,11 @@ fn main() -> ! {
|
|||
radio.send(&mut packet);
|
||||
|
||||
if radio.recv_timeout(&mut packet, &mut timer, TEN_MS).is_err() {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"ciphertext: {}",
|
||||
str::from_utf8(&packet).expect("packet was not valid UTF-8")
|
||||
);
|
||||
|
@ -47,7 +48,7 @@ fn main() -> ! {
|
|||
buf.push(output).expect("buffer full");
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"plaintext: {}",
|
||||
str::from_utf8(&buf).expect("buffer contains non-UTF-8 data")
|
||||
);
|
||||
|
|
|
@ -7,7 +7,8 @@ use core::str;
|
|||
use cortex_m_rt::entry;
|
||||
use dk::ieee802154::{Channel, Packet};
|
||||
use heapless::{consts, LinearMap, Vec};
|
||||
use panic_log as _; // the panicking behavior
|
||||
// this imports `beginner/apps/lib.rs` to retrieve our global logger + panicking-behavior
|
||||
use apps as _;
|
||||
|
||||
const TEN_MS: u32 = 10_000;
|
||||
|
||||
|
@ -37,11 +38,11 @@ fn main() -> ! {
|
|||
// TODO insert the key-value pair
|
||||
// dict.insert(/* ? */, /* ? */).expect("dictionary full");
|
||||
} else {
|
||||
log::error!("response packet was not a single byte");
|
||||
defmt::error!("response packet was not a single byte");
|
||||
dk::exit()
|
||||
}
|
||||
} else {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
}
|
||||
|
@ -51,11 +52,11 @@ fn main() -> ! {
|
|||
radio.send(&mut packet);
|
||||
|
||||
if radio.recv_timeout(&mut packet, &mut timer, TEN_MS).is_err() {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"ciphertext: {}",
|
||||
str::from_utf8(&packet).expect("packet was not valid UTF-8")
|
||||
);
|
||||
|
@ -71,7 +72,7 @@ fn main() -> ! {
|
|||
buffer.push(value).expect("buffer full");
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"plaintext: {}",
|
||||
str::from_utf8(&buffer).expect("buffer contains non-UTF-8 data")
|
||||
);
|
||||
|
|
|
@ -7,7 +7,8 @@ use core::str;
|
|||
use cortex_m_rt::entry;
|
||||
use dk::ieee802154::{Channel, Packet};
|
||||
use heapless::{consts, LinearMap, Vec};
|
||||
use panic_log as _; // the panicking behavior
|
||||
// this imports `beginner/apps/lib.rs` to retrieve our global logger + panicking-behavior
|
||||
use apps as _;
|
||||
|
||||
const TEN_MS: u32 = 10_000;
|
||||
|
||||
|
@ -37,11 +38,11 @@ fn main() -> ! {
|
|||
// TODO insert the key-value pair
|
||||
// dict.insert(/* ? */, /* ? */).expect("dictionary full");
|
||||
} else {
|
||||
log::error!("response packet was not a single byte");
|
||||
defmt::error!("response packet was not a single byte");
|
||||
dk::exit()
|
||||
}
|
||||
} else {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
}
|
||||
|
@ -51,11 +52,11 @@ fn main() -> ! {
|
|||
radio.send(&mut packet);
|
||||
|
||||
if radio.recv_timeout(&mut packet, &mut timer, TEN_MS).is_err() {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"ciphertext: {}",
|
||||
str::from_utf8(&packet).expect("packet was not valid UTF-8")
|
||||
);
|
||||
|
@ -71,7 +72,7 @@ fn main() -> ! {
|
|||
buffer.push(value).expect("buffer full");
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"plaintext: {}",
|
||||
str::from_utf8(&buffer).expect("buffer contains non-UTF-8 data")
|
||||
);
|
||||
|
@ -82,11 +83,11 @@ fn main() -> ! {
|
|||
radio.send(&mut packet);
|
||||
|
||||
if radio.recv_timeout(&mut packet, &mut timer, TEN_MS).is_err() {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"Dongle response: {}",
|
||||
str::from_utf8(&packet).expect("response was not UTF-8")
|
||||
);
|
||||
|
|
|
@ -7,7 +7,8 @@ use core::str;
|
|||
use cortex_m_rt::entry;
|
||||
use dk::ieee802154::{Channel, Packet};
|
||||
use heapless::{consts, LinearMap};
|
||||
use panic_log as _; // the panicking behavior
|
||||
// this imports `beginner/apps/lib.rs` to retrieve our global logger + panicking-behavior
|
||||
use apps as _;
|
||||
|
||||
const TEN_MS: u32 = 10_000;
|
||||
|
||||
|
@ -38,11 +39,11 @@ fn main() -> ! {
|
|||
dict.insert(cipherletter, plainletter)
|
||||
.expect("dictionary full");
|
||||
} else {
|
||||
log::error!("response packet was not a single byte");
|
||||
defmt::error!("response packet was not a single byte");
|
||||
dk::exit()
|
||||
}
|
||||
} else {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
}
|
||||
|
@ -52,11 +53,11 @@ fn main() -> ! {
|
|||
radio.send(&mut packet);
|
||||
|
||||
if radio.recv_timeout(&mut packet, &mut timer, TEN_MS).is_err() {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"ciphertext: {}",
|
||||
str::from_utf8(&packet).expect("packet was not valid UTF-8")
|
||||
);
|
||||
|
@ -74,7 +75,7 @@ fn main() -> ! {
|
|||
*spot = plainletter;
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"plaintext: {}",
|
||||
str::from_utf8(&packet).expect("buffer contains non-UTF-8 data")
|
||||
);
|
||||
|
@ -83,11 +84,11 @@ fn main() -> ! {
|
|||
radio.send(&mut packet);
|
||||
|
||||
if radio.recv_timeout(&mut packet, &mut timer, TEN_MS).is_err() {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"Dongle response: {}",
|
||||
str::from_utf8(&packet).expect("response was not UTF-8")
|
||||
);
|
||||
|
|
|
@ -7,7 +7,8 @@ use core::str;
|
|||
use cortex_m_rt::entry;
|
||||
use dk::ieee802154::{Channel, Packet};
|
||||
use heapless::{consts, LinearMap, Vec};
|
||||
use panic_log as _; // the panicking behavior
|
||||
// this imports `beginner/apps/lib.rs` to retrieve our global logger + panicking-behavior
|
||||
use apps as _;
|
||||
|
||||
const TEN_MS: u32 = 10_000;
|
||||
|
||||
|
@ -41,11 +42,11 @@ fn main() -> ! {
|
|||
dict.insert(cipherletter, plainletter)
|
||||
.expect("dictionary full");
|
||||
} else {
|
||||
log::error!("response packet was not a single byte");
|
||||
defmt::error!("response packet was not a single byte");
|
||||
dk::exit()
|
||||
}
|
||||
} else {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
}
|
||||
|
@ -55,11 +56,11 @@ fn main() -> ! {
|
|||
radio.send(&mut packet);
|
||||
|
||||
if radio.recv_timeout(&mut packet, &mut timer, TEN_MS).is_err() {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"ciphertext: {}",
|
||||
str::from_utf8(&packet).expect("packet was not valid UTF-8")
|
||||
);
|
||||
|
@ -76,7 +77,7 @@ fn main() -> ! {
|
|||
buffer.push(plainletter).expect("buffer full");
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"plaintext: {}",
|
||||
str::from_utf8(&buffer).expect("buffer contains non-UTF-8 data")
|
||||
);
|
||||
|
@ -87,11 +88,11 @@ fn main() -> ! {
|
|||
radio.send(&mut packet);
|
||||
|
||||
if radio.recv_timeout(&mut packet, &mut timer, TEN_MS).is_err() {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
dk::exit()
|
||||
}
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"Dongle response: {}",
|
||||
str::from_utf8(&packet).expect("response was not UTF-8")
|
||||
);
|
||||
|
|
|
@ -6,7 +6,8 @@ use core::str;
|
|||
|
||||
use cortex_m_rt::entry;
|
||||
use dk::ieee802154::{Channel, Packet};
|
||||
use panic_log as _; // the panicking behavior
|
||||
// this imports `beginner/apps/lib.rs` to retrieve our global logger + panicking-behavior
|
||||
use apps as _;
|
||||
|
||||
const TEN_MS: u32 = 10_000;
|
||||
|
||||
|
@ -33,19 +34,19 @@ fn main() -> ! {
|
|||
// let msg = b"Hello?";
|
||||
|
||||
packet.copy_from_slice(msg);
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"sending: {}",
|
||||
str::from_utf8(msg).expect("msg was not valid UTF-8 data")
|
||||
);
|
||||
|
||||
radio.send(&mut packet);
|
||||
if radio.recv_timeout(&mut packet, &mut timer, TEN_MS).is_ok() {
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"received: {}",
|
||||
str::from_utf8(&packet).expect("response was not valid UTF-8 data")
|
||||
);
|
||||
} else {
|
||||
log::error!("no response or response packet was corrupted");
|
||||
defmt::error!("no response or response packet was corrupted");
|
||||
}
|
||||
dk::exit()
|
||||
}
|
||||
|
|
|
@ -6,7 +6,8 @@ use core::str;
|
|||
|
||||
use cortex_m_rt::entry;
|
||||
use dk::ieee802154::{Channel, Error, Packet};
|
||||
use panic_log as _; // the panicking behavior
|
||||
// this imports `beginner/apps/lib.rs` to retrieve our global logger + panicking-behavior
|
||||
use apps as _;
|
||||
|
||||
const TEN_MS: u32 = 10_000;
|
||||
|
||||
|
@ -24,7 +25,7 @@ fn main() -> ! {
|
|||
let msg = b"olleh";
|
||||
packet.copy_from_slice(msg);
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"sending: {}",
|
||||
str::from_utf8(msg).expect("message is not valid UTF-8")
|
||||
);
|
||||
|
@ -37,14 +38,15 @@ fn main() -> ! {
|
|||
|
||||
match res {
|
||||
Ok(crc) => {
|
||||
log::info!(
|
||||
"received: {} (CRC={})",
|
||||
defmt::info!(
|
||||
"received: {} (CRC = {:X})",
|
||||
// ^^ print as uppercase hexadecimal
|
||||
str::from_utf8(&*packet).expect("response is not valid UTF-8"),
|
||||
crc
|
||||
);
|
||||
}
|
||||
Err(Error::Crc(crc)) => log::error!("invalid CRC: {:06x}", crc),
|
||||
Err(Error::Timeout) => log::error!("no response within {} ms", TEN_MS / 1_000),
|
||||
Err(Error::Crc(crc)) => defmt::error!("invalid CRC: {=u16:x}", crc),
|
||||
Err(Error::Timeout) => defmt::error!("no response within {} ms", TEN_MS / 1_000),
|
||||
}
|
||||
|
||||
dk::exit()
|
||||
|
|
|
@ -6,7 +6,8 @@ use core::str;
|
|||
|
||||
use cortex_m_rt::entry;
|
||||
use dk::ieee802154::{Channel, Packet, TxPower};
|
||||
use panic_log as _; // the panicking behavior
|
||||
// this imports `beginner/apps/lib.rs` to retrieve our global logger + panicking-behavior
|
||||
use apps as _;
|
||||
|
||||
#[entry]
|
||||
fn main() -> ! {
|
||||
|
@ -25,7 +26,7 @@ fn main() -> ! {
|
|||
// let msg: &[u8; 5] = &[b'H', b'e', b'l', b'l', b'o'];
|
||||
// let msg: &[u8; 5] = b"Hello";
|
||||
|
||||
log::info!(
|
||||
defmt::info!(
|
||||
"sending: {}",
|
||||
str::from_utf8(msg).expect("msg is not valid UTF-8 data")
|
||||
);
|
||||
|
|
|
@ -3,14 +3,15 @@
|
|||
|
||||
use cortex_m::asm;
|
||||
use cortex_m_rt::entry;
|
||||
use panic_log as _; // panic handler
|
||||
// this imports `beginner/apps/lib.rs` to retrieve our global logger + panicking-behavior
|
||||
use apps as _;
|
||||
|
||||
#[entry]
|
||||
fn main() -> ! {
|
||||
// board initialization
|
||||
dk::init().unwrap();
|
||||
|
||||
log::info!("fib(100) = {:?}", fib(100));
|
||||
defmt::info!("fib(100) = {:?}", fib(100));
|
||||
|
||||
loop {
|
||||
asm::bkpt();
|
||||
|
|
Loading…
Reference in a new issue