qingke 0.7.0

Low level access to WCH's QingKe RISC-V processors
Documentation
#![allow(unused)]

macro_rules! read_csr_as {
    ($register:ident, $csr_number:expr) => {
        /// Reads the CSR
        #[inline]
        pub fn read() -> $register {
            let bits: usize;
            unsafe { asm!(concat!("csrr {}, ",$csr_number), out(reg) bits) };
            $register { bits }
        }
    };
}

macro_rules! set_csr {
    ($(#[$attr:meta])*, $csr_number:expr, $set_field:ident, $e:expr) => {
        $(#[$attr])*
        #[inline]
        pub unsafe fn $set_field() {
            unsafe { asm!(concat!("csrs ",$csr_number,", {0}"), in(reg) $e) }
        }
    }
}

macro_rules! clear_csr {
    ($(#[$attr:meta])*, $csr_number:expr, $clear_field:ident, $e:expr) => {
        $(#[$attr])*
        #[inline]
        pub unsafe fn $clear_field() {
            unsafe { asm!(concat!("csrc ",$csr_number,", {0}"), in(reg) $e) }
        }
    }
}

macro_rules! set_clear_csr {
    ($(#[$attr:meta])*, $csr_number:expr, $set_field:ident, $clear_field:ident, $e:expr) => {
        set_csr!($(#[$attr])*, $csr_number, $set_field, $e);
        clear_csr!($(#[$attr])*, $csr_number, $clear_field, $e);
    }
}
macro_rules! get_csr_value {
    ($csr_number:expr) => {
        {
            let r: usize;
            asm!(concat!("csrr {}, ",$csr_number), out(reg) r);
            r
        }
    };
}

macro_rules! write_csr {
    ($csr_number:literal) => {
        /// Writes the CSR
        #[inline]
        #[allow(unused_variables)]
        unsafe fn _write(bits: usize) {
            unsafe { core::arch::asm!(concat!("csrrw x0, ", stringify!($csr_number), ", {0}"), in(reg) bits) };
        }
    };
}