aboutsummaryrefslogtreecommitdiff
path: root/chips/imxrt1060/src/lib.rs
blob: 0ac779bd63bf156e403e05bbcf83e0479d1d030e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#![no_std]

pub use ral_registers::{Instance, modify_reg, read_reg, write_reg};

mod rt;
pub use rt::*;

pub mod iomuxc;

/// Clock control module.
pub mod ccm {
    pub use imxrt_drivers_ccm_10xx::ahb::pll1::*;

    pub use imxrt_drivers_ccm_10xx::ccm::{
        LowPowerMode, ahb_clk, clock_gate, flexspi1_clk_axi_semc as flexspi1_clk, ipg_clk,
        low_power_mode, lpi2c_clk, lpspi_clk, perclk_clk, set_low_power_mode, uart_clk,
    };
    pub use imxrt_drivers_ccm_10xx::ccm_analog::{pll2, pll3};

    pub use imxrt_drivers_ccm_10xx::ccm::{
        arm_divider, periph_clk2, pre_periph_clk_pll1 as pre_periph_clk,
    };

    pub use imxrt_drivers_ccm_10xx::ccm_analog::pll7;
    pub use imxrt_drivers_ccm_10xx::ccm_analog::{pll1, pll6};
}

pub use imxrt_drivers_flexspi as flexspi;
pub use imxrt_drivers_lpspi as lpspi;
pub use imxrt_drivers_pit as pit;

/// Peripheral instances.
pub mod instances {
    ral_registers::instances! {
        // Safety: The reference manual confirms there are register
        // blocks at this address matching this shape.
        unsafe {
            /// Access CCM registers.
            pub ccm<imxrt_drivers_ccm_10xx::ral::ccm::RegisterBlock> = 0x400F_C000;
            /// Access CCM\_ANALOG registers.
            pub ccm_analog<imxrt_drivers_ccm_10xx::ral::ccm_analog::RegisterBlock> = 0x400D_8000;

            pub flexspi1<crate::flexspi::RegisterBlock> = 0x402A_8000;
            pub flexspi2<crate::flexspi::RegisterBlock> = 0x402A_4000;

            pub pit<crate::pit::RegisterBlock> = 0x4008_4000;

            pub lpspi1<crate::lpspi::RegisterBlock> = 0x4039_4000;
            pub lpspi2<crate::lpspi::RegisterBlock> = 0x4039_8000;
            pub lpspi3<crate::lpspi::RegisterBlock> = 0x4039_C000;
            pub lpspi4<crate::lpspi::RegisterBlock> = 0x403A_0000;
        }
    }
}