soc/amd/common: Refactor single GPIO programming
Make it clearer all the GPIO bank register programming parameters originate from the same soc_amd_gpio entry. Change-Id: I7aa6bd6996fd14dde4b1abcccbd2ae6ef933c87b Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/42691 Reviewed-by: Felix Held <felix-coreboot@felixheld.de> Reviewed-by: Angel Pons <th3fanbus@gmail.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
ff730feacc
commit
0589e3ce7f
1 changed files with 13 additions and 20 deletions
|
@ -181,31 +181,24 @@ uint16_t gpio_acpi_pin(gpio_t gpio)
|
||||||
|
|
||||||
__weak void soc_gpio_hook(uint8_t gpio, uint8_t mux) {}
|
__weak void soc_gpio_hook(uint8_t gpio, uint8_t mux) {}
|
||||||
|
|
||||||
static void set_single_gpio(const struct soc_amd_gpio *gpio_list_ptr,
|
static void set_single_gpio(const struct soc_amd_gpio *g,
|
||||||
struct sci_trigger_regs *sci_trigger_cfg)
|
struct sci_trigger_regs *sci_trigger_cfg)
|
||||||
{
|
{
|
||||||
uint32_t control, control_flags;
|
|
||||||
uint8_t mux, gpio;
|
|
||||||
static const struct soc_amd_event *gev_tbl;
|
static const struct soc_amd_event *gev_tbl;
|
||||||
static size_t gev_items;
|
static size_t gev_items;
|
||||||
int gevent_num;
|
int gevent_num;
|
||||||
const bool can_set_smi_flags = !(CONFIG(VBOOT_STARTS_BEFORE_BOOTBLOCK) &&
|
const bool can_set_smi_flags = !(CONFIG(VBOOT_STARTS_BEFORE_BOOTBLOCK) &&
|
||||||
ENV_SEPARATE_VERSTAGE);
|
ENV_SEPARATE_VERSTAGE);
|
||||||
|
|
||||||
gpio = gpio_list_ptr->gpio;
|
iomux_write8(g->gpio, g->function & AMD_GPIO_MUX_MASK);
|
||||||
mux = gpio_list_ptr->function;
|
iomux_read8(g->gpio); /* Flush posted write */
|
||||||
control = gpio_list_ptr->control;
|
|
||||||
control_flags = gpio_list_ptr->flags;
|
|
||||||
|
|
||||||
iomux_write8(gpio, mux & AMD_GPIO_MUX_MASK);
|
soc_gpio_hook(g->gpio, g->function);
|
||||||
iomux_read8(gpio); /* Flush posted write */
|
|
||||||
|
|
||||||
soc_gpio_hook(gpio, mux);
|
gpio_setbits32(g->gpio, PAD_CFG_MASK, g->control);
|
||||||
|
|
||||||
gpio_setbits32(gpio, PAD_CFG_MASK, control);
|
|
||||||
/* Clear interrupt and wake status (write 1-to-clear bits) */
|
/* Clear interrupt and wake status (write 1-to-clear bits) */
|
||||||
gpio_or32(gpio, GPIO_INT_STATUS | GPIO_WAKE_STATUS);
|
gpio_or32(g->gpio, GPIO_INT_STATUS | GPIO_WAKE_STATUS);
|
||||||
if (control_flags == 0)
|
if (g->flags == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* Can't set SMI flags from PSP */
|
/* Can't set SMI flags from PSP */
|
||||||
|
@ -215,17 +208,17 @@ static void set_single_gpio(const struct soc_amd_gpio *gpio_list_ptr,
|
||||||
if (gev_tbl == NULL)
|
if (gev_tbl == NULL)
|
||||||
soc_get_gpio_event_table(&gev_tbl, &gev_items);
|
soc_get_gpio_event_table(&gev_tbl, &gev_items);
|
||||||
|
|
||||||
gevent_num = get_gpio_gevent(gpio, gev_tbl, gev_items);
|
gevent_num = get_gpio_gevent(g->gpio, gev_tbl, gev_items);
|
||||||
if (gevent_num < 0) {
|
if (gevent_num < 0) {
|
||||||
printk(BIOS_WARNING, "Warning: GPIO pin %d has no associated gevent!\n",
|
printk(BIOS_WARNING, "Warning: GPIO pin %d has no associated gevent!\n",
|
||||||
gpio);
|
g->gpio);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (control_flags & GPIO_FLAG_SMI) {
|
if (g->flags & GPIO_FLAG_SMI) {
|
||||||
program_smi(control_flags, gevent_num);
|
program_smi(g->flags, gevent_num);
|
||||||
} else if (control_flags & GPIO_FLAG_SCI) {
|
} else if (g->flags & GPIO_FLAG_SCI) {
|
||||||
fill_sci_trigger(control_flags, gevent_num, sci_trigger_cfg);
|
fill_sci_trigger(g->flags, gevent_num, sci_trigger_cfg);
|
||||||
soc_route_sci(gevent_num);
|
soc_route_sci(gevent_num);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue