diff options
| author | Adam Greig <adam@adamgreig.com> | 2021-09-29 22:45:33 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-09-29 22:45:33 +0100 |
| commit | a62c4551582a40712336f1f16ffb33591907e80e (patch) | |
| tree | 9dbc8a9accb73aa510f8be0189fb50537a0b7519 | |
| parent | 587e8bd658da6bdfe4da99416b4fa31b93575f77 (diff) | |
| parent | 1fe7f52c68cb590fe341294977c599d971b936a7 (diff) | |
Merge pull request #3 from mciantyre/shadowed-locals
Test read, modify, write macros
| -rw-r--r-- | tests/macros.rs | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/tests/macros.rs b/tests/macros.rs new file mode 100644 index 0000000..8ff36ac --- /dev/null +++ b/tests/macros.rs @@ -0,0 +1,102 @@ +//! Test the read, write, modify macros. + +use ral_registers as ral; + +struct DummyRegisterBlock { + register: ral::RWRegister<u32>, +} + +mod register { + #![allow(non_upper_case_globals, non_snake_case)] // Macro conventions. + + pub mod field_foo { + pub const offset: u32 = 10; + pub const mask: u32 = 0x7 << offset; + pub mod RW {} + pub mod W {} + pub mod R {} + } +} + +fn zeroed_register_block() -> DummyRegisterBlock { + use core::mem::MaybeUninit; + let register_block = MaybeUninit::zeroed(); + // Safety: 0 is a safe bitpattern + unsafe { register_block.assume_init() } +} + +#[test] +fn register_read() { + let register_block = zeroed_register_block(); + register_block.register.write(0b111 << 10); + assert_eq!( + 0x7, + ral::read_reg!(self, ®ister_block, register, field_foo) + ); +} + +#[test] +fn register_write() { + let register_block = zeroed_register_block(); + ral::write_reg!(self, ®ister_block, register, field_foo: 5); + assert_eq!(5 << 10, register_block.register.read()); +} + +#[test] +fn register_modify() { + let register_block = zeroed_register_block(); + register_block.register.write(1 << 10); + ral::modify_reg!(self, ®ister_block, register, field_foo: 6); + assert_eq!(6 << 10, register_block.register.read()); +} + +/// Demonstrates that a local variable, 'mask' +/// doesn't affect the macro's behavior. +/// +/// This is the same test as register_modify(), but +/// with the number '6' in a variable called 'mask'. +#[deny(warnings)] // Promotes "unused variable: mask" into an error. Should no longer happen. +#[test] +fn register_unused_mask_modify() { + let register_block = zeroed_register_block(); + register_block.register.write(1 << 10); + let mask = 6; + ral::modify_reg!(self, ®ister_block, register, field_foo: mask); + assert_eq!(6 << 10, register_block.register.read()); +} + +/// Same test as above, but with a variable called +/// 'offset' instead of 'mask'. +#[deny(warnings)] +#[test] +fn register_unused_offset_modify() { + let register_block = zeroed_register_block(); + register_block.register.write(1 << 10); + let offset = 6; + ral::modify_reg!(self, ®ister_block, register, field_foo: offset); + assert_eq!(6 << 10, register_block.register.read()); +} + +/// Same as above test, but using the 'write' macro +/// instead of 'modify'. +#[deny(warnings)] +#[test] +fn register_unused_mask_write() { + let register_block = zeroed_register_block(); + register_block.register.write(1 << 10); + let mask = 6; + ral::write_reg!(self, ®ister_block, register, field_foo: mask); + assert_eq!(6 << 10, register_block.register.read()); +} + +/// Same test as above, but with a variable called +/// 'offset' instead of 'mask'. +#[deny(warnings)] +#[test] +fn register_unused_offset_write() { + let register_block = zeroed_register_block(); + register_block.register.write(1 << 10); + let offset = 6; + ral::write_reg!(self, ®ister_block, register, field_foo: offset); + assert_eq!(6 << 10, register_block.register.read()); +} |
