In ICH5 and before the GPIOBASE and GPIOCTRL are 0x58 and 0x5C. This patch updates lpc_ich.c that supports ICH5 and before GPIO. This patch fix the "I/O space for GPIO uninitialized" message. Reference: 252516-001, 252517-028: 82801EB (ICH5), 82801ER (ICH5R) documents from developer.intel.com.
Signed-off-by: Agócs Pál <agocs.pal...@gmail.com> diffstat := lpc_ich.c | 27 ++++++++++++++++++++++----- 1 file changed, 22 insertions(+), 5 deletions(-) ------------------------------------------------------------------- diff -upNr a/drivers/mfd/lpc_ich.c b/drivers/mfd/lpc_ich.c --- a/drivers/mfd/lpc_ich.c 2013-01-11 18:19:28.000000000 +0100 +++ b/drivers/mfd/lpc_ich.c 2013-01-14 18:01:38.000000000 +0100 @@ -76,7 +76,9 @@ #define ACPIBASE_GCS_END 0x3414 #define GPIOBASE 0x48 +#define GPIOBASE_ICH5 0x58 #define GPIOCTRL 0x4C +#define GPIOCTRL_ICH5 0x5C #define RCBABASE 0xf0 @@ -659,6 +661,20 @@ static DEFINE_PCI_DEVICE_TABLE(lpc_ich_i }; MODULE_DEVICE_TABLE(pci, lpc_ich_ids); +static u8 gpio_base_offset; +static u8 gpio_ctrl_offset; + +static void set_gpio_offsets(const struct pci_device_id *id) +{ + gpio_base_offset = GPIOBASE; + gpio_ctrl_offset = GPIOCTRL; + + if(id->driver_data <= LPC_ICH5) { + gpio_base_offset = GPIOBASE_ICH5; + gpio_ctrl_offset = GPIOCTRL_ICH5; + } +} + static void lpc_ich_restore_config_space(struct pci_dev *dev) { if (lpc_ich_acpi_save >= 0) { @@ -667,7 +683,7 @@ static void lpc_ich_restore_config_space } if (lpc_ich_gpio_save >= 0) { - pci_write_config_byte(dev, GPIOCTRL, lpc_ich_gpio_save); + pci_write_config_byte(dev, gpio_ctrl_offset, lpc_ich_gpio_save); lpc_ich_gpio_save = -1; } } @@ -685,8 +701,8 @@ static void __devinit lpc_ich_enable_gpi { u8 reg_save; - pci_read_config_byte(dev, GPIOCTRL, ®_save); - pci_write_config_byte(dev, GPIOCTRL, reg_save | 0x10); + pci_read_config_byte(dev, gpio_ctrl_offset, ®_save); + pci_write_config_byte(dev, gpio_ctrl_offset, reg_save | 0x10); lpc_ich_gpio_save = reg_save; } @@ -757,7 +773,7 @@ static int __devinit lpc_ich_init_gpio(s gpe0_done: /* Setup GPIO base register */ - pci_read_config_dword(dev, GPIOBASE, &base_addr_cfg); + pci_read_config_dword(dev, gpio_base_offset, &base_addr_cfg); base_addr = base_addr_cfg & 0x0000ff80; if (!base_addr) { dev_err(&dev->dev, "I/O space for GPIO uninitialized\n"); @@ -857,7 +873,8 @@ static int __devinit lpc_ich_probe(struc { int ret; bool cell_added = false; - + set_gpio_offsets(id); + ret = lpc_ich_init_wdt(dev, id); if (!ret) cell_added = true; -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/