diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2009-09-16 10:49:54 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-09-16 10:49:54 -0400 |
commit | 4406c56d0a4da7a37b9180abeaece6cd00bcc874 (patch) | |
tree | 65a85fa73a25d24cbed6d163fdcf8df1b934a0be /drivers/pci/pci-stub.c | |
parent | 6b7b352f2102e21f9d8f38e932f01d9c5705c073 (diff) | |
parent | 5e3573db2bd5db6925159279d99576a4635bdb66 (diff) |
Merge branch 'linux-next' of git://git.kernel.org/pub/scm/linux/kernel/git/jbarnes/pci-2.6
* 'linux-next' of git://git.kernel.org/pub/scm/linux/kernel/git/jbarnes/pci-2.6: (75 commits)
PCI hotplug: clean up acpi_run_hpp()
PCI hotplug: acpiphp: use generic pci_configure_slot()
PCI hotplug: shpchp: use generic pci_configure_slot()
PCI hotplug: pciehp: use generic pci_configure_slot()
PCI hotplug: add pci_configure_slot()
PCI hotplug: clean up acpi_get_hp_params_from_firmware() interface
PCI hotplug: acpiphp: don't cache hotplug_params in acpiphp_bridge
PCI hotplug: acpiphp: remove superfluous _HPP/_HPX evaluation
PCI: Clear saved_state after the state has been restored
PCI PM: Return error codes from pci_pm_resume()
PCI: use dev_printk in quirk messages
PCI / PCIe portdrv: Fix pcie_portdrv_slot_reset()
PCI Hotplug: convert acpi_pci_detect_ejectable() to take an acpi_handle
PCI Hotplug: acpiphp: find bridges the easy way
PCI: pcie portdrv: remove unused variable
PCI / ACPI PM: Propagate wake-up enable for devices w/o ACPI support
ACPI PM: Replace wakeup.prepared with reference counter
PCI PM: Introduce device flag wakeup_prepared
PCI / ACPI PM: Rework some debug messages
PCI PM: Simplify PCI wake-up code
...
Fixed up conflict in arch/powerpc/kernel/pci_64.c due to OF device tree
scanning having been moved and merged for the 32- and 64-bit cases. The
'needs_freset' initialization added in 6e19314cc ("PCI/powerpc: support
PCIe fundamental reset") is now in arch/powerpc/kernel/pci_of_scan.c.
Diffstat (limited to 'drivers/pci/pci-stub.c')
-rw-r--r-- | drivers/pci/pci-stub.c | 45 |
1 files changed, 44 insertions, 1 deletions
diff --git a/drivers/pci/pci-stub.c b/drivers/pci/pci-stub.c index 74fbec0bf6cb..f7b68ca6cc98 100644 --- a/drivers/pci/pci-stub.c +++ b/drivers/pci/pci-stub.c | |||
@@ -19,8 +19,16 @@ | |||
19 | #include <linux/module.h> | 19 | #include <linux/module.h> |
20 | #include <linux/pci.h> | 20 | #include <linux/pci.h> |
21 | 21 | ||
22 | static char ids[1024] __initdata; | ||
23 | |||
24 | module_param_string(ids, ids, sizeof(ids), 0); | ||
25 | MODULE_PARM_DESC(ids, "Initial PCI IDs to add to the stub driver, format is " | ||
26 | "\"vendor:device[:subvendor[:subdevice[:class[:class_mask]]]]\"" | ||
27 | " and multiple comma separated entries can be specified"); | ||
28 | |||
22 | static int pci_stub_probe(struct pci_dev *dev, const struct pci_device_id *id) | 29 | static int pci_stub_probe(struct pci_dev *dev, const struct pci_device_id *id) |
23 | { | 30 | { |
31 | dev_printk(KERN_INFO, &dev->dev, "claimed by stub\n"); | ||
24 | return 0; | 32 | return 0; |
25 | } | 33 | } |
26 | 34 | ||
@@ -32,7 +40,42 @@ static struct pci_driver stub_driver = { | |||
32 | 40 | ||
33 | static int __init pci_stub_init(void) | 41 | static int __init pci_stub_init(void) |
34 | { | 42 | { |
35 | return pci_register_driver(&stub_driver); | 43 | char *p, *id; |
44 | int rc; | ||
45 | |||
46 | rc = pci_register_driver(&stub_driver); | ||
47 | if (rc) | ||
48 | return rc; | ||
49 | |||
50 | /* add ids specified in the module parameter */ | ||
51 | p = ids; | ||
52 | while ((id = strsep(&p, ","))) { | ||
53 | unsigned int vendor, device, subvendor = PCI_ANY_ID, | ||
54 | subdevice = PCI_ANY_ID, class=0, class_mask=0; | ||
55 | int fields; | ||
56 | |||
57 | fields = sscanf(id, "%x:%x:%x:%x:%x:%x", | ||
58 | &vendor, &device, &subvendor, &subdevice, | ||
59 | &class, &class_mask); | ||
60 | |||
61 | if (fields < 2) { | ||
62 | printk(KERN_WARNING | ||
63 | "pci-stub: invalid id string \"%s\"\n", id); | ||
64 | continue; | ||
65 | } | ||
66 | |||
67 | printk(KERN_INFO | ||
68 | "pci-stub: add %04X:%04X sub=%04X:%04X cls=%08X/%08X\n", | ||
69 | vendor, device, subvendor, subdevice, class, class_mask); | ||
70 | |||
71 | rc = pci_add_dynid(&stub_driver, vendor, device, | ||
72 | subvendor, subdevice, class, class_mask, 0); | ||
73 | if (rc) | ||
74 | printk(KERN_WARNING | ||
75 | "pci-stub: failed to add dynamic id (%d)\n", rc); | ||
76 | } | ||
77 | |||
78 | return 0; | ||
36 | } | 79 | } |
37 | 80 | ||
38 | static void __exit pci_stub_exit(void) | 81 | static void __exit pci_stub_exit(void) |