#[non_exhaustive]pub struct ClocksConfig {
pub firc: Option<FircConfig>,
pub sirc: SircConfig,
pub fro16k: Option<Fro16KConfig>,
}Expand description
┌─────────────────────────────────────────────────────────┐
│ │
│ ┌───────────┐ clk_out ┌─────────┐ │
XTAL ──────┼──▷│ System │───────────▷│ │ clk_in │
│ │ OSC │ clkout_byp │ MUX │──────────────────┼──────▷
EXTAL ──────┼──▷│ │───────────▷│ │ │
│ └───────────┘ └─────────┘ │
│ │
│ ┌───────────┐ fro_hf_root ┌────┐ fro_hf │
│ │ FRO180 ├───────┬─────▷│ CG │─────────────────────┼──────▷
│ │ │ │ ├────┤ clk_45m │
│ │ │ └─────▷│ CG │─────────────────────┼──────▷
│ └───────────┘ └────┘ │
│ ┌───────────┐ fro_12m_root ┌────┐ fro_12m │
│ │ FRO12M │────────┬─────▷│ CG │────────────────────┼──────▷
│ │ │ │ ├────┤ clk_1m │
│ │ │ └─────▷│1/12│────────────────────┼──────▷
│ └───────────┘ └────┘ │
│ │
│ ┌──────────┐ │
│ │000 │ │
│ clk_in │ │ │
│ ───────────────▷│001 │ │
│ fro_12m │ │ │
│ ───────────────▷│010 │ │
│ fro_hf_root │ │ │
│ ───────────────▷│011 │ main_clk │
│ │ │───────────────────────────┼──────▷
clk_16k ──────┼─────────────────▷│100 │ │
│ none │ │ │
│ ───────────────▷│101 │ │
│ pll1_clk │ │ │
│ ───────────────▷│110 │ │
│ none │ │ │
│ ───────────────▷│111 │ │
│ └──────────┘ │
│ ▲ │
│ │ │
│ SCG SCS │
│ SCG-Lite │
└─────────────────────────────────────────────────────────┘
clk_in ┌─────┐
───────────────▷│00 │
clk_45m │ │
───────────────▷│01 │ ┌───────────┐ pll1_clk
none │ │─────▷│ SPLL │───────────────▷
───────────────▷│10 │ └───────────┘
fro_12m │ │
───────────────▷│11 │
└─────┘Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional
Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.firc: Option<FircConfig>FIRC, FRO180, 45/60/90/180M clock source
sirc: SircConfigSIRC, FRO12M, clk_12m clock source
fro16k: Option<Fro16KConfig>FRO16K clock source
Trait Implementations§
Auto Trait Implementations§
impl Freeze for ClocksConfig
impl RefUnwindSafe for ClocksConfig
impl Send for ClocksConfig
impl Sync for ClocksConfig
impl Unpin for ClocksConfig
impl UnwindSafe for ClocksConfig
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more