diff options
| author | Christian Cunningham <cc@localhost> | 2022-08-26 17:25:34 -0700 | 
|---|---|---|
| committer | Christian Cunningham <cc@localhost> | 2022-08-26 17:25:34 -0700 | 
| commit | a04cf2dbb8d2e890405fbf0a1022aaad3015b1e8 (patch) | |
| tree | 381892074d13c059d50cb88caa41f8a8722c07ce /src/bsp/drivers/gpio | |
| parent | 7f3d7d9ce9818078b6a4616b4c31a28e2868397b (diff) | |
Modularize
Diffstat (limited to 'src/bsp/drivers/gpio')
| -rw-r--r-- | src/bsp/drivers/gpio/mod.rs | 28 | 
1 files changed, 28 insertions, 0 deletions
| diff --git a/src/bsp/drivers/gpio/mod.rs b/src/bsp/drivers/gpio/mod.rs new file mode 100644 index 0000000..a94c6e5 --- /dev/null +++ b/src/bsp/drivers/gpio/mod.rs @@ -0,0 +1,28 @@ +/// # GPIO Register +pub mod GPPUD { +    const ADDR: u32 = 0x3F200094; +    pub fn set(v: u32) { +        use crate::cpu::store32; +        store32(ADDR, v) +    } +    pub fn clear() { +        set(0) +    } +} +/// # GPIO Clock 0 Register +pub mod GPPUDCLK0 { +    const ADDR: u32 = 0x3F200098; +    const MASK: u32 = (1 << 14) | (1 << 15); +    pub fn set(v: u32) { +        use crate::cpu::store32; +        store32(ADDR, v) +    } +    pub fn init() { +        use crate::cpu::spin_for_n_cycles; +        super::GPPUD::clear(); +        spin_for_n_cycles(150); +        set(MASK); +        spin_for_n_cycles(150); +        set(0); +    } +} | 
