southbridge/intel/bd82x6x: Use common gpio.c

Use shared gpio code from common folder.
Bd82x6x's gpio.c and gpio.h is used by other southbridges
as well and will be removed once it is unused.

Change-Id: I8bd981c4696c174152cf41caefa6c083650d283a
Signed-off-by: Patrick Rudolph <siro@das-labor.org>
Reviewed-on: https://review.coreboot.org/13614
Tested-by: build bot (Jenkins)
Reviewed-by: Martin Roth <martinroth@google.com>
This commit is contained in:
Patrick Rudolph 2016-02-06 17:42:42 +01:00 committed by Stefan Reinauer
parent ffc31d07f7
commit e8e66f4763
46 changed files with 87 additions and 219 deletions

View File

@ -12,7 +12,7 @@
#include "northbridge/intel/sandybridge/sandybridge.h" #include "northbridge/intel/sandybridge/sandybridge.h"
#include "northbridge/intel/sandybridge/raminit_native.h" #include "northbridge/intel/sandybridge/raminit_native.h"
#include "southbridge/intel/bd82x6x/pch.h" #include "southbridge/intel/bd82x6x/pch.h"
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>
#include <cbfs.h> #include <cbfs.h>

View File

@ -1,4 +1,4 @@
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
const struct pch_gpio_set1 pch_gpio_set1_mode = { const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_GPIO, .gpio0 = GPIO_MODE_GPIO,
.gpio1 = GPIO_MODE_GPIO, .gpio1 = GPIO_MODE_GPIO,

View File

@ -1,4 +1,4 @@
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
static const struct pch_gpio_set1 pch_gpio_set1_mode = { static const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_NATIVE, .gpio0 = GPIO_MODE_NATIVE,
.gpio1 = GPIO_MODE_NATIVE, .gpio1 = GPIO_MODE_NATIVE,

View File

@ -29,7 +29,7 @@
#include <northbridge/intel/sandybridge/sandybridge.h> #include <northbridge/intel/sandybridge/sandybridge.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/bd82x6x/gpio.h> #include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>

View File

@ -1,4 +1,4 @@
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
static const struct pch_gpio_set1 pch_gpio_set1_mode = { static const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_NATIVE, .gpio0 = GPIO_MODE_NATIVE,
.gpio1 = GPIO_MODE_NATIVE, .gpio1 = GPIO_MODE_NATIVE,

View File

@ -29,7 +29,7 @@
#include <northbridge/intel/sandybridge/sandybridge.h> #include <northbridge/intel/sandybridge/sandybridge.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/bd82x6x/gpio.h> #include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>

View File

@ -21,6 +21,7 @@
#include <device/pci.h> #include <device/pci.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#include <ec/quanta/ene_kb3940q/ec.h> #include <ec/quanta/ene_kb3940q/ec.h>
#include "ec.h" #include "ec.h"
@ -29,9 +30,6 @@
#define FORCE_RECOVERY_MODE 0 #define FORCE_RECOVERY_MODE 0
#define FORCE_DEVELOPER_MODE 0 #define FORCE_DEVELOPER_MODE 0
int get_pch_gpio(unsigned char gpio_num);
#ifndef __PRE_RAM__ #ifndef __PRE_RAM__
#include <boot/coreboot_tables.h> #include <boot/coreboot_tables.h>
@ -92,38 +90,9 @@ void fill_lb_gpios(struct lb_gpios *gpios)
} }
#endif #endif
int get_pch_gpio(unsigned char gpio_num)
{
device_t dev;
int retval = 0;
#ifdef __PRE_RAM__
dev = PCI_DEV(0, 0x1f, 0);
#else
dev = dev_find_slot(0, PCI_DEVFN(0x1f,0));
#endif
u16 gpio_base = pci_read_config16(dev, GPIOBASE) & 0xfffe;
if (!gpio_base)
return(0);
if (gpio_num >= 64){
u32 gp_lvl3 = inl(gpio_base + GP_LVL3);
retval = ((gp_lvl3 >> (gpio_num - 64)) & 1);
} else if (gpio_num >= 32){
u32 gp_lvl2 = inl(gpio_base + GP_LVL2);
retval = ((gp_lvl2 >> (gpio_num - 32)) & 1);
} else {
u32 gp_lvl = inl(gpio_base + GP_LVL);
retval = ((gp_lvl >> gpio_num) & 1);
}
return retval;
}
int get_write_protect_state(void) int get_write_protect_state(void)
{ {
return !get_pch_gpio(WP_GPIO); return !get_gpio(WP_GPIO);
} }
int get_lid_switch(void) int get_lid_switch(void)
@ -141,7 +110,7 @@ int get_developer_mode_switch(void)
#endif #endif
/* Servo GPIO is active low, reverse it for intial state (request) */ /* Servo GPIO is active low, reverse it for intial state (request) */
dev_mode = !get_pch_gpio(DEVMODE_GPIO); dev_mode = !get_gpio(DEVMODE_GPIO);
printk(BIOS_DEBUG,"DEVELOPER MODE FROM GPIO %d: %x\n",DEVMODE_GPIO, printk(BIOS_DEBUG,"DEVELOPER MODE FROM GPIO %d: %x\n",DEVMODE_GPIO,
dev_mode); dev_mode);

View File

@ -13,7 +13,7 @@
* GNU General Public License for more details. * GNU General Public License for more details.
*/ */
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
const struct pch_gpio_set1 pch_gpio_set1_mode = { const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_NONE, /* Unused */ .gpio0 = GPIO_MODE_NONE, /* Unused */

View File

@ -30,7 +30,7 @@
#include <northbridge/intel/sandybridge/raminit.h> #include <northbridge/intel/sandybridge/raminit.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/bd82x6x/gpio.h> #include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>
#include <halt.h> #include <halt.h>

View File

@ -19,6 +19,7 @@
#include <device/device.h> #include <device/device.h>
#include <device/pci.h> #include <device/pci.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#include "ec.h" #include "ec.h"
#include <ec/google/chromeec/ec.h> #include <ec/google/chromeec/ec.h>
@ -73,21 +74,7 @@ void fill_lb_gpios(struct lb_gpios *gpios)
int get_write_protect_state(void) int get_write_protect_state(void)
{ {
device_t dev; return get_gpio(57);
#ifdef __PRE_RAM__
dev = PCI_DEV(0, 0x1f, 0);
#else
dev = dev_find_slot(0, PCI_DEVFN(0x1f, 0));
#endif
u16 gpio_base = pci_read_config32(dev, GPIOBASE) & 0xfffe;
//u16 gen_pmcon_1 = pci_read_config32(dev, GEN_PMCON_1);
if (!gpio_base)
return -1;
u32 gp_lvl2 = inl(gpio_base + 0x38);
return (gp_lvl2 >> (57 - 32)) & 1;
} }
int get_lid_switch(void) int get_lid_switch(void)

View File

@ -16,7 +16,7 @@
#ifndef LINK_GPIO_H #ifndef LINK_GPIO_H
#define LINK_GPIO_H #define LINK_GPIO_H
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
const struct pch_gpio_set1 pch_gpio_set1_mode = { const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_GPIO, /* NMI_DBG# */ .gpio0 = GPIO_MODE_GPIO, /* NMI_DBG# */

View File

@ -32,6 +32,7 @@
#include "onboard.h" #include "onboard.h"
#include "ec.h" #include "ec.h"
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#include <smbios.h> #include <smbios.h>
#include <device/pci.h> #include <device/pci.h>
#include <ec/google/chromeec/ec.h> #include <ec/google/chromeec/ec.h>

View File

@ -30,8 +30,7 @@
#include <northbridge/intel/sandybridge/sandybridge.h> #include <northbridge/intel/sandybridge/sandybridge.h>
#include <northbridge/intel/sandybridge/raminit.h> #include <northbridge/intel/sandybridge/raminit.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/gpio.h> #include <southbridge/intel/common/gpio.h>
#include <southbridge/intel/bd82x6x/pch.h>
#include "ec/google/chromeec/ec.h" #include "ec/google/chromeec/ec.h"
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>

View File

@ -21,6 +21,7 @@
#include <device/pci.h> #include <device/pci.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#include <ec/compal/ene932/ec.h> #include <ec/compal/ene932/ec.h>
#include "ec.h" #include "ec.h"
@ -83,104 +84,41 @@ void fill_lb_gpios(struct lb_gpios *gpios)
int get_lid_switch(void) int get_lid_switch(void)
{ {
device_t dev; return get_gpio(15);
#ifdef __PRE_RAM__
dev = PCI_DEV(0, 0x1f, 0);
#else
dev = dev_find_slot(0, PCI_DEVFN(0x1f, 0));
#endif
u16 gpio_base = pci_read_config32(dev, GPIOBASE) & 0xfffe;
if (!gpio_base)
return 0;
u32 gp_lvl = inl(gpio_base + GP_LVL);
return (gp_lvl >> 15) & 1;
} }
int get_developer_mode_switch(void) int get_developer_mode_switch(void)
{ {
device_t dev; u8 gpio = !get_gpio(17);
#ifdef __PRE_RAM__
dev = PCI_DEV(0, 0x1f, 0);
#else
dev = dev_find_slot(0, PCI_DEVFN(0x1f,0));
#endif
u16 gpio_base = pci_read_config32(dev, GPIOBASE) & 0xfffe;
if (!gpio_base)
return(0);
/* /*
* Dev mode is controled by EC and uboot stores a flag in TPM. This GPIO is only * Dev mode is controlled by EC and uboot stores a flag in TPM.
* for the debug header. It is AND'd to the EC request. * This GPIO is only for the debug header.
* It is AND'd to the EC request.
*/ */
u32 gp_lvl = inl(gpio_base + GP_LVL); printk(BIOS_DEBUG, "DEV MODE GPIO 17: %x\n", gpio);
printk(BIOS_DEBUG,"DEV MODE GPIO 17: %x\n", !((gp_lvl >> 17) & 1));
/* GPIO17, active low -- return active high reading and let /* GPIO17, active low -- return active high reading and let
* it be inverted by the caller if needed. */ * it be inverted by the caller if needed. */
return !((gp_lvl >> 17) & 1); return gpio;
} }
int get_write_protect_state(void) int get_write_protect_state(void)
{ {
device_t dev; return !get_gpio(70);
#ifdef __PRE_RAM__
dev = PCI_DEV(0, 0x1f, 0);
#else
dev = dev_find_slot(0, PCI_DEVFN(0x1f, 0));
#endif
u16 gpio_base = pci_read_config32(dev, GPIOBASE) & 0xfffe;
if (!gpio_base)
return 0;
u32 gp_lvl3 = inl(gpio_base + GP_LVL3);
return !((gp_lvl3 >> (70 - 64)) & 1);
} }
int get_recovery_mode_switch(void) int get_recovery_mode_switch(void)
{ {
u8 rec_mode; u8 gpio = !get_gpio(68);
device_t dev;
#ifdef __PRE_RAM__
dev = PCI_DEV(0, 0x1f, 0);
#else
dev = dev_find_slot(0, PCI_DEVFN(0x1f,0));
#endif
u16 gpio_base = pci_read_config32(dev, GPIOBASE) & 0xfffe;
if (!gpio_base)
return(0);
/* GPIO68, active low. For Servo support /* GPIO68, active low. For Servo support
* Treat as active high and let the caller invert if needed. */ * Treat as active high and let the caller invert if needed. */
u32 gp_lvl3 = inl(gpio_base + GP_LVL3); printk(BIOS_DEBUG, "REC MODE GPIO 68: %x\n", gpio);
rec_mode = !((gp_lvl3 >> (68 - 64)) & 1);
printk(BIOS_DEBUG,"REC MODE GPIO 68: %x\n", rec_mode);
return (rec_mode); return gpio;
} }
int parrot_ec_running_ro(void) int parrot_ec_running_ro(void)
{ {
device_t dev; return !get_gpio(68);
#ifdef __PRE_RAM__
dev = PCI_DEV(0, 0x1f, 0);
#else
dev = dev_find_slot(0, PCI_DEVFN(0x1f,0));
#endif
u16 gpio_base = pci_read_config32(dev, GPIOBASE) & 0xfffe;
if (!gpio_base)
return(0);
/* GPIO68 EC_RW is active low.
* Treat as active high and let the caller invert if needed. */
u32 gp_lvl3 = inl(gpio_base + GP_LVL3);
return !((gp_lvl3 >> (68 - 64)) & 1);
} }

View File

@ -16,7 +16,7 @@
#ifndef PARROT_GPIO_H #ifndef PARROT_GPIO_H
#define PARROT_GPIO_H #define PARROT_GPIO_H
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
const struct pch_gpio_set1 pch_gpio_set1_mode = { const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_NONE, /* NOT USED */ .gpio0 = GPIO_MODE_NONE, /* NOT USED */

View File

@ -30,6 +30,7 @@
#include <northbridge/intel/sandybridge/raminit.h> #include <northbridge/intel/sandybridge/raminit.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>
#include <halt.h> #include <halt.h>

View File

@ -21,6 +21,7 @@
#include <device/pci.h> #include <device/pci.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#include "ec.h" #include "ec.h"
#include <ec/quanta/it8518/ec.h> #include <ec/quanta/it8518/ec.h>
@ -81,20 +82,7 @@ void fill_lb_gpios(struct lb_gpios *gpios)
int get_write_protect_state(void) int get_write_protect_state(void)
{ {
device_t dev; return !get_gpio(7);
#ifdef __PRE_RAM__
dev = PCI_DEV(0, 0x1f, 0);
#else
dev = dev_find_slot(0, PCI_DEVFN(0x1f, 0));
#endif
u16 gpio_base = pci_read_config32(dev, GPIOBASE) & 0xfffe;
if (!gpio_base)
return 0;
u32 gp_lvl = inl(gpio_base + GP_LVL);
return !((gp_lvl >> 7) & 1);
} }
int get_lid_switch(void) int get_lid_switch(void)

View File

@ -16,7 +16,7 @@
#ifndef STOUT_GPIO_H #ifndef STOUT_GPIO_H
#define STOUT_GPIO_H #define STOUT_GPIO_H
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
const struct pch_gpio_set1 pch_gpio_set1_mode = { const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_GPIO, /* GPIO0 */ .gpio0 = GPIO_MODE_GPIO, /* GPIO0 */

View File

@ -30,6 +30,7 @@
#include <northbridge/intel/sandybridge/raminit.h> #include <northbridge/intel/sandybridge/raminit.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>
#include <halt.h> #include <halt.h>

View File

@ -19,6 +19,7 @@
#include <device/device.h> #include <device/device.h>
#include <device/pci.h> #include <device/pci.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#ifndef __PRE_RAM__ #ifndef __PRE_RAM__
#include <boot/coreboot_tables.h> #include <boot/coreboot_tables.h>
@ -81,30 +82,12 @@ void fill_lb_gpios(struct lb_gpios *gpios)
int get_developer_mode_switch(void) int get_developer_mode_switch(void)
{ {
device_t dev; /* Developer: GPIO57, active high */
#ifdef __PRE_RAM__ return get_gpio(57);
dev = PCI_DEV(0, 0x1f, 0);
#else
dev = dev_find_slot(0, PCI_DEVFN(0x1f,0));
#endif
u16 gpio_base = pci_read_config32(dev, GPIOBASE) & 0xfffe;
u32 gp_lvl2 = inl(gpio_base + 0x38);
/* Developer: GPIO17, active high */
return (gp_lvl2 >> (57-32)) & 1;
} }
int get_recovery_mode_switch(void) int get_recovery_mode_switch(void)
{ {
device_t dev;
#ifdef __PRE_RAM__
dev = PCI_DEV(0, 0x1f, 0);
#else
dev = dev_find_slot(0, PCI_DEVFN(0x1f,0));
#endif
u16 gpio_base = pci_read_config32(dev, GPIOBASE) & 0xfffe;
u32 gp_lvl = inl(gpio_base + 0x0c);
/* Recovery: GPIO22, active low */ /* Recovery: GPIO22, active low */
return !((gp_lvl >> 22) & 1); return !get_gpio(22);
} }

View File

@ -16,7 +16,7 @@
#ifndef EMERALDLAKE2_GPIO_H #ifndef EMERALDLAKE2_GPIO_H
#define EMERALDLAKE2_GPIO_H #define EMERALDLAKE2_GPIO_H
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
const struct pch_gpio_set1 pch_gpio_set1_mode = { const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_GPIO, .gpio0 = GPIO_MODE_GPIO,

View File

@ -31,6 +31,7 @@
#include <northbridge/intel/sandybridge/raminit.h> #include <northbridge/intel/sandybridge/raminit.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>
#include <halt.h> #include <halt.h>

View File

@ -16,7 +16,7 @@
#ifndef KTQM77_GPIO_H #ifndef KTQM77_GPIO_H
#define KTQM77_GPIO_H #define KTQM77_GPIO_H
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
/* /*
* TODO: Investigate somehow... Current values are taken from a running * TODO: Investigate somehow... Current values are taken from a running

View File

@ -30,6 +30,7 @@
#include <northbridge/intel/sandybridge/raminit.h> #include <northbridge/intel/sandybridge/raminit.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>
#include <halt.h> #include <halt.h>

View File

@ -1,4 +1,4 @@
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
const struct pch_gpio_set1 pch_gpio_set1_mode = { const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_GPIO, // -USB30_SMIB - input .gpio0 = GPIO_MODE_GPIO, // -USB30_SMIB - input
.gpio1 = GPIO_MODE_GPIO, // -EC_SCI - input .gpio1 = GPIO_MODE_GPIO, // -EC_SCI - input

View File

@ -1,4 +1,4 @@
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
const struct pch_gpio_set1 pch_gpio_set1_mode = { const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_GPIO, .gpio0 = GPIO_MODE_GPIO,
.gpio1 = GPIO_MODE_GPIO, // -EC_SCI - input .gpio1 = GPIO_MODE_GPIO, // -EC_SCI - input

View File

@ -16,7 +16,7 @@
#ifndef T520_GPIO_H #ifndef T520_GPIO_H
#define T520_GPIO_H #define T520_GPIO_H
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
const struct pch_gpio_set1 pch_gpio_set1_mode = { const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_GPIO, // -USB30_SMI - input .gpio0 = GPIO_MODE_GPIO, // -USB30_SMI - input

View File

@ -31,7 +31,7 @@
#include <northbridge/intel/sandybridge/sandybridge.h> #include <northbridge/intel/sandybridge/sandybridge.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/bd82x6x/gpio.h> #include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>
#include <cbfs.h> #include <cbfs.h>

View File

@ -1,4 +1,4 @@
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
const struct pch_gpio_set1 pch_gpio_set1_mode = { const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_GPIO, .gpio0 = GPIO_MODE_GPIO,
.gpio1 = GPIO_MODE_GPIO, .gpio1 = GPIO_MODE_GPIO,

View File

@ -16,7 +16,7 @@
#ifndef LENOVO_X201_GPIO_H #ifndef LENOVO_X201_GPIO_H
#define LENOVO_X201_GPIO_H #define LENOVO_X201_GPIO_H
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
const struct pch_gpio_set1 pch_gpio_set1_mode = { const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_GPIO, .gpio0 = GPIO_MODE_GPIO,

View File

@ -1,4 +1,4 @@
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
static const struct pch_gpio_set1 pch_gpio_set1_mode = { static const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_GPIO, .gpio0 = GPIO_MODE_GPIO,
.gpio1 = GPIO_MODE_GPIO, .gpio1 = GPIO_MODE_GPIO,

View File

@ -29,7 +29,7 @@
#include <northbridge/intel/sandybridge/sandybridge.h> #include <northbridge/intel/sandybridge/sandybridge.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/bd82x6x/gpio.h> #include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>

View File

@ -17,7 +17,7 @@
#ifndef X230_GPIO_H #ifndef X230_GPIO_H
#define X230_GPIO_H #define X230_GPIO_H
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
const struct pch_gpio_set1 pch_gpio_set1_mode = { const struct pch_gpio_set1 pch_gpio_set1_mode = {
.gpio0 = GPIO_MODE_GPIO, .gpio0 = GPIO_MODE_GPIO,

View File

@ -31,7 +31,7 @@
#include <northbridge/intel/sandybridge/sandybridge.h> #include <northbridge/intel/sandybridge/sandybridge.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/bd82x6x/gpio.h> #include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>
#include <cbfs.h> #include <cbfs.h>

View File

@ -20,6 +20,7 @@
#include <device/pci.h> #include <device/pci.h>
#include <northbridge/intel/sandybridge/sandybridge.h> #include <northbridge/intel/sandybridge/sandybridge.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#define GPIO_SPI_WP 24 #define GPIO_SPI_WP 24
#define GPIO_REC_MODE 42 #define GPIO_REC_MODE 42
@ -119,19 +120,16 @@ int get_recovery_mode_switch(void)
void init_bootmode_straps(void) void init_bootmode_straps(void)
{ {
#ifdef __PRE_RAM__ #ifdef __PRE_RAM__
u16 gpio_base = pci_read_config32(PCH_LPC_DEV, GPIO_BASE) & 0xfffe;
u32 gp_lvl2 = inl(gpio_base + GP_LVL2);
u32 gp_lvl = inl(gpio_base + GP_LVL);
u32 flags = 0; u32 flags = 0;
/* Write Protect: GPIO24 = KBC3_SPI_WP#, active high */ /* Write Protect: GPIO24 = KBC3_SPI_WP#, active high */
if (gp_lvl & (1 << GPIO_SPI_WP)) if (get_gpio(GPIO_SPI_WP))
flags |= (1 << FLAG_SPI_WP); flags |= (1 << FLAG_SPI_WP);
/* Recovery: GPIO42 = CHP3_REC_MODE#, active low */ /* Recovery: GPIO42 = CHP3_REC_MODE#, active low */
if (!(gp_lvl2 & (1 << (GPIO_REC_MODE-32)))) if (!get_gpio(GPIO_REC_MODE))
flags |= (1 << FLAG_REC_MODE); flags |= (1 << FLAG_REC_MODE);
/* Developer: GPIO17 = KBC3_DVP_MODE, active high */ /* Developer: GPIO17 = KBC3_DVP_MODE, active high */
if (gp_lvl & (1 << GPIO_DEV_MODE)) if (get_gpio(GPIO_DEV_MODE))
flags |= (1 << FLAG_DEV_MODE); flags |= (1 << FLAG_DEV_MODE);
pci_write_config32(PCI_DEV(0, 0x1f, 2), SATA_SP, flags); pci_write_config32(PCI_DEV(0, 0x1f, 2), SATA_SP, flags);

View File

@ -16,7 +16,7 @@
#ifndef LUMPY_GPIO_H #ifndef LUMPY_GPIO_H
#define LUMPY_GPIO_H #define LUMPY_GPIO_H
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
/* /*
* GPIO SET 1 includes GPIO0 to GPIO31 * GPIO SET 1 includes GPIO0 to GPIO31

View File

@ -33,6 +33,7 @@
#include <northbridge/intel/sandybridge/raminit.h> #include <northbridge/intel/sandybridge/raminit.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>
#include <halt.h> #include <halt.h>

View File

@ -19,6 +19,7 @@
#include <device/device.h> #include <device/device.h>
#include <device/pci.h> #include <device/pci.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#define GPIO_SPI_WP 68 #define GPIO_SPI_WP 68
#define GPIO_REC_MODE 42 #define GPIO_REC_MODE 42
@ -116,20 +117,16 @@ int get_recovery_mode_switch(void)
void init_bootmode_straps(void) void init_bootmode_straps(void)
{ {
#ifdef __PRE_RAM__ #ifdef __PRE_RAM__
u16 gpio_base = pci_read_config32(PCH_LPC_DEV, GPIO_BASE) & 0xfffe;
u32 gp_lvl3 = inl(gpio_base + GP_LVL3);
u32 gp_lvl2 = inl(gpio_base + GP_LVL2);
u32 gp_lvl = inl(gpio_base + GP_LVL);
u32 flags = 0; u32 flags = 0;
/* Write Protect: GPIO68 = CHP3_SPI_WP, active high */ /* Write Protect: GPIO68 = CHP3_SPI_WP, active high */
if (gp_lvl3 & (1 << (GPIO_SPI_WP-64))) if (get_gpio(GPIO_SPI_WP))
flags |= (1 << FLAG_SPI_WP); flags |= (1 << FLAG_SPI_WP);
/* Recovery: GPIO42 = CHP3_REC_MODE#, active low */ /* Recovery: GPIO42 = CHP3_REC_MODE#, active low */
if (!(gp_lvl2 & (1 << (GPIO_REC_MODE-32)))) if (!get_gpio(GPIO_REC_MODE))
flags |= (1 << FLAG_REC_MODE); flags |= (1 << FLAG_REC_MODE);
/* Developer: GPIO17 = KBC3_DVP_MODE, active high */ /* Developer: GPIO17 = KBC3_DVP_MODE, active high */
if (gp_lvl & (1 << GPIO_DEV_MODE)) if (get_gpio(GPIO_DEV_MODE))
flags |= (1 << FLAG_DEV_MODE); flags |= (1 << FLAG_DEV_MODE);
pci_write_config32(PCI_DEV(0, 0x1f, 2), SATA_SP, flags); pci_write_config32(PCI_DEV(0, 0x1f, 2), SATA_SP, flags);

View File

@ -16,7 +16,7 @@
#ifndef STUMPY_GPIO_H #ifndef STUMPY_GPIO_H
#define STUMPY_GPIO_H #define STUMPY_GPIO_H
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
/* /*
* GPIO SET 1 includes GPIO0 to GPIO31 * GPIO SET 1 includes GPIO0 to GPIO31

View File

@ -33,6 +33,7 @@
#include <northbridge/intel/sandybridge/raminit.h> #include <northbridge/intel/sandybridge/raminit.h>
#include <northbridge/intel/sandybridge/raminit_native.h> #include <northbridge/intel/sandybridge/raminit_native.h>
#include <southbridge/intel/bd82x6x/pch.h> #include <southbridge/intel/bd82x6x/pch.h>
#include <southbridge/intel/common/gpio.h>
#include <arch/cpu.h> #include <arch/cpu.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>
#include <halt.h> #include <halt.h>

View File

@ -31,7 +31,7 @@
#include <tpm.h> #include <tpm.h>
#include <northbridge/intel/sandybridge/chip.h> #include <northbridge/intel/sandybridge/chip.h>
#include "southbridge/intel/bd82x6x/pch.h" #include "southbridge/intel/bd82x6x/pch.h"
#include "southbridge/intel/bd82x6x/gpio.h" #include <southbridge/intel/common/gpio.h>
static void early_pch_init(void) static void early_pch_init(void)
{ {

View File

@ -35,6 +35,7 @@ config SOUTH_BRIDGE_OPTIONS # dummy
select COMMON_FADT select COMMON_FADT
select ACPI_SATA_GENERATOR select ACPI_SATA_GENERATOR
select HAVE_INTEL_FIRMWARE select HAVE_INTEL_FIRMWARE
select SOUTHBRIDGE_INTEL_COMMON_GPIO
config EHCI_BAR config EHCI_BAR
hex hex

View File

@ -41,7 +41,7 @@ smm-$(CONFIG_SPI_FLASH_SMM) += ../common/spi.c
ramstage-$(CONFIG_HAVE_SMI_HANDLER) += smi.c ramstage-$(CONFIG_HAVE_SMI_HANDLER) += smi.c
smm-$(CONFIG_HAVE_SMI_HANDLER) += smihandler.c me.c me_8.x.c finalize.c pch.c smm-$(CONFIG_HAVE_SMI_HANDLER) += smihandler.c me.c me_8.x.c finalize.c pch.c
romstage-y += early_smbus.c me_status.c gpio.c romstage-y += early_smbus.c me_status.c
romstage-y += reset.c romstage-y += reset.c
romstage-y += early_spi.c early_pch_common.c romstage-y += early_spi.c early_pch_common.c
romstage-y += early_rcba.c romstage-y += early_rcba.c

View File

@ -18,6 +18,22 @@
#include <stdint.h> #include <stdint.h>
/* ICH7 GPIOBASE */
#define GPIO_USE_SEL 0x00
#define GP_IO_SEL 0x04
#define GP_LVL 0x0c
#define GPO_BLINK 0x18
#define GPI_INV 0x2c
#define GPIO_USE_SEL2 0x30
#define GP_IO_SEL2 0x34
#define GP_LVL2 0x38
#define GPIO_USE_SEL3 0x40
#define GP_IO_SEL3 0x44
#define GP_LVL3 0x48
#define GP_RST_SEL1 0x60
#define GP_RST_SEL2 0x64
#define GP_RST_SEL3 0x68
#define GPIO_MODE_NATIVE 0 #define GPIO_MODE_NATIVE 0
#define GPIO_MODE_GPIO 1 #define GPIO_MODE_GPIO 1
#define GPIO_MODE_NONE 1 #define GPIO_MODE_NONE 1

View File

@ -462,22 +462,6 @@ early_usb_init (const struct southbridge_usb_port *portmap);
#define XUSB2PRM 0xd4 /* 32bit */ #define XUSB2PRM 0xd4 /* 32bit */
#define USB3PRM 0xdc /* 32bit */ #define USB3PRM 0xdc /* 32bit */
/* ICH7 GPIOBASE */
#define GPIO_USE_SEL 0x00
#define GP_IO_SEL 0x04
#define GP_LVL 0x0c
#define GPO_BLINK 0x18
#define GPI_INV 0x2c
#define GPIO_USE_SEL2 0x30
#define GP_IO_SEL2 0x34
#define GP_LVL2 0x38
#define GPIO_USE_SEL3 0x40
#define GP_IO_SEL3 0x44
#define GP_LVL3 0x48
#define GP_RST_SEL1 0x60
#define GP_RST_SEL2 0x64
#define GP_RST_SEL3 0x68
/* ICH7 PMBASE */ /* ICH7 PMBASE */
#define PM1_STS 0x00 #define PM1_STS 0x00
#define WAK_STS (1 << 15) #define WAK_STS (1 << 15)

View File

@ -30,6 +30,7 @@
#include <northbridge/intel/sandybridge/sandybridge.h> #include <northbridge/intel/sandybridge/sandybridge.h>
#include <arch/pci_mmio_cfg.h> #include <arch/pci_mmio_cfg.h>
#include <southbridge/intel/bd82x6x/me.h> #include <southbridge/intel/bd82x6x/me.h>
#include <southbridge/intel/common/gpio.h>
#include <cpu/intel/model_206ax/model_206ax.h> #include <cpu/intel/model_206ax/model_206ax.h>
/* While we read PMBASE dynamically in case it changed, let's /* While we read PMBASE dynamically in case it changed, let's