blob: 232976ca9916fa80d531adb57767d9fa990e6e9a [file] [log] [blame]
/*
* Copyright (c) 2023 Antmicro <www.antmicro.com>
* Copyright (c) 2025 Linumiz GmbH
* SPDX-License-Identifier: Apache-2.0
*/
#include <zephyr/drivers/pinctrl.h>
/* ambiq-sdk includes */
#include <soc.h>
#if defined(CONFIG_SOC_SERIES_APOLLO2X)
static void pinctrl_configure_pin(const pinctrl_soc_pin_t *cfg)
{
uint32_t config = 0;
if (cfg->alt_func) {
config |= AM_HAL_GPIO_FUNC(cfg->alt_func);
}
if (cfg->input_enable) {
config |= AM_HAL_GPIO_INPEN;
}
switch (cfg->drive_strength) {
case 2:
config |= AM_HAL_GPIO_DRIVE_2MA;
break;
case 4:
config |= AM_HAL_GPIO_DRIVE_4MA;
break;
case 8:
config |= AM_HAL_GPIO_DRIVE_8MA;
break;
case 12:
config |= AM_HAL_GPIO_DRIVE_12MA;
break;
}
if (cfg->bias_pull_up) {
switch (cfg->ambiq_pull_up_ohms) {
case 1500:
config |= AM_HAL_GPIO_PULL1_5K;
break;
case 6000:
config |= AM_HAL_GPIO_PULL6K;
break;
case 12000:
config |= AM_HAL_GPIO_PULL12K;
break;
case 24000:
config |= AM_HAL_GPIO_PULL24K;
break;
}
}
if (cfg->open_drain) {
config |= AM_HAL_GPIO_OUT_OPENDRAIN;
}
am_hal_gpio_pin_config(cfg->pin_num, config);
}
#else
static void pinctrl_configure_pin(const pinctrl_soc_pin_t *pin)
{
am_hal_gpio_pincfg_t pin_config = {0};
#if defined(CONFIG_SOC_SERIES_APOLLO3X)
pin_config.uFuncSel = pin->alt_func;
pin_config.eGPInput =
pin->input_enable ? AM_HAL_GPIO_PIN_INPUT_ENABLE : AM_HAL_GPIO_PIN_INPUT_NONE;
pin_config.eGPOutcfg = pin->push_pull ? AM_HAL_GPIO_PIN_OUTCFG_PUSHPULL
: pin->open_drain ? AM_HAL_GPIO_PIN_OUTCFG_OPENDRAIN
: pin->tristate ? AM_HAL_GPIO_PIN_OUTCFG_TRISTATE
: AM_HAL_GPIO_PIN_OUTCFG_DISABLE;
pin_config.eDriveStrength = pin->drive_strength;
pin_config.uNCE = pin->nce;
pin_config.eCEpol = pin->nce_pol;
#if defined(CONFIG_SOC_APOLLO3P_BLUE)
pin_config.bIomMSPIn = pin->iom_mspi;
#endif
pin_config.uIOMnum = pin->iom_num;
if (pin->bias_pull_up) {
pin_config.ePullup = pin->ambiq_pull_up_ohms + AM_HAL_GPIO_PIN_PULLUP_1_5K;
} else if (pin->bias_pull_down) {
pin_config.ePullup = AM_HAL_GPIO_PIN_PULLDOWN;
}
#else
pin_config.GP.cfg_b.uFuncSel = pin->alt_func;
pin_config.GP.cfg_b.eGPInput =
pin->input_enable ? AM_HAL_GPIO_PIN_INPUT_ENABLE : AM_HAL_GPIO_PIN_INPUT_NONE;
pin_config.GP.cfg_b.eGPOutCfg = pin->push_pull ? AM_HAL_GPIO_PIN_OUTCFG_PUSHPULL
: pin->open_drain ? AM_HAL_GPIO_PIN_OUTCFG_OPENDRAIN
: pin->tristate ? AM_HAL_GPIO_PIN_OUTCFG_TRISTATE
: AM_HAL_GPIO_PIN_OUTCFG_DISABLE;
pin_config.GP.cfg_b.eDriveStrength = pin->drive_strength;
#if defined(CONFIG_SOC_SERIES_APOLLO4X)
pin_config.GP.cfg_b.uSlewRate = pin->slew_rate;
switch (pin->sdif_cdwp) {
case 1:
am_hal_gpio_cd_pin_config(pin->pin_num);
break;
case 2:
am_hal_gpio_wp_pin_config(pin->pin_num);
break;
default:
/* not a sdif pin */
break;
}
#else
switch (pin->sdif_cdwp) {
case 1:
am_hal_gpio_cd0_pin_config(pin->pin_num);
break;
case 2:
am_hal_gpio_wp0_pin_config(pin->pin_num);
break;
case 3:
am_hal_gpio_cd1_pin_config(pin->pin_num);
break;
case 4:
am_hal_gpio_wp1_pin_config(pin->pin_num);
break;
default:
/* not a sdif pin */
break;
}
#endif
pin_config.GP.cfg_b.uNCE = pin->nce;
pin_config.GP.cfg_b.eCEpol = pin->nce_pol;
if (pin->bias_pull_up) {
pin_config.GP.cfg_b.ePullup = pin->ambiq_pull_up_ohms + AM_HAL_GPIO_PIN_PULLUP_1_5K;
} else if (pin->bias_pull_down) {
pin_config.GP.cfg_b.ePullup = AM_HAL_GPIO_PIN_PULLDOWN_50K;
}
#endif
am_hal_gpio_pinconfig(pin->pin_num, pin_config);
}
#endif
int pinctrl_configure_pins(const pinctrl_soc_pin_t *pins, uint8_t pin_cnt, uintptr_t reg)
{
ARG_UNUSED(reg);
for (uint8_t i = 0U; i < pin_cnt; i++) {
pinctrl_configure_pin(pins++);
}
return 0;
}