embassy/embassy-stm32/src/rcc/mod.rs

98 lines
2.4 KiB
Rust
Raw Normal View History

#![macro_use]
2021-06-14 10:48:14 +02:00
use crate::time::Hertz;
2021-05-27 09:50:11 +02:00
use core::mem::MaybeUninit;
2021-06-14 10:48:14 +02:00
2022-02-14 02:12:06 +01:00
#[cfg_attr(rcc_f0, path = "f0.rs")]
#[cfg_attr(rcc_f1, path = "f1.rs")]
#[cfg_attr(rcc_f2, path = "f2.rs")]
#[cfg_attr(rcc_f3, path = "f3.rs")]
#[cfg_attr(any(rcc_f4, rcc_f410), path = "f4.rs")]
#[cfg_attr(rcc_f7, path = "f7.rs")]
#[cfg_attr(rcc_g0, path = "g0.rs")]
#[cfg_attr(rcc_g4, path = "g4.rs")]
#[cfg_attr(any(rcc_h7, rcc_h7ab), path = "h7.rs")]
#[cfg_attr(rcc_l0, path = "l0.rs")]
#[cfg_attr(rcc_l1, path = "l1.rs")]
#[cfg_attr(rcc_l4, path = "l4.rs")]
2022-04-08 02:57:48 +02:00
#[cfg_attr(rcc_l5, path = "l5.rs")]
#[cfg_attr(rcc_u5, path = "u5.rs")]
#[cfg_attr(rcc_wb, path = "wb.rs")]
2022-04-08 03:40:51 +02:00
#[cfg_attr(any(rcc_wl5, rcc_wle), path = "wl.rs")]
mod _version;
pub use _version::*;
2021-06-14 10:48:14 +02:00
#[derive(Clone, Copy)]
pub struct Clocks {
pub sys: Hertz,
2021-07-30 22:48:13 +02:00
2022-02-14 02:12:06 +01:00
// APB
2021-06-14 10:48:14 +02:00
pub apb1: Hertz,
2021-07-30 22:48:13 +02:00
pub apb1_tim: Hertz,
#[cfg(not(rcc_g0))]
2021-06-14 10:48:14 +02:00
pub apb2: Hertz,
2021-07-30 22:48:13 +02:00
#[cfg(not(rcc_g0))]
pub apb2_tim: Hertz,
2022-04-08 03:40:51 +02:00
#[cfg(any(rcc_wl5, rcc_wle, rcc_u5))]
pub apb3: Hertz,
2022-02-24 05:59:42 +01:00
#[cfg(any(rcc_h7, rcc_h7ab))]
2022-02-14 02:12:06 +01:00
pub apb4: Hertz,
2021-06-23 01:07:48 +02:00
2022-02-14 02:12:06 +01:00
// AHB
2021-06-14 10:48:14 +02:00
pub ahb1: Hertz,
2022-01-24 00:50:35 +01:00
#[cfg(any(
2022-04-08 02:57:48 +02:00
rcc_l4, rcc_l5, rcc_f2, rcc_f4, rcc_f410, rcc_f7, rcc_h7, rcc_h7ab, rcc_g4, rcc_u5, rcc_wb,
2022-04-08 03:40:51 +02:00
rcc_wl5, rcc_wle
2022-01-24 00:50:35 +01:00
))]
2021-06-14 10:48:14 +02:00
pub ahb2: Hertz,
2022-02-24 05:59:42 +01:00
#[cfg(any(
2022-04-08 03:40:51 +02:00
rcc_l4, rcc_l5, rcc_f2, rcc_f4, rcc_f410, rcc_f7, rcc_h7, rcc_h7ab, rcc_u5, rcc_wb,
rcc_wl5, rcc_wle
2022-02-24 05:59:42 +01:00
))]
2021-06-14 11:41:02 +02:00
pub ahb3: Hertz,
2022-02-24 05:59:42 +01:00
#[cfg(any(rcc_h7, rcc_h7ab))]
2021-07-09 15:33:17 +02:00
pub ahb4: Hertz,
2022-01-24 00:50:35 +01:00
#[cfg(any(rcc_f4, rcc_f410, rcc_f7))]
2021-07-28 04:09:48 +02:00
pub pll48: Option<Hertz>,
#[cfg(rcc_f1)]
pub adc: Hertz,
2022-03-19 11:05:00 +01:00
#[cfg(any(rcc_h7, rcc_h7ab))]
pub adc: Option<Hertz>,
2021-06-14 10:48:14 +02:00
}
2021-05-27 09:50:11 +02:00
/// Frozen clock frequencies
///
/// The existence of this value indicates that the clock configuration can no longer be changed
static mut CLOCK_FREQS: MaybeUninit<Clocks> = MaybeUninit::uninit();
/// Sets the clock frequencies
///
/// Safety: Sets a mutable global.
pub(crate) unsafe fn set_freqs(freqs: Clocks) {
2021-05-27 09:50:11 +02:00
CLOCK_FREQS.as_mut_ptr().write(freqs);
}
/// Safety: Reads a mutable global.
pub(crate) unsafe fn get_freqs() -> &'static Clocks {
2021-05-27 09:50:11 +02:00
&*CLOCK_FREQS.as_ptr()
}
#[cfg(feature = "unstable-pac")]
pub mod low_level {
pub use super::sealed::*;
}
pub(crate) mod sealed {
pub trait RccPeripheral {
fn frequency() -> crate::time::Hertz;
fn reset();
fn enable();
fn disable();
}
}
pub trait RccPeripheral: sealed::RccPeripheral + 'static {}