slcr: add soft_rst()
This commit is contained in:
parent
b961526b97
commit
ee7ae7f7cc
15
src/slcr.rs
15
src/slcr.rs
|
@ -66,7 +66,7 @@ pub struct RegisterBlock {
|
||||||
reserved2: [u32; 5],
|
reserved2: [u32; 5],
|
||||||
pub clk_621_true: RW<u32>,
|
pub clk_621_true: RW<u32>,
|
||||||
reserved3: [u32; 14],
|
reserved3: [u32; 14],
|
||||||
pub pss_rst_ctrl: RW<u32>,
|
pub pss_rst_ctrl: PssRstCtrl,
|
||||||
pub ddr_rst_ctrl: RW<u32>,
|
pub ddr_rst_ctrl: RW<u32>,
|
||||||
pub topsw_rst_ctrl: RW<u32>,
|
pub topsw_rst_ctrl: RW<u32>,
|
||||||
pub dmac_rst_ctrl: RW<u32>,
|
pub dmac_rst_ctrl: RW<u32>,
|
||||||
|
@ -207,6 +207,16 @@ impl RegisterBlock {
|
||||||
self_.slcr_lock.lock();
|
self_.slcr_lock.lock();
|
||||||
r
|
r
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Perform a soft reset
|
||||||
|
pub fn soft_reset(&mut self) -> ! {
|
||||||
|
self.pss_rst_ctrl.write(
|
||||||
|
PssRstCtrl::zeroed()
|
||||||
|
.soft_rst(true)
|
||||||
|
);
|
||||||
|
|
||||||
|
unreachable!()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
register!(slcr_lock, SlcrLock, WO, u32);
|
register!(slcr_lock, SlcrLock, WO, u32);
|
||||||
|
@ -305,6 +315,9 @@ impl UartRstCtrl {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
register!(pss_rst_ctrl, PssRstCtrl, RW, u32);
|
||||||
|
register_bit!(pss_rst_ctrl, soft_rst, 1);
|
||||||
|
|
||||||
/// Used for MioPin*.io_type
|
/// Used for MioPin*.io_type
|
||||||
#[repr(u8)]
|
#[repr(u8)]
|
||||||
pub enum IoBufferType {
|
pub enum IoBufferType {
|
||||||
|
|
Loading…
Reference in New Issue