mirror of
https://github.com/adulau/aha.git
synced 2025-01-03 22:53:18 +00:00
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jbarnes/pci-2.6
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jbarnes/pci-2.6: x86/PCI: add workaround for bug in ASUS A7V600 BIOS (rev 1005) PCI/x86: fix up PCI stuff so that PCI_GOANY supports OLPC
This commit is contained in:
commit
256a13dd70
5 changed files with 18 additions and 10 deletions
|
@ -1508,13 +1508,13 @@ config PCI_GOMMCONFIG
|
|||
config PCI_GODIRECT
|
||||
bool "Direct"
|
||||
|
||||
config PCI_GOANY
|
||||
bool "Any"
|
||||
|
||||
config PCI_GOOLPC
|
||||
bool "OLPC"
|
||||
depends on OLPC
|
||||
|
||||
config PCI_GOANY
|
||||
bool "Any"
|
||||
|
||||
endchoice
|
||||
|
||||
config PCI_BIOS
|
||||
|
@ -1531,9 +1531,8 @@ config PCI_MMCONFIG
|
|||
depends on X86_32 && PCI && ACPI && (PCI_GOMMCONFIG || PCI_GOANY)
|
||||
|
||||
config PCI_OLPC
|
||||
bool
|
||||
depends on PCI && PCI_GOOLPC
|
||||
default y
|
||||
def_bool y
|
||||
depends on PCI && OLPC && (PCI_GOOLPC || PCI_GOANY)
|
||||
|
||||
config PCI_DOMAINS
|
||||
def_bool y
|
||||
|
|
|
@ -15,7 +15,8 @@ static __init int pci_access_init(void)
|
|||
pci_mmcfg_early_init();
|
||||
|
||||
#ifdef CONFIG_PCI_OLPC
|
||||
pci_olpc_init();
|
||||
if (!pci_olpc_init())
|
||||
return 0; /* skip additional checks if it's an XO */
|
||||
#endif
|
||||
#ifdef CONFIG_PCI_BIOS
|
||||
pci_pcbios_init();
|
||||
|
|
|
@ -621,6 +621,13 @@ static __init int via_router_probe(struct irq_router *r,
|
|||
*/
|
||||
device = PCI_DEVICE_ID_VIA_8235;
|
||||
break;
|
||||
case PCI_DEVICE_ID_VIA_8237:
|
||||
/**
|
||||
* Asus a7v600 bios wrongly reports 8237
|
||||
* as 586-compatible
|
||||
*/
|
||||
device = PCI_DEVICE_ID_VIA_8237;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -302,12 +302,13 @@ static struct pci_raw_ops pci_olpc_conf = {
|
|||
.write = pci_olpc_write,
|
||||
};
|
||||
|
||||
void __init pci_olpc_init(void)
|
||||
int __init pci_olpc_init(void)
|
||||
{
|
||||
if (!machine_is_olpc() || olpc_has_vsa())
|
||||
return;
|
||||
return -ENODEV;
|
||||
|
||||
printk(KERN_INFO "PCI: Using configuration type OLPC\n");
|
||||
raw_pci_ops = &pci_olpc_conf;
|
||||
is_lx = is_geode_lx();
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -101,7 +101,7 @@ extern struct pci_raw_ops pci_direct_conf1;
|
|||
extern int pci_direct_probe(void);
|
||||
extern void pci_direct_init(int type);
|
||||
extern void pci_pcbios_init(void);
|
||||
extern void pci_olpc_init(void);
|
||||
extern int pci_olpc_init(void);
|
||||
|
||||
/* pci-mmconfig.c */
|
||||
|
||||
|
|
Loading…
Reference in a new issue