diff options
Diffstat (limited to 'drivers/pci/quirks.c')
-rw-r--r-- | drivers/pci/quirks.c | 36 |
1 files changed, 35 insertions, 1 deletions
diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 8726698866b..d58b94030ef 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c | |||
@@ -338,6 +338,23 @@ static void __devinit quirk_s3_64M(struct pci_dev *dev) | |||
338 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_S3, PCI_DEVICE_ID_S3_868, quirk_s3_64M); | 338 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_S3, PCI_DEVICE_ID_S3_868, quirk_s3_64M); |
339 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_S3, PCI_DEVICE_ID_S3_968, quirk_s3_64M); | 339 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_S3, PCI_DEVICE_ID_S3_968, quirk_s3_64M); |
340 | 340 | ||
341 | /* | ||
342 | * Some CS5536 BIOSes (for example, the Soekris NET5501 board w/ comBIOS | ||
343 | * ver. 1.33 20070103) don't set the correct ISA PCI region header info. | ||
344 | * BAR0 should be 8 bytes; instead, it may be set to something like 8k | ||
345 | * (which conflicts w/ BAR1's memory range). | ||
346 | */ | ||
347 | static void __devinit quirk_cs5536_vsa(struct pci_dev *dev) | ||
348 | { | ||
349 | if (pci_resource_len(dev, 0) != 8) { | ||
350 | struct resource *res = &dev->resource[0]; | ||
351 | res->end = res->start + 8 - 1; | ||
352 | dev_info(&dev->dev, "CS5536 ISA bridge bug detected " | ||
353 | "(incorrect header); workaround applied.\n"); | ||
354 | } | ||
355 | } | ||
356 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_CS5536_ISA, quirk_cs5536_vsa); | ||
357 | |||
341 | static void __devinit quirk_io_region(struct pci_dev *dev, unsigned region, | 358 | static void __devinit quirk_io_region(struct pci_dev *dev, unsigned region, |
342 | unsigned size, int nr, const char *name) | 359 | unsigned size, int nr, const char *name) |
343 | { | 360 | { |
@@ -2684,14 +2701,31 @@ static int reset_intel_82599_sfp_virtfn(struct pci_dev *dev, int probe) | |||
2684 | 2701 | ||
2685 | #define PCI_DEVICE_ID_INTEL_82599_SFP_VF 0x10ed | 2702 | #define PCI_DEVICE_ID_INTEL_82599_SFP_VF 0x10ed |
2686 | 2703 | ||
2687 | struct pci_dev_reset_methods pci_dev_reset_methods[] = { | 2704 | static const struct pci_dev_reset_methods pci_dev_reset_methods[] = { |
2688 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82599_SFP_VF, | 2705 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82599_SFP_VF, |
2689 | reset_intel_82599_sfp_virtfn }, | 2706 | reset_intel_82599_sfp_virtfn }, |
2690 | { PCI_VENDOR_ID_INTEL, PCI_ANY_ID, | 2707 | { PCI_VENDOR_ID_INTEL, PCI_ANY_ID, |
2691 | reset_intel_generic_dev }, | 2708 | reset_intel_generic_dev }, |
2692 | { 0 } | 2709 | { 0 } |
2693 | }; | 2710 | }; |
2711 | |||
2712 | int pci_dev_specific_reset(struct pci_dev *dev, int probe) | ||
2713 | { | ||
2714 | const struct pci_dev_reset_methods *i; | ||
2715 | |||
2716 | for (i = pci_dev_reset_methods; i->reset; i++) { | ||
2717 | if ((i->vendor == dev->vendor || | ||
2718 | i->vendor == (u16)PCI_ANY_ID) && | ||
2719 | (i->device == dev->device || | ||
2720 | i->device == (u16)PCI_ANY_ID)) | ||
2721 | return i->reset(dev, probe); | ||
2722 | } | ||
2723 | |||
2724 | return -ENOTTY; | ||
2725 | } | ||
2726 | |||
2694 | #else | 2727 | #else |
2695 | void pci_fixup_device(enum pci_fixup_pass pass, struct pci_dev *dev) {} | 2728 | void pci_fixup_device(enum pci_fixup_pass pass, struct pci_dev *dev) {} |
2729 | int pci_dev_specific_reset(struct pci_dev *dev, int probe) { return -ENOTTY; } | ||
2696 | #endif | 2730 | #endif |
2697 | EXPORT_SYMBOL(pci_fixup_device); | 2731 | EXPORT_SYMBOL(pci_fixup_device); |