1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-17 05:12:57 +01:00

treewide/rust: cargo fmt

This commit is contained in:
chrysn 2024-10-02 22:17:08 +02:00
parent 44cd632af0
commit 69a89b80ca
6 changed files with 105 additions and 52 deletions

View File

@ -1,9 +1,9 @@
#![no_std] #![no_std]
use lsm303agr::{interface, mode, Lsm303agr, AccelOutputDataRate::Hz50, AccelMode}; use lsm303agr::{interface, mode, AccelMode, AccelOutputDataRate::Hz50, Lsm303agr};
use riot_wrappers::{saul, println, i2c, cstr::cstr, mutex::Mutex}; use riot_wrappers::{cstr::cstr, i2c, mutex::Mutex, println, saul};
use saul::{Phydat, registration}; use saul::{registration, Phydat};
// FIXME: Is this the way we want to go? It's mimicking the C way, but we could just as well take // FIXME: Is this the way we want to go? It's mimicking the C way, but we could just as well take
// the board config from some YAML. // the board config from some YAML.
@ -29,8 +29,10 @@ static DRIVER_MAG: registration::Driver<SaulLSM, MagAspect> = registration::Driv
// device is registered. (In an alternative implementation where all SAUL registries are managed by // device is registered. (In an alternative implementation where all SAUL registries are managed by
// XFA, this would be possible; finding the point in time when they are ready to be used would be // XFA, this would be possible; finding the point in time when they are ready to be used would be
// tricky, though.). // tricky, though.).
static REG: Mutex<[Option<registration::Registration<SaulLSM>>; NDEVICES]> = Mutex::new([None; NDEVICES]); static REG: Mutex<[Option<registration::Registration<SaulLSM>>; NDEVICES]> =
static REG_MAG: Mutex<[Option<registration::Registration<SaulLSM, MagAspect>>; NDEVICES]> = Mutex::new([None; NDEVICES]); Mutex::new([None; NDEVICES]);
static REG_MAG: Mutex<[Option<registration::Registration<SaulLSM, MagAspect>>; NDEVICES]> =
Mutex::new([None; NDEVICES]);
// This can't go into ROM because it contains an inner Mutex (and possibly state data from the // This can't go into ROM because it contains an inner Mutex (and possibly state data from the
// Lsm303agr instance, didn't bother to check) // Lsm303agr instance, didn't bother to check)
static LSM: Mutex<[Option<SaulLSM>; NDEVICES]> = Mutex::new([None; NDEVICES]); static LSM: Mutex<[Option<SaulLSM>; NDEVICES]> = Mutex::new([None; NDEVICES]);
@ -45,31 +47,40 @@ pub extern "C" fn auto_init_lsm303agr() {
/// Initialize the configured LSM303AGR device, returning an error string for debug if anything /// Initialize the configured LSM303AGR device, returning an error string for debug if anything
/// goes wrong /// goes wrong
fn init() -> Result<(), &'static str> { fn init() -> Result<(), &'static str> {
let lsm = LSM let lsm = LSM.try_leak().expect("LSM303AGR init is only called once");
.try_leak()
.expect("LSM303AGR init is only called once");
let reg = REG let reg = REG.try_leak().expect("LSM303AGR init is only called once");
.try_leak()
.expect("LSM303AGR init is only called once");
let reg_mag = REG_MAG let reg_mag = REG_MAG
.try_leak() .try_leak()
.expect("LSM303AGR init is only called once"); .expect("LSM303AGR init is only called once");
for (&i2cdev, (lsm, (reg, reg_mag))) in I2C_DEVICES.iter().zip(lsm.iter_mut().zip(reg.iter_mut().zip(reg_mag.iter_mut()))) { for (&i2cdev, (lsm, (reg, reg_mag))) in I2C_DEVICES
.iter()
.zip(lsm.iter_mut().zip(reg.iter_mut().zip(reg_mag.iter_mut())))
{
let mut device = Lsm303agr::new_with_i2c(i2c::I2CDevice::new(i2cdev)); let mut device = Lsm303agr::new_with_i2c(i2c::I2CDevice::new(i2cdev));
let mut init_clock = riot_wrappers::ztimer::Clock::msec(); let mut init_clock = riot_wrappers::ztimer::Clock::msec();
device.init() device.init().map_err(|_| "Device initialization failed")?;
.map_err(|_| "Device initialization failed")?; device
device.set_accel_mode_and_odr(&mut init_clock, AccelMode::Normal, Hz50) .set_accel_mode_and_odr(&mut init_clock, AccelMode::Normal, Hz50)
.map_err(|_| "Device configuration failed")?; .map_err(|_| "Device configuration failed")?;
let lsm = lsm.insert(SaulLSM { device: Mutex::new(device) }); let lsm = lsm.insert(SaulLSM {
device: Mutex::new(device),
});
let reg = reg.insert(registration::Registration::new(&DRIVER, lsm, Some(cstr!("LSM303AGR accelerometer")))); let reg = reg.insert(registration::Registration::new(
let reg_mag = reg_mag.insert(registration::Registration::new(&DRIVER_MAG, lsm, Some(cstr!("LSM303AGR magnetometer")))); &DRIVER,
lsm,
Some(cstr!("LSM303AGR accelerometer")),
));
let reg_mag = reg_mag.insert(registration::Registration::new(
&DRIVER_MAG,
lsm,
Some(cstr!("LSM303AGR magnetometer")),
));
reg.register_static(); reg.register_static();
reg_mag.register_static(); reg_mag.register_static();
@ -89,13 +100,15 @@ impl registration::Drivable for &SaulLSM {
fn read(self) -> Result<Phydat, registration::Error> { fn read(self) -> Result<Phydat, registration::Error> {
// SAUL doesn't guarantee exclusive access; different threads may read simultaneously. // SAUL doesn't guarantee exclusive access; different threads may read simultaneously.
let mut device = self.device.try_lock() let mut device = self.device.try_lock().ok_or(registration::Error)?;
.ok_or(registration::Error)?;
let data = device.acceleration() let data = device.acceleration().map_err(|_| registration::Error)?;
.map_err(|_| registration::Error)?;
// Data is in the +-2g range by default, which doesn't overflow even the i16 SAUL uses // Data is in the +-2g range by default, which doesn't overflow even the i16 SAUL uses
Ok(Phydat::new(&[data.x_mg() as _, data.y_mg() as _, data.z_mg() as _], Some(saul::Unit::GForce), -3)) Ok(Phydat::new(
&[data.x_mg() as _, data.y_mg() as _, data.z_mg() as _],
Some(saul::Unit::GForce),
-3,
))
} }
} }
@ -114,11 +127,13 @@ impl registration::Drivable for MagAspect {
fn read(self) -> Result<Phydat, registration::Error> { fn read(self) -> Result<Phydat, registration::Error> {
// SAUL doesn't guarantee exclusive access; different threads may read simultaneously. // SAUL doesn't guarantee exclusive access; different threads may read simultaneously.
let mut device = self.0.device.try_lock() let mut device = self.0.device.try_lock().ok_or(registration::Error)?;
.ok_or(registration::Error)?;
let data = device.magnetic_field() let data = device.magnetic_field().map_err(|_| registration::Error)?;
.map_err(|_| registration::Error)?; return Ok(Phydat::fit(
return Ok(Phydat::fit(&[data.x_nt(), data.y_nt(), data.z_nt()], Some(saul::Unit::T), -9)) &[data.x_nt(), data.y_nt(), data.z_nt()],
Some(saul::Unit::T),
-9,
));
} }
} }

View File

@ -5,8 +5,8 @@
// directory for more details. // directory for more details.
#![no_std] #![no_std]
use riot_wrappers::riot_main;
use riot_wrappers::println; use riot_wrappers::println;
use riot_wrappers::riot_main;
use riot_wrappers::ztimer::{Clock, Ticks}; use riot_wrappers::ztimer::{Clock, Ticks};
use static_cell::StaticCell; use static_cell::StaticCell;
@ -20,7 +20,9 @@ fn main() {
static EXECUTOR: StaticCell<embassy_executor_riot::Executor> = StaticCell::new(); static EXECUTOR: StaticCell<embassy_executor_riot::Executor> = StaticCell::new();
let executor: &'static mut _ = EXECUTOR.init(embassy_executor_riot::Executor::new()); let executor: &'static mut _ = EXECUTOR.init(embassy_executor_riot::Executor::new());
executor.run(|spawner| { executor.run(|spawner| {
spawner.spawn(amain(spawner)).expect("Starting task for the first time"); spawner
.spawn(amain(spawner))
.expect("Starting task for the first time");
}) })
} }
@ -28,8 +30,12 @@ fn main() {
async fn amain(spawner: embassy_executor::Spawner) { async fn amain(spawner: embassy_executor::Spawner) {
println!("Running asynchronously:"); println!("Running asynchronously:");
spawner.spawn(fast_messages("A")).expect("Starting task for the first time"); spawner
spawner.spawn(fast_messages("B")).expect("Task is configured to allow two instances"); .spawn(fast_messages("A"))
.expect("Starting task for the first time");
spawner
.spawn(fast_messages("B"))
.expect("Task is configured to allow two instances");
let msec = Clock::msec(); let msec = Clock::msec();

View File

@ -5,10 +5,10 @@
// directory for more details. // directory for more details.
#![no_std] #![no_std]
use riot_wrappers::{riot_main, println}; use riot_wrappers::{gcoap, gnrc, ztimer};
use riot_wrappers::{gcoap, ztimer, gnrc}; use riot_wrappers::{println, riot_main};
use coap_handler_implementations::{ReportingHandlerBuilder, HandlerBuilder}; use coap_handler_implementations::{HandlerBuilder, ReportingHandlerBuilder};
extern crate rust_riotmodules; extern crate rust_riotmodules;
@ -21,40 +21,65 @@ fn main() {
unsafe { do_vfs_init() }; unsafe { do_vfs_init() };
static PINGS: riot_coap_handler_demos::ping::PingPool = riot_coap_handler_demos::ping::PingPool::new(); static PINGS: riot_coap_handler_demos::ping::PingPool =
static PING_PASSIVE: riot_coap_handler_demos::ping_passive::PingHistoryMutex<{ riot_coap_handler_demos::ping_passive::DEFAULT_SIZE }> = riot_coap_handler_demos::ping_passive::PingHistoryMutex::new(); riot_coap_handler_demos::ping::PingPool::new();
static PING_PASSIVE: riot_coap_handler_demos::ping_passive::PingHistoryMutex<
{ riot_coap_handler_demos::ping_passive::DEFAULT_SIZE },
> = riot_coap_handler_demos::ping_passive::PingHistoryMutex::new();
let handler = coap_message_demos::full_application_tree(None) let handler = coap_message_demos::full_application_tree(None)
.below(&["ps"], riot_coap_handler_demos::ps::ps_tree()) .below(&["ps"], riot_coap_handler_demos::ps::ps_tree())
.below(&["led"], riot_coap_handler_demos::led::all_leds()) .below(&["led"], riot_coap_handler_demos::led::all_leds())
.below(&["vfs"], riot_coap_handler_demos::vfs::vfs("")) .below(&["vfs"], riot_coap_handler_demos::vfs::vfs(""))
.below(&["saul"], riot_coap_handler_demos::saul::SaulHandler::new(&["saul"])) .below(
&["saul"],
riot_coap_handler_demos::saul::SaulHandler::new(&["saul"]),
)
.below(&["netif"], riot_coap_handler_demos::netif::netif()) .below(&["netif"], riot_coap_handler_demos::netif::netif())
.below(&["nib", "neigh"], riot_coap_handler_demos::nib::neighbor_cache()) .below(
&["nib", "neigh"],
riot_coap_handler_demos::nib::neighbor_cache(),
)
.below(&["ping"], riot_coap_handler_demos::ping::ping_tree(&PINGS)) .below(&["ping"], riot_coap_handler_demos::ping::ping_tree(&PINGS))
.at(&["pinged"], riot_coap_handler_demos::ping_passive::resource(&PING_PASSIVE)) .at(
.with_wkc() &["pinged"],
; riot_coap_handler_demos::ping_passive::resource(&PING_PASSIVE),
)
.with_wkc();
let mut handler = riot_wrappers::coap_handler::v0_2::GcoapHandler(handler); let mut handler = riot_wrappers::coap_handler::v0_2::GcoapHandler(handler);
let mut listener = gcoap::SingleHandlerListener::new_catch_all(&mut handler); let mut listener = gcoap::SingleHandlerListener::new_catch_all(&mut handler);
static SLOT: static_cell::StaticCell<gnrc::netreg::callback::Slot<riot_coap_handler_demos::ping::PingCallback>> = static_cell::StaticCell::new(); static SLOT: static_cell::StaticCell<
gnrc::netreg::callback::Slot<riot_coap_handler_demos::ping::PingCallback>,
> = static_cell::StaticCell::new();
PINGS.register(SLOT.init(Default::default())); PINGS.register(SLOT.init(Default::default()));
static PASSIVE_SLOT: static_cell::StaticCell<gnrc::netreg::callback::Slot<&'static riot_coap_handler_demos::ping_passive::PingHistoryMutex<{ riot_coap_handler_demos::ping_passive::DEFAULT_SIZE }>>> = static_cell::StaticCell::new(); static PASSIVE_SLOT: static_cell::StaticCell<
gnrc::netreg::callback::Slot<
&'static riot_coap_handler_demos::ping_passive::PingHistoryMutex<
{ riot_coap_handler_demos::ping_passive::DEFAULT_SIZE },
>,
>,
> = static_cell::StaticCell::new();
PING_PASSIVE.register(PASSIVE_SLOT.init(Default::default())); PING_PASSIVE.register(PASSIVE_SLOT.init(Default::default()));
gcoap::scope(|greg| { gcoap::scope(|greg| {
greg.register(&mut listener); greg.register(&mut listener);
println!("CoAP server ready; waiting for interfaces to settle before reporting addresses..."); println!(
"CoAP server ready; waiting for interfaces to settle before reporting addresses..."
);
let sectimer = ztimer::Clock::sec(); let sectimer = ztimer::Clock::sec();
sectimer.sleep(ztimer::Ticks(2)); sectimer.sleep(ztimer::Ticks(2));
for netif in gnrc::Netif::all() { for netif in gnrc::Netif::all() {
println!("Active interface from PID {:?} ({:?})", netif.pid(), netif.pid().get_name().unwrap_or("unnamed")); println!(
"Active interface from PID {:?} ({:?})",
netif.pid(),
netif.pid().get_name().unwrap_or("unnamed")
);
match netif.ipv6_addrs() { match netif.ipv6_addrs() {
Ok(addrs) => { Ok(addrs) => {
for a in &addrs { for a in &addrs {

View File

@ -5,8 +5,8 @@
// directory for more details. // directory for more details.
#![no_std] #![no_std]
use riot_wrappers::riot_main;
use riot_wrappers::println; use riot_wrappers::println;
use riot_wrappers::riot_main;
extern crate rust_riotmodules; extern crate rust_riotmodules;

View File

@ -1,13 +1,20 @@
#![no_std] #![no_std]
use riot_wrappers::println;
use core::fmt::Write; use core::fmt::Write;
use riot_wrappers::println;
riot_wrappers::static_command!(static_hello_world, "hello_world", "Print a greeting", hello_world); riot_wrappers::static_command!(
static_hello_world,
"hello_world",
"Print a greeting",
hello_world
);
pub fn hello_world<'a>(_w: &mut impl Write, args: impl IntoIterator<Item=&'a str>) { pub fn hello_world<'a>(_w: &mut impl Write, args: impl IntoIterator<Item = &'a str>) {
let mut args = args.into_iter(); let mut args = args.into_iter();
let commandname = args.next().expect("How was this started without an argv[0]?"); let commandname = args
.next()
.expect("How was this started without an argv[0]?");
match args.next() { match args.next() {
Some("--help") => println!("Usage: {commandname}"), Some("--help") => println!("Usage: {commandname}"),

View File

@ -5,8 +5,8 @@
// directory for more details. // directory for more details.
#![no_std] #![no_std]
use riot_wrappers::riot_main;
use riot_wrappers::println; use riot_wrappers::println;
use riot_wrappers::riot_main;
extern crate rust_riotmodules; extern crate rust_riotmodules;