aboutsummaryrefslogtreecommitdiff
path: root/src/soc
diff options
context:
space:
mode:
authorAngel Pons <th3fanbus@gmail.com>2021-01-28 17:26:07 +0100
committerPatrick Georgi <pgeorgi@google.com>2021-02-15 08:54:28 +0000
commit9cf9b8547669507e46039702194fec9eb364a2e4 (patch)
tree2845c07596cda4c6f5a7b8d5c56cd1675f46e110 /src/soc
parent52e48b56e2c30b8d164cc3f6a308238de122e369 (diff)
soc/intel/broadwell/pch: Use Lynxpoint GPIO code
This allows dropping `gpio.c` from Broadwell. Change-Id: I6b34e11f849cdf01e402fe79d078711af94e1ec0 Signed-off-by: Angel Pons <th3fanbus@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/50081 Reviewed-by: Patrick Georgi <pgeorgi@google.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Diffstat (limited to 'src/soc')
-rw-r--r--src/soc/intel/broadwell/pch/Makefile.inc6
-rw-r--r--src/soc/intel/broadwell/pch/gpio.c133
2 files changed, 3 insertions, 136 deletions
diff --git a/src/soc/intel/broadwell/pch/Makefile.inc b/src/soc/intel/broadwell/pch/Makefile.inc
index 2bd31d25e9..740c711198 100644
--- a/src/soc/intel/broadwell/pch/Makefile.inc
+++ b/src/soc/intel/broadwell/pch/Makefile.inc
@@ -4,9 +4,9 @@ ramstage-y += adsp.c
romstage-y += early_pch.c
ramstage-$(CONFIG_ELOG) += elog.c
ramstage-y += finalize.c
-ramstage-y += gpio.c
-romstage-y += gpio.c
-smm-y += gpio.c
+ramstage-y += ../../../../southbridge/intel/lynxpoint/lp_gpio.c
+romstage-y += ../../../../southbridge/intel/lynxpoint/lp_gpio.c
+smm-y += ../../../../southbridge/intel/lynxpoint/lp_gpio.c
ramstage-y += hda.c
ramstage-y += iobp.c
romstage-y += iobp.c
diff --git a/src/soc/intel/broadwell/pch/gpio.c b/src/soc/intel/broadwell/pch/gpio.c
deleted file mode 100644
index a1c8345d3b..0000000000
--- a/src/soc/intel/broadwell/pch/gpio.c
+++ /dev/null
@@ -1,133 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <stdint.h>
-#include <arch/io.h>
-#include <device/device.h>
-#include <device/pci.h>
-#include <soc/iomap.h>
-#include <soc/pm.h>
-#include <southbridge/intel/lynxpoint/lp_gpio.h>
-
-/*
- * This function will return a number that indicates which PIRQ
- * this GPIO maps to. If this is not a PIRQ capable GPIO then
- * it will return -1. The GPIO to PIRQ mapping is not linear.
- */
-static int gpio_to_pirq(int gpio)
-{
- switch (gpio) {
- case 8: return 0; /* PIRQI */
- case 9: return 1; /* PIRQJ */
- case 10: return 2; /* PIRQK */
- case 13: return 3; /* PIRQL */
- case 14: return 4; /* PIRQM */
- case 45: return 5; /* PIRQN */
- case 46: return 6; /* PIRQO */
- case 47: return 7; /* PIRQP */
- case 48: return 8; /* PIRQQ */
- case 49: return 9; /* PIRQR */
- case 50: return 10; /* PIRQS */
- case 51: return 11; /* PIRQT */
- case 52: return 12; /* PIRQU */
- case 53: return 13; /* PIRQV */
- case 54: return 14; /* PIRQW */
- case 55: return 15; /* PIRQX */
- default: return -1;
- };
-}
-
-void setup_pch_lp_gpios(const struct pch_lp_gpio_map map[])
-{
- const struct pch_lp_gpio_map *config;
- u32 owner[3] = {0};
- u32 route[3] = {0};
- u32 irqen[3] = {0};
- u32 reset[3] = {0};
- u32 blink = 0;
- u16 pirq2apic = 0;
- int set, bit, gpio = 0;
-
- for (config = map; config->conf0 != GPIO_LIST_END; config++, gpio++) {
- if (gpio > MAX_GPIO_NUMBER)
- break;
-
- /* Setup Configuration registers 1 and 2 */
- outl(config->conf0, GPIO_BASE_ADDRESS + GPIO_CONFIG0(gpio));
- outl(config->conf1, GPIO_BASE_ADDRESS + GPIO_CONFIG1(gpio));
-
- /* Determine set and bit based on GPIO number */
- set = gpio >> 5;
- bit = gpio % 32;
-
- /* Apply settings to set specific bits */
- owner[set] |= config->owner << bit;
- route[set] |= config->route << bit;
- irqen[set] |= config->irqen << bit;
- reset[set] |= config->reset << bit;
-
- if (set == 0)
- blink |= config->blink << bit;
-
- /* PIRQ to IO-APIC map */
- if (config->pirq == GPIO_PIRQ_APIC_ROUTE) {
- set = gpio_to_pirq(gpio);
- if (set >= 0)
- pirq2apic |= 1 << set;
- }
- }
-
- for (set = 0; set <= 2; set++) {
- outl(owner[set], GPIO_BASE_ADDRESS + GPIO_OWNER(set));
- outl(route[set], GPIO_BASE_ADDRESS + GPIO_ROUTE(set));
- outl(irqen[set], GPIO_BASE_ADDRESS + GPIO_IRQ_IE(set));
- outl(reset[set], GPIO_BASE_ADDRESS + GPIO_RESET(set));
- }
-
- outl(blink, GPIO_BASE_ADDRESS + GPIO_BLINK);
- outl(pirq2apic, GPIO_BASE_ADDRESS + GPIO_PIRQ_APIC_EN);
-}
-
-int get_gpio(int gpio_num)
-{
- if (gpio_num > MAX_GPIO_NUMBER)
- return 0;
-
- return !!(inl(GPIO_BASE_ADDRESS + GPIO_CONFIG0(gpio_num)) & GPI_LEVEL);
-}
-
-/*
- * get a number comprised of multiple GPIO values. gpio_num_array points to
- * the array of gpio pin numbers to scan, terminated by -1.
- */
-unsigned int get_gpios(const int *gpio_num_array)
-{
- int gpio;
- unsigned int bitmask = 1;
- unsigned int vector = 0;
-
- while (bitmask &&
- ((gpio = *gpio_num_array++) != -1)) {
- if (get_gpio(gpio))
- vector |= bitmask;
- bitmask <<= 1;
- }
- return vector;
-}
-
-void set_gpio(int gpio_num, int value)
-{
- u32 conf0;
-
- if (gpio_num > MAX_GPIO_NUMBER)
- return;
-
- conf0 = inl(GPIO_BASE_ADDRESS + GPIO_CONFIG0(gpio_num));
- conf0 &= ~GPO_LEVEL_MASK;
- conf0 |= value << GPO_LEVEL_SHIFT;
- outl(conf0, GPIO_BASE_ADDRESS + GPIO_CONFIG0(gpio_num));
-}
-
-int gpio_is_native(int gpio_num)
-{
- return !(inl(GPIO_BASE_ADDRESS + GPIO_CONFIG0(gpio_num)) & 1);
-}