register-rs
Common interface for MMIO and CPU registers
Usage
This crate uses the tock-register-interface, please refer to their
Readme
for the whole API.
Defining a CPU register
#![feature(use_extern_macros)]
#![feature(asm)]
#[macro_use]
extern crate register;
use register::cpu::RegisterReadWrite;
register_bitfields! {u32,
CNTP_CTL_EL0 [
ENABLE OFFSET(0) NUMBITS(1) [],
IMASK OFFSET(1) NUMBITS(1) [],
ISTATUS OFFSET(2) NUMBITS(1) []
]
}
struct Reg;
impl RegisterReadWrite<u32, CNTP_CTL_EL0::Register> for Reg {
#[inline]
fn get(&self) -> u32 {
let reg;
unsafe {
asm!("mrs $0, CNTP_CTL_EL0" : "=r"(reg) ::: "volatile");
}
reg
}
#[inline]
fn set(&self, value: u32) {
unsafe {
asm!("msr CNTP_CTL_EL0, $0" :: "r"(value) :: "volatile");
}
}
}
static CNTP_CTL_EL0: Reg = Reg {};
fn main() {
CNTP_CTL_EL0.modify(CNTP_CTL_EL0::ENABLE::SET + CNTP_CTL_EL0::IMASK::SET);
}
Defining MMIO registers
#![feature(use_extern_macros)]
#[macro_use]
extern crate register;
use register::mmio::*;
register_bitfields! {
u32,
GPFSEL1 [
FSEL14 OFFSET(12) NUMBITS(3) [
Input = 0b000,
Output = 0b001,
TXD0 = 0b100
],
FSEL15 OFFSET(15) NUMBITS(3) [
Input = 0b000,
Output = 0b001,
RXD0 = 0b100
]
]
}
#[allow(non_snake_case)]
#[repr(C)]
pub struct RegisterBlock {
GPFSEL1: ReadWrite<u32, GPFSEL1::Register>, SYSTMR_HI: ReadOnly<u32>, }
fn main() {
let regs = 0x1337_0000 as *const RegisterBlock;
unsafe { (*regs).SYSTMR_HI.get() };
}
License
Licensed under either of
at your option.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the
work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any
additional terms or conditions.