Move clocks to rcc mod
This commit is contained in:
parent
6eaf224fec
commit
a41a812345
3 changed files with 51 additions and 97 deletions
|
@ -10,6 +10,7 @@ use embassy::time::{Clock as EmbassyClock, TICKS_PER_SECOND};
|
||||||
|
|
||||||
use crate::interrupt::{CriticalSection, Interrupt, Mutex};
|
use crate::interrupt::{CriticalSection, Interrupt, Mutex};
|
||||||
use crate::pac::timer::TimGp16;
|
use crate::pac::timer::TimGp16;
|
||||||
|
use crate::rcc::get_freqs;
|
||||||
use crate::time::Hertz;
|
use crate::time::Hertz;
|
||||||
|
|
||||||
// Clock timekeeping works with something we call "periods", which are time intervals
|
// Clock timekeeping works with something we call "periods", which are time intervals
|
||||||
|
@ -33,20 +34,6 @@ fn calc_now(period: u32, counter: u16) -> u64 {
|
||||||
((period as u64) << 15) + ((counter as u32 ^ ((period & 1) << 15)) as u64)
|
((period as u64) << 15) + ((counter as u32 ^ ((period & 1) << 15)) as u64)
|
||||||
}
|
}
|
||||||
|
|
||||||
static mut CLOCK_FREQS: Option<ClockFreqs> = None;
|
|
||||||
|
|
||||||
#[derive(Copy, Clone)]
|
|
||||||
pub struct ClockFreqs {
|
|
||||||
pub tim2: Hertz,
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Sets the clock frequencies
|
|
||||||
///
|
|
||||||
/// Safety: Sets a mutable global.
|
|
||||||
pub unsafe fn set_freqs(freqs: ClockFreqs) {
|
|
||||||
CLOCK_FREQS.replace(freqs);
|
|
||||||
}
|
|
||||||
|
|
||||||
struct AlarmState {
|
struct AlarmState {
|
||||||
timestamp: Cell<u64>,
|
timestamp: Cell<u64>,
|
||||||
#[allow(clippy::type_complexity)]
|
#[allow(clippy::type_complexity)]
|
||||||
|
@ -91,7 +78,8 @@ impl<T: Instance> Clock<T> {
|
||||||
|
|
||||||
// TODO: Temporary until clock code generation is in place
|
// TODO: Temporary until clock code generation is in place
|
||||||
pub fn start_tim2(&'static self) {
|
pub fn start_tim2(&'static self) {
|
||||||
#[cfg(feature = "_stm32l0")]
|
cfg_if::cfg_if! {
|
||||||
|
if #[cfg(feature = "_stm32l0")] {
|
||||||
unsafe {
|
unsafe {
|
||||||
let rcc = crate::pac::RCC;
|
let rcc = crate::pac::RCC;
|
||||||
rcc.apb1enr()
|
rcc.apb1enr()
|
||||||
|
@ -100,9 +88,11 @@ impl<T: Instance> Clock<T> {
|
||||||
rcc.apb1rstr().modify(|w| w.set_tim2rst(false));
|
rcc.apb1rstr().modify(|w| w.set_tim2rst(false));
|
||||||
}
|
}
|
||||||
|
|
||||||
let timer_freq = unsafe { CLOCK_FREQS.unwrap().tim2 };
|
let timer_freq = unsafe { crate::rcc::get_freqs().apb1_clk };
|
||||||
self.start(timer_freq);
|
self.start(timer_freq);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn start(&'static self, timer_freq: Hertz) {
|
pub fn start(&'static self, timer_freq: Hertz) {
|
||||||
let inner = T::inner();
|
let inner = T::inner();
|
||||||
|
|
|
@ -1,13 +1,11 @@
|
||||||
use crate::clock::Clock;
|
|
||||||
use crate::clock::{set_freqs, ClockFreqs};
|
|
||||||
use crate::interrupt;
|
|
||||||
use crate::pac;
|
use crate::pac;
|
||||||
use crate::pac::peripherals::{self, RCC, TIM2};
|
use crate::pac::peripherals::{self, RCC};
|
||||||
|
use crate::rcc::{set_freqs, Clocks};
|
||||||
use crate::time::Hertz;
|
use crate::time::Hertz;
|
||||||
use crate::time::U32Ext;
|
use crate::time::U32Ext;
|
||||||
use embassy::util::Unborrow;
|
use embassy::util::Unborrow;
|
||||||
use pac::rcc::vals;
|
use pac::rcc::vals;
|
||||||
use vals::{Hpre, Lptimen, Msirange, Plldiv, Pllmul, Pllon, Pllsrc, Ppre, Sw};
|
use vals::{Hpre, Msirange, Plldiv, Pllmul, Pllon, Pllsrc, Ppre, Sw};
|
||||||
|
|
||||||
/// Most of clock setup is copied from stm32l0xx-hal, and adopted to the generated PAC,
|
/// Most of clock setup is copied from stm32l0xx-hal, and adopted to the generated PAC,
|
||||||
/// and with the addition of the init function to configure a system clock.
|
/// and with the addition of the init function to configure a system clock.
|
||||||
|
@ -492,7 +490,6 @@ impl RccExt for RCC {
|
||||||
};
|
};
|
||||||
|
|
||||||
Clocks {
|
Clocks {
|
||||||
source: cfgr.mux,
|
|
||||||
sys_clk: sys_clk.hz(),
|
sys_clk: sys_clk.hz(),
|
||||||
ahb_clk: ahb_freq.hz(),
|
ahb_clk: ahb_freq.hz(),
|
||||||
apb1_clk: apb1_freq.hz(),
|
apb1_clk: apb1_freq.hz(),
|
||||||
|
@ -505,69 +502,6 @@ impl RccExt for RCC {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Frozen clock frequencies
|
|
||||||
///
|
|
||||||
/// The existence of this value indicates that the clock configuration can no longer be changed
|
|
||||||
#[derive(Clone, Copy)]
|
|
||||||
pub struct Clocks {
|
|
||||||
source: ClockSrc,
|
|
||||||
sys_clk: Hertz,
|
|
||||||
ahb_clk: Hertz,
|
|
||||||
apb1_clk: Hertz,
|
|
||||||
apb1_tim_clk: Hertz,
|
|
||||||
apb2_clk: Hertz,
|
|
||||||
apb2_tim_clk: Hertz,
|
|
||||||
apb1_pre: u8,
|
|
||||||
apb2_pre: u8,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Clocks {
|
|
||||||
/// Returns the clock source
|
|
||||||
pub fn source(&self) -> &ClockSrc {
|
|
||||||
&self.source
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns the system (core) frequency
|
|
||||||
pub fn sys_clk(&self) -> Hertz {
|
|
||||||
self.sys_clk
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns the frequency of the AHB
|
|
||||||
pub fn ahb_clk(&self) -> Hertz {
|
|
||||||
self.ahb_clk
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns the frequency of the APB1
|
|
||||||
pub fn apb1_clk(&self) -> Hertz {
|
|
||||||
self.apb1_clk
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns the frequency of the APB1 timers
|
|
||||||
pub fn apb1_tim_clk(&self) -> Hertz {
|
|
||||||
self.apb1_tim_clk
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns the prescaler of the APB1
|
|
||||||
pub fn apb1_pre(&self) -> u8 {
|
|
||||||
self.apb1_pre
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns the frequency of the APB2
|
|
||||||
pub fn apb2_clk(&self) -> Hertz {
|
|
||||||
self.apb2_clk
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns the frequency of the APB2 timers
|
|
||||||
pub fn apb2_tim_clk(&self) -> Hertz {
|
|
||||||
self.apb2_tim_clk
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns the prescaler of the APB2
|
|
||||||
pub fn apb2_pre(&self) -> u8 {
|
|
||||||
self.apb2_pre
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Token that exists only, if the HSI48 clock has been enabled
|
/// Token that exists only, if the HSI48 clock has been enabled
|
||||||
///
|
///
|
||||||
/// You can get an instance of this struct by calling [`Rcc::enable_hsi48`].
|
/// You can get an instance of this struct by calling [`Rcc::enable_hsi48`].
|
||||||
|
@ -598,9 +532,7 @@ pub unsafe fn init(config: Config) {
|
||||||
w.set_iophen(enabled);
|
w.set_iophen(enabled);
|
||||||
});
|
});
|
||||||
|
|
||||||
let mut r = <peripherals::RCC as embassy::util::Steal>::steal();
|
let r = <peripherals::RCC as embassy::util::Steal>::steal();
|
||||||
let clocks = r.freeze(config);
|
let clocks = r.freeze(config);
|
||||||
set_freqs(ClockFreqs {
|
set_freqs(clocks);
|
||||||
tim2: clocks.apb1_clk(),
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,35 @@
|
||||||
|
use crate::time::Hertz;
|
||||||
|
use core::mem::MaybeUninit;
|
||||||
|
|
||||||
|
/// Frozen clock frequencies
|
||||||
|
///
|
||||||
|
/// The existence of this value indicates that the clock configuration can no longer be changed
|
||||||
|
#[derive(Clone, Copy)]
|
||||||
|
pub struct Clocks {
|
||||||
|
pub sys_clk: Hertz,
|
||||||
|
pub ahb_clk: Hertz,
|
||||||
|
pub apb1_clk: Hertz,
|
||||||
|
pub apb1_tim_clk: Hertz,
|
||||||
|
pub apb2_clk: Hertz,
|
||||||
|
pub apb2_tim_clk: Hertz,
|
||||||
|
pub apb1_pre: u8,
|
||||||
|
pub apb2_pre: u8,
|
||||||
|
}
|
||||||
|
|
||||||
|
static mut CLOCK_FREQS: MaybeUninit<Clocks> = MaybeUninit::uninit();
|
||||||
|
|
||||||
|
/// Sets the clock frequencies
|
||||||
|
///
|
||||||
|
/// Safety: Sets a mutable global.
|
||||||
|
pub unsafe fn set_freqs(freqs: Clocks) {
|
||||||
|
CLOCK_FREQS.as_mut_ptr().write(freqs);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Safety: Reads a mutable global.
|
||||||
|
pub unsafe fn get_freqs() -> &'static Clocks {
|
||||||
|
&*CLOCK_FREQS.as_ptr()
|
||||||
|
}
|
||||||
|
|
||||||
cfg_if::cfg_if! {
|
cfg_if::cfg_if! {
|
||||||
if #[cfg(feature = "_stm32h7")] {
|
if #[cfg(feature = "_stm32h7")] {
|
||||||
mod h7;
|
mod h7;
|
||||||
|
|
Loading…
Reference in a new issue