stm32: add disable_ucpdx_dead_battery
This commit is contained in:
parent
1b4d3e1e29
commit
096d147dce
@ -189,6 +189,18 @@ pub struct Config {
|
|||||||
/// Defaults to P0 (highest).
|
/// Defaults to P0 (highest).
|
||||||
#[cfg(gpdma)]
|
#[cfg(gpdma)]
|
||||||
pub gpdma_interrupt_priority: Priority,
|
pub gpdma_interrupt_priority: Priority,
|
||||||
|
|
||||||
|
/// Disables UCPD1 dead battery functionality.
|
||||||
|
///
|
||||||
|
/// Defaults to true (disabled).
|
||||||
|
#[cfg(ucpd)]
|
||||||
|
pub disable_ucpd1_dead_battery: bool,
|
||||||
|
|
||||||
|
/// Disables UCPD2 dead battery functionality.
|
||||||
|
///
|
||||||
|
/// Defaults to true (disabled).
|
||||||
|
#[cfg(all(ucpd, stm32g0x1))]
|
||||||
|
pub disable_ucpd2_dead_battery: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Default for Config {
|
impl Default for Config {
|
||||||
@ -203,6 +215,10 @@ impl Default for Config {
|
|||||||
dma_interrupt_priority: Priority::P0,
|
dma_interrupt_priority: Priority::P0,
|
||||||
#[cfg(gpdma)]
|
#[cfg(gpdma)]
|
||||||
gpdma_interrupt_priority: Priority::P0,
|
gpdma_interrupt_priority: Priority::P0,
|
||||||
|
#[cfg(ucpd)]
|
||||||
|
disable_ucpd1_dead_battery: true,
|
||||||
|
#[cfg(all(ucpd, stm32g0x1))]
|
||||||
|
uisable_ucpd2_dead_battery: true,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -254,6 +270,36 @@ pub fn init(config: Config) -> Peripherals {
|
|||||||
#[cfg(not(any(stm32f2, stm32f4, stm32f7, stm32l0, stm32h5, stm32h7)))]
|
#[cfg(not(any(stm32f2, stm32f4, stm32f7, stm32l0, stm32h5, stm32h7)))]
|
||||||
peripherals::FLASH::enable_and_reset_with_cs(cs);
|
peripherals::FLASH::enable_and_reset_with_cs(cs);
|
||||||
|
|
||||||
|
// dead battery IOs are still present on g0x0 despite not having UCPD
|
||||||
|
#[cfg(any(stm32g070, stm32g0b0))]
|
||||||
|
let (disable_ucpd1_dead_battery, disable_ucpd2_dead_battery) = (true, true);
|
||||||
|
#[cfg(ucpd)]
|
||||||
|
let disable_ucpd1_dead_battery = config.disable_ucpd1_dead_battery;
|
||||||
|
#[cfg(all(ucpd, stm32g0x1))]
|
||||||
|
let disable_ucpd2_dead_battery = config.disable_ucpd2_dead_battery;
|
||||||
|
|
||||||
|
#[cfg(any(stm32g070, stm32g0b0, all(ucpd, stm32g0x1)))]
|
||||||
|
{
|
||||||
|
crate::pac::SYSCFG.cfgr1().modify(|w| {
|
||||||
|
w.set_ucpd1_strobe(disable_ucpd1_dead_battery);
|
||||||
|
w.set_ucpd2_strobe(disable_ucpd2_dead_battery);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(all(ucpd, any(stm32g4, stm32l5)))]
|
||||||
|
{
|
||||||
|
crate::pac::PWR
|
||||||
|
.cr3()
|
||||||
|
.modify(|w| w.set_ucpd1_dbdis(disable_ucpd1_dead_battery))
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(all(ucpd, any(stm32h5, stm32u5)))]
|
||||||
|
{
|
||||||
|
crate::pac::PWR
|
||||||
|
.ucpdr()
|
||||||
|
.modify(|w| w.set_ucpd1_dbdis(disable_ucpd1_dead_battery))
|
||||||
|
}
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
#[cfg(feature = "_split-pins-enabled")]
|
#[cfg(feature = "_split-pins-enabled")]
|
||||||
crate::pac::SYSCFG.pmcr().modify(|pmcr| {
|
crate::pac::SYSCFG.pmcr().modify(|pmcr| {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user