mirror of
https://github.com/italicsjenga/rp-hal-boards.git
synced 2025-01-11 13:01:30 +11:00
Update embedded time
This commit is contained in:
parent
512172179a
commit
bcfbd72ed1
|
@ -13,7 +13,7 @@ license = "MIT OR Apache-2.0"
|
||||||
cortex-m = "0.7.2"
|
cortex-m = "0.7.2"
|
||||||
rp2040-hal = { path = "../../rp2040-hal", version = "0.1.0" }
|
rp2040-hal = { path = "../../rp2040-hal", version = "0.1.0" }
|
||||||
cortex-m-rt = { version = "0.6.14", optional = true }
|
cortex-m-rt = { version = "0.6.14", optional = true }
|
||||||
embedded-time = "0.10.1"
|
embedded-time = "0.12.0"
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
panic-halt= "0.2.0"
|
panic-halt= "0.2.0"
|
||||||
|
|
|
@ -40,7 +40,7 @@ fn main() -> ! {
|
||||||
.ok()
|
.ok()
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
let mut delay = cortex_m::delay::Delay::new(core.SYST, *clocks.system_clock.freq().integer());
|
let mut delay = cortex_m::delay::Delay::new(core.SYST, clocks.system_clock.freq().integer());
|
||||||
|
|
||||||
let sio = Sio::new(pac.SIO);
|
let sio = Sio::new(pac.SIO);
|
||||||
let pins = Pins::new(
|
let pins = Pins::new(
|
||||||
|
|
|
@ -44,7 +44,7 @@ fn main() -> ! {
|
||||||
.ok()
|
.ok()
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
let mut delay = cortex_m::delay::Delay::new(core.SYST, *clocks.system_clock.freq().integer());
|
let mut delay = cortex_m::delay::Delay::new(core.SYST, clocks.system_clock.freq().integer());
|
||||||
|
|
||||||
let mut pwm_pin = Pwm4::new(25);
|
let mut pwm_pin = Pwm4::new(25);
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,7 @@ license = "MIT OR Apache-2.0"
|
||||||
[dependencies]
|
[dependencies]
|
||||||
cortex-m = "0.7.2"
|
cortex-m = "0.7.2"
|
||||||
embedded-hal = { version = "0.2.5", features=["unproven"] }
|
embedded-hal = { version = "0.2.5", features=["unproven"] }
|
||||||
embedded-time = "0.10"
|
embedded-time = "0.12.0"
|
||||||
nb = "1.0"
|
nb = "1.0"
|
||||||
rp2040-pac = { git = "https://github.com/rp-rs/rp2040-pac", branch="main" }
|
rp2040-pac = { git = "https://github.com/rp-rs/rp2040-pac", branch="main" }
|
||||||
paste = "1.0"
|
paste = "1.0"
|
||||||
|
|
|
@ -191,7 +191,7 @@ macro_rules! clock {
|
||||||
let div = if freq.eq(&src_freq) {
|
let div = if freq.eq(&src_freq) {
|
||||||
1 << 8
|
1 << 8
|
||||||
} else {
|
} else {
|
||||||
*(shifted_src_freq / *freq.integer() as u64).integer() as u32
|
(shifted_src_freq / freq.integer() as u64).integer() as u32
|
||||||
};
|
};
|
||||||
|
|
||||||
// If increasing divisor, set divisor before source. Otherwise set source
|
// If increasing divisor, set divisor before source. Otherwise set source
|
||||||
|
@ -348,7 +348,7 @@ macro_rules! stoppable_clock {
|
||||||
let div = if freq.eq(&src_freq) {
|
let div = if freq.eq(&src_freq) {
|
||||||
1 << 8
|
1 << 8
|
||||||
} else {
|
} else {
|
||||||
*(shifted_src_freq / *freq.integer() as u64).integer() as u32
|
(shifted_src_freq / freq.integer() as u64).integer() as u32
|
||||||
};
|
};
|
||||||
|
|
||||||
// If increasing divisor, set divisor before source. Otherwise set source
|
// If increasing divisor, set divisor before source. Otherwise set source
|
||||||
|
@ -370,7 +370,7 @@ macro_rules! stoppable_clock {
|
||||||
// Note XOSC_COUNT is not helpful here because XOSC is not
|
// Note XOSC_COUNT is not helpful here because XOSC is not
|
||||||
// necessarily running, nor is timer... so, 3 cycles per loop:
|
// necessarily running, nor is timer... so, 3 cycles per loop:
|
||||||
let sys_freq = 125_000_000; // TODO get actual sys_clk frequency
|
let sys_freq = 125_000_000; // TODO get actual sys_clk frequency
|
||||||
let delay_cyc = sys_freq / *self.frequency.integer() + 1u32;
|
let delay_cyc = sys_freq / self.frequency.integer() + 1u32;
|
||||||
cortex_m::asm::delay(delay_cyc);
|
cortex_m::asm::delay(delay_cyc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -173,10 +173,10 @@ impl<D: PhaseLockedLoopDevice> PhaseLockedLoop<Disabled, D> {
|
||||||
}
|
}
|
||||||
|
|
||||||
let fbdiv = vco_freq
|
let fbdiv = vco_freq
|
||||||
.checked_div(ref_freq_hz.integer())
|
.checked_div(&ref_freq_hz.integer())
|
||||||
.ok_or(Error::BadArgument)?;
|
.ok_or(Error::BadArgument)?;
|
||||||
|
|
||||||
let fbdiv: u16 = (*fbdiv.integer())
|
let fbdiv: u16 = (fbdiv.integer())
|
||||||
.try_into()
|
.try_into()
|
||||||
.map_err(|_| Error::BadArgument)?;
|
.map_err(|_| Error::BadArgument)?;
|
||||||
|
|
||||||
|
|
|
@ -85,8 +85,8 @@ impl<D: SpiDevice, const DS: u8> Spi<Disabled, D, DS> {
|
||||||
peri_frequency: F,
|
peri_frequency: F,
|
||||||
baudrate: B,
|
baudrate: B,
|
||||||
) -> Hertz {
|
) -> Hertz {
|
||||||
let freq_in = *peri_frequency.into().integer();
|
let freq_in = peri_frequency.into().integer();
|
||||||
let baudrate = *baudrate.into().integer();
|
let baudrate = baudrate.into().integer();
|
||||||
let mut prescale: u8 = u8::MAX;
|
let mut prescale: u8 = u8::MAX;
|
||||||
let mut postdiv: u8 = 1;
|
let mut postdiv: u8 = 1;
|
||||||
|
|
||||||
|
|
|
@ -371,7 +371,7 @@ fn calculate_baudrate_dividers(
|
||||||
let baudrate_div = frequency
|
let baudrate_div = frequency
|
||||||
.integer()
|
.integer()
|
||||||
.checked_mul(8)
|
.checked_mul(8)
|
||||||
.and_then(|r| r.checked_div(*wanted_baudrate.integer()))
|
.and_then(|r| r.checked_div(wanted_baudrate.integer()))
|
||||||
.ok_or(Error::BadArgument)?;
|
.ok_or(Error::BadArgument)?;
|
||||||
|
|
||||||
Ok(match (baudrate_div >> 7, ((baudrate_div & 0x7F) + 1) / 2) {
|
Ok(match (baudrate_div >> 7, ((baudrate_div & 0x7F) + 1) / 2) {
|
||||||
|
@ -408,7 +408,7 @@ fn configure_baudrate(
|
||||||
device.uartlcr_h.modify(|_, w| w);
|
device.uartlcr_h.modify(|_, w| w);
|
||||||
|
|
||||||
Ok(Baud(
|
Ok(Baud(
|
||||||
(4 * *frequency.integer()) / (64 * baud_div_int + baud_div_frac) as u32,
|
(4 * frequency.integer()) / (64 * baud_div_int + baud_div_frac) as u32,
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -113,12 +113,12 @@ impl CrystalOscillator<Disabled> {
|
||||||
//See Chapter 2, Section 16, §3)
|
//See Chapter 2, Section 16, §3)
|
||||||
//We do the calculation first.
|
//We do the calculation first.
|
||||||
let startup_delay = frequency
|
let startup_delay = frequency
|
||||||
.checked_div(delay_to_hz.integer())
|
.checked_div(&delay_to_hz.integer())
|
||||||
.and_then(|r| r.to_generic::<u32>(DIVIDER).ok())
|
.and_then(|r| r.to_generic::<u32>(DIVIDER).ok())
|
||||||
.ok_or(Error::BadArgument)?;
|
.ok_or(Error::BadArgument)?;
|
||||||
|
|
||||||
//Then we check if it fits into an u16.
|
//Then we check if it fits into an u16.
|
||||||
let startup_delay: u16 = (*startup_delay.integer())
|
let startup_delay: u16 = (startup_delay.integer())
|
||||||
.try_into()
|
.try_into()
|
||||||
.map_err(|_| Error::BadArgument)?;
|
.map_err(|_| Error::BadArgument)?;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue