forked from M-Labs/artiq
1
0
Fork 0

Rust: add some conditional compilation back to rtio_crg.

This commit is contained in:
whitequark 2016-10-04 08:58:21 +00:00
parent b590c6c7d8
commit 2e4d19a1ce
1 changed files with 38 additions and 20 deletions

View File

@ -1,8 +1,42 @@
use board::csr; use config;
use {clock, config};
#[cfg(has_rtio_crg)]
mod imp {
use board::csr;
use clock;
pub fn init() {
unsafe { csr::rtio_crg::pll_reset_write(0) }
}
pub fn check() -> bool {
unsafe { csr::rtio_crg::pll_locked_read() != 0 }
}
pub fn switch_clock(clk: u8) -> bool {
unsafe {
let cur_clk = csr::rtio_crg::clock_sel_read();
if clk != cur_clk {
csr::rtio_crg::pll_reset_write(1);
csr::rtio_crg::clock_sel_write(clk);
csr::rtio_crg::pll_reset_write(0);
}
}
clock::spin_us(150);
return check()
}
}
#[cfg(not(has_rtio_crg))]
mod imp {
pub fn init() {}
pub fn check() -> bool { true }
pub fn switch_clock(clk: u8) -> bool { true }
}
pub fn init() { pub fn init() {
unsafe { csr::rtio_crg::pll_reset_write(0) } imp::init();
let mut opt = [b'i']; let mut opt = [b'i'];
let clk; let clk;
@ -28,20 +62,4 @@ pub fn init() {
} }
} }
pub fn check() -> bool { pub use self::imp::{check, switch_clock};
unsafe { csr::rtio_crg::pll_locked_read() != 0 }
}
pub fn switch_clock(clk: u8) -> bool {
unsafe {
let cur_clk = csr::rtio_crg::clock_sel_read();
if clk != cur_clk {
csr::rtio_crg::pll_reset_write(1);
csr::rtio_crg::clock_sel_write(clk);
csr::rtio_crg::pll_reset_write(0);
}
}
clock::spin_us(150);
return check()
}