Skip to content

Commit

Permalink
add imxrt1050 support based on the imxrt1060
Browse files Browse the repository at this point in the history
- uses an imxrt-iomuxc feature for imxrt1050
  • Loading branch information
hatimbt committed Jan 31, 2024
1 parent 15f1795 commit e47175f
Show file tree
Hide file tree
Showing 3 changed files with 128 additions and 0 deletions.
1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,7 @@ features = ["imxrt-ral/imxrt1062", "imxrt1060"]
default = ["imxrt-usbd"]
imxrt1010 = ["imxrt-iomuxc/imxrt1010"]
imxrt1020 = ["imxrt-iomuxc/imxrt1020"]
imxrt1050 = ["imxrt-iomuxc/imxrt1050"]
imxrt1060 = ["imxrt-iomuxc/imxrt1060"]
imxrt1064 = ["imxrt-iomuxc/imxrt1060"]
imxrt1170 = ["imxrt-iomuxc/imxrt1170"]
Expand Down
3 changes: 3 additions & 0 deletions src/chip/imxrt10xx.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,9 @@ cfg_if::cfg_if! {
} else if #[cfg(chip = "imxrt1020")] {
#[path = "imxrt10xx/imxrt1020.rs"]
pub(crate) mod config;
} else if #[cfg(any(chip = "imxrt1050"))] {
#[path = "imxrt10xx/imxrt1050.rs"]
pub(crate) mod config;
} else if #[cfg(any(chip = "imxrt1060", chip = "imxrt1064"))] {
#[path = "imxrt10xx/imxrt1060.rs"]
pub(crate) mod config;
Expand Down
124 changes: 124 additions & 0 deletions src/chip/imxrt10xx/imxrt1050.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
//! i.MX RT 1050 chip family features.
//!
//! Use this module to customize features for the
//! 1050 chips.
pub use imxrt_iomuxc::imxrt1050 as pads;

#[path = "ccm"]
pub(crate) mod ccm {
pub mod arm_divider;

#[path = "pre_periph_clk_pll1.rs"]
pub mod pre_periph_clk;

mod periph_clk2_podf;
mod periph_clk2_sel;

/// Peripheral clock 2.
pub mod periph_clk2 {
pub use super::periph_clk2_podf::*;
pub use super::periph_clk2_sel::*;
}

pub(crate) mod analog {
pub mod pll1;
}

/// Re-exported by the common clock_gate module.
pub(crate) mod clock_gate {
use crate::chip::ccm::clock_gate;

/// All clock gates downstream of the PERCLK root clock.
pub const PERCLK_CLOCK_GATES: &[clock_gate::Locator] = &[
clock_gate::pit(),
clock_gate::gpt_bus::<1>(),
clock_gate::gpt_bus::<2>(),
clock_gate::gpt_serial::<1>(),
clock_gate::gpt_serial::<2>(),
];

/// All clock gates downstream of the UART root clock.
pub const UART_CLOCK_GATES: &[clock_gate::Locator] = &[
clock_gate::lpuart::<1>(),
clock_gate::lpuart::<2>(),
clock_gate::lpuart::<3>(),
clock_gate::lpuart::<4>(),
clock_gate::lpuart::<5>(),
clock_gate::lpuart::<6>(),
clock_gate::lpuart::<7>(),
clock_gate::lpuart::<8>(),
];

/// All clock gates downstream of the LPSPI root clock.
pub const LPSPI_CLOCK_GATES: &[clock_gate::Locator] = &[
clock_gate::lpspi::<1>(),
clock_gate::lpspi::<2>(),
clock_gate::lpspi::<3>(),
clock_gate::lpspi::<4>(),
];

/// All clock gates downstream of the LPI2C root clock.
pub const LPI2C_CLOCK_GATES: &[clock_gate::Locator] = &[
clock_gate::lpi2c::<1>(),
clock_gate::lpi2c::<2>(),
clock_gate::lpi2c::<3>(),
clock_gate::lpi2c::<4>(),
];

/// All clock gates downstream of the IPG root clock.
pub const IPG_CLOCK_GATES: &[clock_gate::Locator] = &[
clock_gate::adc::<1>(),
clock_gate::adc::<2>(),
clock_gate::dma(),
clock_gate::flexpwm::<1>(),
clock_gate::flexpwm::<2>(),
clock_gate::flexpwm::<3>(),
clock_gate::flexpwm::<4>(),
// GPIOs assume that we're not "fast," since the fast
// GPIOs run directly off the ARM / AHB clock. This
// is safe for now, since we don't currently support fast
// GPIOs.
clock_gate::gpio::<1>(),
clock_gate::gpio::<2>(),
clock_gate::gpio::<3>(),
clock_gate::gpio::<4>(),
clock_gate::gpio::<5>(),
clock_gate::trng(),
clock_gate::snvs_lp(),
clock_gate::snvs_hp(),
clock_gate::usb(),
];
}

// TODO
pub(crate) mod clko {
/// CLKO1 output clock selections.
// #[repr(u32)]
#[derive(Debug, Clone, Copy, PartialEq, Eq)]

pub enum Clko1Selection {}

/// CLKO2 output clock selections.
// #[repr(u32)]
#[derive(Debug, Clone, Copy, PartialEq, Eq)]

pub enum Clko2Selection {}
}

ccm_flexio!(
flexio1_clk, "FLEXIO1",
divider: (CDCDR, FLEXIO1_CLK_PODF),
predivider: (CDCDR, FLEXIO1_CLK_PRED),
selection: (CDCDR, FLEXIO1_CLK_SEL),
);

ccm_flexio!(
flexio2_clk, "FLEXIO2",
divider: (CS1CDR, FLEXIO2_CLK_PODF),
predivider: (CS1CDR, FLEXIO2_CLK_PRED),
selection: (CSCMR2, FLEXIO2_CLK_SEL),
);
}

pub(crate) const DMA_CHANNEL_COUNT: usize = 32;

0 comments on commit e47175f

Please sign in to comment.