diff options
| author | Jorge Aparicio <jorge@japaric.io> | 2017-04-25 14:13:46 -0500 |
|---|---|---|
| committer | Jorge Aparicio <jorge@japaric.io> | 2017-04-25 14:13:46 -0500 |
| commit | 8659ecea720193ab7e6d760f5948635be5b940d4 (patch) | |
| tree | 0e2abb3041db252842283c1a965eec638aac147f /tests | |
| parent | e72687a36635ccfce494f8807269bf897b3b6d7b (diff) | |
add a `peripherals!` macro
for safe declaration of `Peripheral`s
closes #12
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/cfail/peripherals-alias-1.rs | 68 | ||||
| -rw-r--r-- | tests/cfail/peripherals-alias-2.rs | 74 |
2 files changed, 142 insertions, 0 deletions
diff --git a/tests/cfail/peripherals-alias-1.rs b/tests/cfail/peripherals-alias-1.rs new file mode 100644 index 0000000..0dfe8d1 --- /dev/null +++ b/tests/cfail/peripherals-alias-1.rs @@ -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 }; + } +} diff --git a/tests/cfail/peripherals-alias-2.rs b/tests/cfail/peripherals-alias-2.rs new file mode 100644 index 0000000..e649459 --- /dev/null +++ b/tests/cfail/peripherals-alias-2.rs @@ -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 }; + } +} |
