/* * Copyright 2022, 2024 NXP * * SPDX-License-Identifier: Apache-2.0 */ #include #include #include int pinctrl_configure_pins(const pinctrl_soc_pin_t *pins, uint8_t pin_cnt, uintptr_t reg) { /* configure all pins */ for (uint8_t i = 0U; i < pin_cnt; i++) { uint32_t mux_register = pins[i].pinmux.mux_register; uint32_t mux_mode = pins[i].pinmux.mux_mode; uint32_t input_register = pins[i].pinmux.input_register; uint32_t input_daisy = pins[i].pinmux.input_daisy; uint32_t config_register = pins[i].pinmux.config_register; uint32_t pin_ctrl_flags = pins[i].pin_ctrl_flags; #if defined(CONFIG_SOC_SERIES_IMXRT10XX) || defined(CONFIG_SOC_SERIES_IMXRT11XX) volatile uint32_t *gpr_register = (volatile uint32_t *)((uintptr_t)pins[i].pinmux.gpr_register); if (gpr_register) { /* Set or clear specified GPR bit for this mux */ if (pins[i].pinmux.gpr_val) { *gpr_register |= (pins[i].pinmux.gpr_val << pins[i].pinmux.gpr_shift); } else { *gpr_register &= ~(0x1 << pins[i].pinmux.gpr_shift); } } #endif #ifdef CONFIG_SOC_MIMX9352 sys_write32(IOMUXC1_SW_MUX_CTL_PAD_MUX_MODE(mux_mode) | IOMUXC1_SW_MUX_CTL_PAD_SION(MCUX_IMX_INPUT_ENABLE(pin_ctrl_flags)), (mem_addr_t)mux_register); if (input_register) { sys_write32(IOMUXC1_SELECT_INPUT_DAISY(input_daisy), (mem_addr_t)input_register); } if (config_register) { sys_write32(pin_ctrl_flags & (~(0x1 << MCUX_IMX_INPUT_ENABLE_SHIFT)), (mem_addr_t)config_register); } #elif defined(CONFIG_SOC_MIMX8UD7) if (mux_register == config_register) { sys_write32(IOMUXC_PCR_MUX_MODE(mux_mode) | pin_ctrl_flags, (mem_addr_t)mux_register); } else { sys_write32(IOMUXC_PCR_MUX_MODE(mux_mode), (mem_addr_t)mux_register); if (config_register) { sys_write32(pin_ctrl_flags, (mem_addr_t)config_register); } } if (input_register) { sys_write32(IOMUXC_PSMI_SSS(input_daisy), (mem_addr_t)input_register); } #else sys_write32( IOMUXC_SW_MUX_CTL_PAD_MUX_MODE(mux_mode) | IOMUXC_SW_MUX_CTL_PAD_SION(MCUX_IMX_INPUT_ENABLE(pin_ctrl_flags)), (mem_addr_t)mux_register); if (input_register) { sys_write32(IOMUXC_SELECT_INPUT_DAISY(input_daisy), (mem_addr_t)input_register); } if (config_register) { sys_write32(pin_ctrl_flags & (~(0x1 << MCUX_IMX_INPUT_ENABLE_SHIFT)), config_register); } #endif } return 0; } static int imx_pinctrl_init(void) { #if defined(CONFIG_SOC_SERIES_IMXRT10XX) || defined(CONFIG_SOC_SERIES_IMXRT11XX) CLOCK_EnableClock(kCLOCK_Iomuxc); #ifdef CONFIG_SOC_SERIES_IMXRT10XX CLOCK_EnableClock(kCLOCK_IomuxcSnvs); CLOCK_EnableClock(kCLOCK_IomuxcGpr); #elif defined(CONFIG_SOC_SERIES_IMXRT11XX) CLOCK_EnableClock(kCLOCK_Iomuxc_Lpsr); #endif /* CONFIG_SOC_SERIES_IMXRT10XX */ #elif defined(CONFIG_SOC_MIMX8MQ6) CLOCK_EnableClock(kCLOCK_Iomux); #endif /* CONFIG_SOC_SERIES_IMXRT10XX || CONFIG_SOC_SERIES_IMXRT11XX */ #if defined(CONFIG_SOC_SERIES_IMXRT118X) CLOCK_EnableClock(kCLOCK_Iomuxc1); CLOCK_EnableClock(kCLOCK_Iomuxc2); #endif /* CONFIG_SOC_SERIES_IMXRT118X */ return 0; } SYS_INIT(imx_pinctrl_init, PRE_KERNEL_1, 0);