mirror of
https://github.com/rtic-rs/rtic.git
synced 2024-11-23 20:22:51 +01:00
add a peripherals!
macro
for safe declaration of `Peripheral`s closes #12
This commit is contained in:
parent
e72687a366
commit
8659ecea72
3 changed files with 160 additions and 0 deletions
18
src/lib.rs
18
src/lib.rs
|
@ -705,6 +705,24 @@ pub unsafe trait GreaterThanOrEqual<RHS> {}
|
||||||
/// Do not implement this trait yourself. This is an implementation detail.
|
/// Do not implement this trait yourself. This is an implementation detail.
|
||||||
pub unsafe trait LessThanOrEqual<RHS> {}
|
pub unsafe trait LessThanOrEqual<RHS> {}
|
||||||
|
|
||||||
|
/// Assigns ceilings to peripherals
|
||||||
|
#[macro_export]
|
||||||
|
macro_rules! peripherals {
|
||||||
|
($device:ident, {
|
||||||
|
$($PERIPHERAL:ident: Peripheral {
|
||||||
|
register_block: $RegisterBlock:ident,
|
||||||
|
ceiling: $C:ident,
|
||||||
|
},)+
|
||||||
|
}) => {
|
||||||
|
$(
|
||||||
|
#[no_mangle]
|
||||||
|
static $PERIPHERAL:
|
||||||
|
$crate::Peripheral<::$device::$RegisterBlock, $crate::$C> =
|
||||||
|
unsafe { $crate::Peripheral::new(::$device::$PERIPHERAL) };
|
||||||
|
)+
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// A macro to declare tasks
|
/// A macro to declare tasks
|
||||||
///
|
///
|
||||||
/// **NOTE** This macro will expand to a `main` function.
|
/// **NOTE** This macro will expand to a `main` function.
|
||||||
|
|
68
tests/cfail/peripherals-alias-1.rs
Normal file
68
tests/cfail/peripherals-alias-1.rs
Normal file
|
@ -0,0 +1,68 @@
|
||||||
|
// error-pattern: has already been defined
|
||||||
|
|
||||||
|
#![feature(used)]
|
||||||
|
|
||||||
|
#[macro_use]
|
||||||
|
extern crate cortex_m_rtfm as rtfm;
|
||||||
|
|
||||||
|
use rtfm::{C16, P0, P1};
|
||||||
|
use device::interrupt::Exti0;
|
||||||
|
|
||||||
|
peripherals!(device, {
|
||||||
|
GPIOA: Peripheral {
|
||||||
|
register_block: Gpioa,
|
||||||
|
ceiling: C1,
|
||||||
|
},
|
||||||
|
// WRONG: peripheral alias
|
||||||
|
GPIOA: Peripheral {
|
||||||
|
register_block: Gpioa,
|
||||||
|
ceiling: C2,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
tasks!(device, {});
|
||||||
|
|
||||||
|
fn init(_: P0, _: &C16) {}
|
||||||
|
|
||||||
|
fn idle(_: P0) -> ! {
|
||||||
|
loop {}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn j1(_task: Exti0, _prio: P1) {}
|
||||||
|
|
||||||
|
// fake device crate
|
||||||
|
extern crate core;
|
||||||
|
extern crate cortex_m;
|
||||||
|
|
||||||
|
mod device {
|
||||||
|
use cortex_m::peripheral::Peripheral;
|
||||||
|
|
||||||
|
pub const GPIOA: Peripheral<Gpioa> = unsafe { Peripheral::new(0x0) };
|
||||||
|
|
||||||
|
pub struct Gpioa;
|
||||||
|
|
||||||
|
pub mod interrupt {
|
||||||
|
use cortex_m::interrupt::Nr;
|
||||||
|
|
||||||
|
extern "C" fn default_handler<T>(_: T) {}
|
||||||
|
|
||||||
|
pub struct Handlers {
|
||||||
|
pub Exti0: extern "C" fn(Exti0),
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct Exti0;
|
||||||
|
|
||||||
|
pub enum Interrupt {
|
||||||
|
Exti0,
|
||||||
|
}
|
||||||
|
|
||||||
|
unsafe impl Nr for Interrupt {
|
||||||
|
fn nr(&self) -> u8 {
|
||||||
|
0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub const DEFAULT_HANDLERS: Handlers =
|
||||||
|
Handlers { Exti0: default_handler };
|
||||||
|
}
|
||||||
|
}
|
74
tests/cfail/peripherals-alias-2.rs
Normal file
74
tests/cfail/peripherals-alias-2.rs
Normal file
|
@ -0,0 +1,74 @@
|
||||||
|
// error-pattern: symbol `GPIOA` is already defined
|
||||||
|
|
||||||
|
#![feature(const_fn)]
|
||||||
|
#![feature(used)]
|
||||||
|
|
||||||
|
#[macro_use]
|
||||||
|
extern crate cortex_m_rtfm as rtfm;
|
||||||
|
|
||||||
|
use rtfm::{C16, P0, P1};
|
||||||
|
use device::interrupt::Exti0;
|
||||||
|
|
||||||
|
peripherals!(device, {
|
||||||
|
GPIOA: Peripheral {
|
||||||
|
register_block: Gpioa,
|
||||||
|
ceiling: C1,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
mod foo {
|
||||||
|
// WRONG: peripheral alias
|
||||||
|
peripherals!(device, {
|
||||||
|
GPIOA: Peripheral {
|
||||||
|
register_block: Gpioa,
|
||||||
|
ceiling: C2,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
tasks!(device, {});
|
||||||
|
|
||||||
|
fn init(_: P0, _: &C16) {}
|
||||||
|
|
||||||
|
fn idle(_: P0) -> ! {
|
||||||
|
loop {}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn j1(_task: Exti0, _prio: P1) {}
|
||||||
|
|
||||||
|
// fake device crate
|
||||||
|
extern crate core;
|
||||||
|
extern crate cortex_m;
|
||||||
|
|
||||||
|
mod device {
|
||||||
|
use cortex_m::peripheral::Peripheral;
|
||||||
|
|
||||||
|
pub const GPIOA: Peripheral<Gpioa> = unsafe { Peripheral::new(0x0) };
|
||||||
|
|
||||||
|
pub struct Gpioa;
|
||||||
|
|
||||||
|
pub mod interrupt {
|
||||||
|
use cortex_m::interrupt::Nr;
|
||||||
|
|
||||||
|
extern "C" fn default_handler<T>(_: T) {}
|
||||||
|
|
||||||
|
pub struct Handlers {
|
||||||
|
pub Exti0: extern "C" fn(Exti0),
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct Exti0;
|
||||||
|
|
||||||
|
pub enum Interrupt {
|
||||||
|
Exti0,
|
||||||
|
}
|
||||||
|
|
||||||
|
unsafe impl Nr for Interrupt {
|
||||||
|
fn nr(&self) -> u8 {
|
||||||
|
0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub const DEFAULT_HANDLERS: Handlers =
|
||||||
|
Handlers { Exti0: default_handler };
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue