* [PATCH -v2 00/11] PCI: quirk related clean up
@ 2012-02-24  7:46 Yinghai Lu
  2012-02-24  7:46 ` [PATCH 01/11] PCI: Add class support in quirk handling Yinghai Lu
                   ` (10 more replies)
  0 siblings, 11 replies; 13+ messages in thread
From: Yinghai Lu @ 2012-02-24  7:46 UTC (permalink / raw)
  To: Jesse Barnes; +Cc: linux-pci, linux-kernel, Yinghai Lu
After commit:
| commit 3209874a1da2c51c7325e601d9634189ee178ad6
| Author: Arjan van de Ven <arjan@infradead.org>
| Date:   Mon Jan 30 20:52:07 2012 -0800
|
|    PCI: Annotate PCI quirks in initcall_debug style
will have lots of print out for quirks when initcall_debug is specified.
It turns out most of them are not really called for the devices because
quirks itself will check class id and bail out early.
Try to put class into quirk declaration. So we could avoid dive into these
quirks.
could be found at:
        git://git.kernel.org/pub/scm/linux/kernel/git/yinghai/linux-yinghai.git for-pci5
4ace9ad: PCI: Use class for quirk for usb host controller fixup
cc60c7c: PCI: Use class for quirk for ti816x class fixup
85fa49c: PCI: Use class for quirk for intel e100 interrupt fixup
8e4b35b: PCI: Use class for quirk for netmos class fixup
7c4b5d6: PCI: Use class for quirk for legacy ATA NO_D3
176e7df: PCI: Use class for quirk for cardbus_legacy
c2c7107: PCI: Use class for quirk for host bridge mmio_always_on
6924d3b: PCI: Use class for quirk for pci_fixup_video
7133c84: PCI: Use class quirk for intel fix_transparent_bridge
bf9f6e6: PCI: Use class for quirk for via_no_dac
d2e6e88: PCI: Add class support in quirk handling
-v2: separate to small patches for different quirk according to Jesse.
Thanks
Yinghai
 arch/x86/kernel/pci-dma.c     |    5 ++-
 arch/x86/pci/fixup.c          |   12 +++----
 drivers/pci/quirks.c          |   61 +++++++++++++++++++++------------------
 drivers/usb/host/pci-quirks.c |    3 +-
 include/linux/pci.h           |   63 +++++++++++++++++++++++++++++++++-------
 5 files changed, 95 insertions(+), 49 deletions(-)
^ permalink raw reply	[flat|nested] 13+ messages in thread* [PATCH 01/11] PCI: Add class support in quirk handling 2012-02-24 7:46 [PATCH -v2 00/11] PCI: quirk related clean up Yinghai Lu @ 2012-02-24 7:46 ` Yinghai Lu 2012-02-24 22:35 ` Jesse Barnes 2012-02-24 7:46 ` [PATCH 02/11] PCI: Use class for quirk for via_no_dac Yinghai Lu ` (9 subsequent siblings) 10 siblings, 1 reply; 13+ messages in thread From: Yinghai Lu @ 2012-02-24 7:46 UTC (permalink / raw) To: Jesse Barnes; +Cc: linux-pci, linux-kernel, Yinghai Lu Recently there is new support to make quirk calling will report duration time. That will boot log get more print out with initcall_debug is specified. Found a lot of quirks are calling for not related devices. Reason is quirk frame do not support class handling. So quirk code have to use PCI_ANY_ID for vendor/device and let quirk code itself to check class inside the func. The patch add class and cls_shift into struct pci_fixup. Also update related macro to accept the class and shift. -v2: fix v1 that left over of sparated patch. -v3: according to Jesse, change cls to class, cls_shift, to class_shift. Signed-off-by: Yinghai Lu <yinghai@kernel.org> --- drivers/pci/quirks.c | 12 +++++---- include/linux/pci.h | 63 +++++++++++++++++++++++++++++++++++++++++-------- 2 files changed, 59 insertions(+), 16 deletions(-) diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index fb544d6..2b4b1ea 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -2961,17 +2961,19 @@ DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_INTEL, 0x010a, disable_igfx_irq); static void pci_do_fixups(struct pci_dev *dev, struct pci_fixup *f, struct pci_fixup *end) { - while (f < end) { - if ((f->vendor == dev->vendor || f->vendor == (u16) PCI_ANY_ID) && - (f->device == dev->device || f->device == (u16) PCI_ANY_ID)) { + for (; f < end; f++) + if ((f->class == (u32) (dev->class >> f->class_shift) || + f->class == (u32) PCI_ANY_ID) && + (f->vendor == dev->vendor || + f->vendor == (u16) PCI_ANY_ID) && + (f->device == dev->device || + f->device == (u16) PCI_ANY_ID)) { dev_dbg(&dev->dev, "calling %pF\n", f->hook); if (initcall_debug) do_one_fixup_debug(f->hook, dev); else f->hook(dev); } - f++; - } } extern struct pci_fixup __start_pci_fixups_early[]; diff --git a/include/linux/pci.h b/include/linux/pci.h index bcaa51c..ec32328 100644 --- a/include/linux/pci.h +++ b/include/linux/pci.h @@ -1364,7 +1364,10 @@ static inline void pci_resource_to_user(const struct pci_dev *dev, int bar, */ struct pci_fixup { - u16 vendor, device; /* You can use PCI_ANY_ID here of course */ + u16 vendor; /* You can use PCI_ANY_ID here of course */ + u16 device; /* You can use PCI_ANY_ID here of course */ + u32 class; /* You can use PCI_ANY_ID here too */ + unsigned int class_shift; /* should be 0, 8, 16 */ void (*hook)(struct pci_dev *dev); }; @@ -1379,30 +1382,68 @@ enum pci_fixup_pass { }; /* Anonymous variables would be nice... */ -#define DECLARE_PCI_FIXUP_SECTION(section, name, vendor, device, hook) \ - static const struct pci_fixup __pci_fixup_##name __used \ - __attribute__((__section__(#section))) = { vendor, device, hook }; +#define DECLARE_PCI_FIXUP_SECTION(section, name, vendor, device, class, \ + class_shift, hook) \ + static const struct pci_fixup const __pci_fixup_##name __used \ + __attribute__((__section__(#section), aligned((sizeof(void *))))) \ + = { vendor, device, class, class_shift, hook }; + +#define DECLARE_PCI_FIXUP_CLASS_EARLY(vendor, device, class, \ + class_shift, hook) \ + DECLARE_PCI_FIXUP_SECTION(.pci_fixup_early, \ + vendor##device##hook, vendor, device, class, class_shift, hook) +#define DECLARE_PCI_FIXUP_CLASS_HEADER(vendor, device, class, \ + class_shift, hook) \ + DECLARE_PCI_FIXUP_SECTION(.pci_fixup_header, \ + vendor##device##hook, vendor, device, class, class_shift, hook) +#define DECLARE_PCI_FIXUP_CLASS_FINAL(vendor, device, class, \ + class_shift, hook) \ + DECLARE_PCI_FIXUP_SECTION(.pci_fixup_final, \ + vendor##device##hook, vendor, device, class, class_shift, hook) +#define DECLARE_PCI_FIXUP_CLASS_ENABLE(vendor, device, class, \ + class_shift, hook) \ + DECLARE_PCI_FIXUP_SECTION(.pci_fixup_enable, \ + vendor##device##hook, vendor, device, class, class_shift, hook) +#define DECLARE_PCI_FIXUP_CLASS_RESUME(vendor, device, class, \ + class_shift, hook) \ + DECLARE_PCI_FIXUP_SECTION(.pci_fixup_resume, \ + resume##vendor##device##hook, vendor, device, class, \ + class_shift, hook) +#define DECLARE_PCI_FIXUP_CLASS_RESUME_EARLY(vendor, device, class, \ + class_shift, hook) \ + DECLARE_PCI_FIXUP_SECTION(.pci_fixup_resume_early, \ + resume_early##vendor##device##hook, vendor, device, \ + class, class_shift, hook) +#define DECLARE_PCI_FIXUP_CLASS_SUSPEND(vendor, device, class, \ + class_shift, hook) \ + DECLARE_PCI_FIXUP_SECTION(.pci_fixup_suspend, \ + suspend##vendor##device##hook, vendor, device, class, \ + class_shift, hook) + #define DECLARE_PCI_FIXUP_EARLY(vendor, device, hook) \ DECLARE_PCI_FIXUP_SECTION(.pci_fixup_early, \ - vendor##device##hook, vendor, device, hook) + vendor##device##hook, vendor, device, PCI_ANY_ID, 0, hook) #define DECLARE_PCI_FIXUP_HEADER(vendor, device, hook) \ DECLARE_PCI_FIXUP_SECTION(.pci_fixup_header, \ - vendor##device##hook, vendor, device, hook) + vendor##device##hook, vendor, device, PCI_ANY_ID, 0, hook) #define DECLARE_PCI_FIXUP_FINAL(vendor, device, hook) \ DECLARE_PCI_FIXUP_SECTION(.pci_fixup_final, \ - vendor##device##hook, vendor, device, hook) + vendor##device##hook, vendor, device, PCI_ANY_ID, 0, hook) #define DECLARE_PCI_FIXUP_ENABLE(vendor, device, hook) \ DECLARE_PCI_FIXUP_SECTION(.pci_fixup_enable, \ - vendor##device##hook, vendor, device, hook) + vendor##device##hook, vendor, device, PCI_ANY_ID, 0, hook) #define DECLARE_PCI_FIXUP_RESUME(vendor, device, hook) \ DECLARE_PCI_FIXUP_SECTION(.pci_fixup_resume, \ - resume##vendor##device##hook, vendor, device, hook) + resume##vendor##device##hook, vendor, device, \ + PCI_ANY_ID, 0, hook) #define DECLARE_PCI_FIXUP_RESUME_EARLY(vendor, device, hook) \ DECLARE_PCI_FIXUP_SECTION(.pci_fixup_resume_early, \ - resume_early##vendor##device##hook, vendor, device, hook) + resume_early##vendor##device##hook, vendor, device, \ + PCI_ANY_ID, 0, hook) #define DECLARE_PCI_FIXUP_SUSPEND(vendor, device, hook) \ DECLARE_PCI_FIXUP_SECTION(.pci_fixup_suspend, \ - suspend##vendor##device##hook, vendor, device, hook) + suspend##vendor##device##hook, vendor, device, \ + PCI_ANY_ID, 0, hook) #ifdef CONFIG_PCI_QUIRKS void pci_fixup_device(enum pci_fixup_pass pass, struct pci_dev *dev); -- 1.7.7 ^ permalink raw reply related [flat|nested] 13+ messages in thread
* Re: [PATCH 01/11] PCI: Add class support in quirk handling 2012-02-24 7:46 ` [PATCH 01/11] PCI: Add class support in quirk handling Yinghai Lu @ 2012-02-24 22:35 ` Jesse Barnes 0 siblings, 0 replies; 13+ messages in thread From: Jesse Barnes @ 2012-02-24 22:35 UTC (permalink / raw) To: Yinghai Lu; +Cc: linux-pci, linux-kernel [-- Attachment #1: Type: text/plain, Size: 829 bytes --] On Thu, 23 Feb 2012 23:46:49 -0800 Yinghai Lu <yinghai@kernel.org> wrote: > Recently there is new support to make quirk calling will report duration time. > That will boot log get more print out with initcall_debug is specified. > > Found a lot of quirks are calling for not related devices. > > Reason is quirk frame do not support class handling. So quirk code have to > use PCI_ANY_ID for vendor/device and let quirk code itself to check class > inside the func. > > The patch add class and cls_shift into struct pci_fixup. > Also update related macro to accept the class and shift. > > -v2: fix v1 that left over of sparated patch. > -v3: according to Jesse, change cls to class, cls_shift, to class_shift. > Applied these, thanks Yinghai. -- Jesse Barnes, Intel Open Source Technology Center [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 836 bytes --] ^ permalink raw reply [flat|nested] 13+ messages in thread
* [PATCH 02/11] PCI: Use class for quirk for via_no_dac 2012-02-24 7:46 [PATCH -v2 00/11] PCI: quirk related clean up Yinghai Lu 2012-02-24 7:46 ` [PATCH 01/11] PCI: Add class support in quirk handling Yinghai Lu @ 2012-02-24 7:46 ` Yinghai Lu 2012-02-24 7:46 ` [PATCH 03/11] PCI: Use class quirk for intel fix_transparent_bridge Yinghai Lu ` (8 subsequent siblings) 10 siblings, 0 replies; 13+ messages in thread From: Yinghai Lu @ 2012-02-24 7:46 UTC (permalink / raw) To: Jesse Barnes; +Cc: linux-pci, linux-kernel, Yinghai Lu Signed-off-by: Yinghai Lu <yinghai@kernel.org> --- arch/x86/kernel/pci-dma.c | 5 +++-- 1 files changed, 3 insertions(+), 2 deletions(-) diff --git a/arch/x86/kernel/pci-dma.c b/arch/x86/kernel/pci-dma.c index 1c4d769..28e5e06 100644 --- a/arch/x86/kernel/pci-dma.c +++ b/arch/x86/kernel/pci-dma.c @@ -262,10 +262,11 @@ rootfs_initcall(pci_iommu_init); static __devinit void via_no_dac(struct pci_dev *dev) { - if ((dev->class >> 8) == PCI_CLASS_BRIDGE_PCI && forbid_dac == 0) { + if (forbid_dac == 0) { dev_info(&dev->dev, "disabling DAC on VIA PCI bridge\n"); forbid_dac = 1; } } -DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_VIA, PCI_ANY_ID, via_no_dac); +DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_VENDOR_ID_VIA, PCI_ANY_ID, + PCI_CLASS_BRIDGE_PCI, 8, via_no_dac); #endif -- 1.7.7 ^ permalink raw reply related [flat|nested] 13+ messages in thread
* [PATCH 03/11] PCI: Use class quirk for intel fix_transparent_bridge 2012-02-24 7:46 [PATCH -v2 00/11] PCI: quirk related clean up Yinghai Lu 2012-02-24 7:46 ` [PATCH 01/11] PCI: Add class support in quirk handling Yinghai Lu 2012-02-24 7:46 ` [PATCH 02/11] PCI: Use class for quirk for via_no_dac Yinghai Lu @ 2012-02-24 7:46 ` Yinghai Lu 2012-02-24 7:46 ` [PATCH 04/11] PCI: Use class for quirk for pci_fixup_video Yinghai Lu ` (7 subsequent siblings) 10 siblings, 0 replies; 13+ messages in thread From: Yinghai Lu @ 2012-02-24 7:46 UTC (permalink / raw) To: Jesse Barnes; +Cc: linux-pci, linux-kernel, Yinghai Lu Signed-off-by: Yinghai Lu <yinghai@kernel.org> --- arch/x86/pci/fixup.c | 6 +++--- 1 files changed, 3 insertions(+), 3 deletions(-) diff --git a/arch/x86/pci/fixup.c b/arch/x86/pci/fixup.c index 6dd8955..24172ff 100644 --- a/arch/x86/pci/fixup.c +++ b/arch/x86/pci/fixup.c @@ -164,11 +164,11 @@ DECLARE_PCI_FIXUP_RESUME(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_8367_0, pci_fixup_ */ static void __devinit pci_fixup_transparent_bridge(struct pci_dev *dev) { - if ((dev->class >> 8) == PCI_CLASS_BRIDGE_PCI && - (dev->device & 0xff00) == 0x2400) + if ((dev->device & 0xff00) == 0x2400) dev->transparent = 1; } -DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, PCI_ANY_ID, pci_fixup_transparent_bridge); +DECLARE_PCI_FIXUP_CLASS_HEADER(PCI_VENDOR_ID_INTEL, PCI_ANY_ID, + PCI_CLASS_BRIDGE_PCI, 8, pci_fixup_transparent_bridge); /* * Fixup for C1 Halt Disconnect problem on nForce2 systems. -- 1.7.7 ^ permalink raw reply related [flat|nested] 13+ messages in thread
* [PATCH 04/11] PCI: Use class for quirk for pci_fixup_video 2012-02-24 7:46 [PATCH -v2 00/11] PCI: quirk related clean up Yinghai Lu ` (2 preceding siblings ...) 2012-02-24 7:46 ` [PATCH 03/11] PCI: Use class quirk for intel fix_transparent_bridge Yinghai Lu @ 2012-02-24 7:46 ` Yinghai Lu 2012-02-24 7:46 ` [PATCH 05/11] PCI: Use class for quirk for host bridge mmio_always_on Yinghai Lu ` (6 subsequent siblings) 10 siblings, 0 replies; 13+ messages in thread From: Yinghai Lu @ 2012-02-24 7:46 UTC (permalink / raw) To: Jesse Barnes; +Cc: linux-pci, linux-kernel, Yinghai Lu Signed-off-by: Yinghai Lu <yinghai@kernel.org> --- arch/x86/pci/fixup.c | 6 ++---- 1 files changed, 2 insertions(+), 4 deletions(-) diff --git a/arch/x86/pci/fixup.c b/arch/x86/pci/fixup.c index 24172ff..d0e6e40 100644 --- a/arch/x86/pci/fixup.c +++ b/arch/x86/pci/fixup.c @@ -322,9 +322,6 @@ static void __devinit pci_fixup_video(struct pci_dev *pdev) struct pci_bus *bus; u16 config; - if ((pdev->class >> 8) != PCI_CLASS_DISPLAY_VGA) - return; - /* Is VGA routed to us? */ bus = pdev->bus; while (bus) { @@ -353,7 +350,8 @@ static void __devinit pci_fixup_video(struct pci_dev *pdev) dev_printk(KERN_DEBUG, &pdev->dev, "Boot video device\n"); } } -DECLARE_PCI_FIXUP_FINAL(PCI_ANY_ID, PCI_ANY_ID, pci_fixup_video); +DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_ANY_ID, PCI_ANY_ID, + PCI_CLASS_DISPLAY_VGA, 8, pci_fixup_video); static const struct dmi_system_id __devinitconst msi_k8t_dmi_table[] = { -- 1.7.7 ^ permalink raw reply related [flat|nested] 13+ messages in thread
* [PATCH 05/11] PCI: Use class for quirk for host bridge mmio_always_on 2012-02-24 7:46 [PATCH -v2 00/11] PCI: quirk related clean up Yinghai Lu ` (3 preceding siblings ...) 2012-02-24 7:46 ` [PATCH 04/11] PCI: Use class for quirk for pci_fixup_video Yinghai Lu @ 2012-02-24 7:46 ` Yinghai Lu 2012-02-24 7:46 ` [PATCH 06/11] PCI: Use class for quirk for cardbus_legacy Yinghai Lu ` (5 subsequent siblings) 10 siblings, 0 replies; 13+ messages in thread From: Yinghai Lu @ 2012-02-24 7:46 UTC (permalink / raw) To: Jesse Barnes; +Cc: linux-pci, linux-kernel, Yinghai Lu Signed-off-by: Yinghai Lu <yinghai@kernel.org> --- drivers/pci/quirks.c | 6 +++--- 1 files changed, 3 insertions(+), 3 deletions(-) diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 2b4b1ea..007abec 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -102,10 +102,10 @@ DECLARE_PCI_FIXUP_HEADER(PCI_ANY_ID, PCI_ANY_ID, quirk_resource_alignment); */ static void __devinit quirk_mmio_always_on(struct pci_dev *dev) { - if ((dev->class >> 8) == PCI_CLASS_BRIDGE_HOST) - dev->mmio_always_on = 1; + dev->mmio_always_on = 1; } -DECLARE_PCI_FIXUP_EARLY(PCI_ANY_ID, PCI_ANY_ID, quirk_mmio_always_on); +DECLARE_PCI_FIXUP_CLASS_EARLY(PCI_ANY_ID, PCI_ANY_ID, + PCI_CLASS_BRIDGE_HOST, 8, quirk_mmio_always_on); /* The Mellanox Tavor device gives false positive parity errors * Mark this device with a broken_parity_status, to allow -- 1.7.7 ^ permalink raw reply related [flat|nested] 13+ messages in thread
* [PATCH 06/11] PCI: Use class for quirk for cardbus_legacy 2012-02-24 7:46 [PATCH -v2 00/11] PCI: quirk related clean up Yinghai Lu ` (4 preceding siblings ...) 2012-02-24 7:46 ` [PATCH 05/11] PCI: Use class for quirk for host bridge mmio_always_on Yinghai Lu @ 2012-02-24 7:46 ` Yinghai Lu 2012-02-24 7:46 ` [PATCH 07/11] PCI: Use class for quirk for legacy ATA NO_D3 Yinghai Lu ` (4 subsequent siblings) 10 siblings, 0 replies; 13+ messages in thread From: Yinghai Lu @ 2012-02-24 7:46 UTC (permalink / raw) To: Jesse Barnes; +Cc: linux-pci, linux-kernel, Yinghai Lu Signed-off-by: Yinghai Lu <yinghai@kernel.org> --- drivers/pci/quirks.c | 8 ++++---- 1 files changed, 4 insertions(+), 4 deletions(-) diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 007abec..f41e00d 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -1004,12 +1004,12 @@ DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C597_0, quirk_vt */ static void quirk_cardbus_legacy(struct pci_dev *dev) { - if ((PCI_CLASS_BRIDGE_CARDBUS << 8) ^ dev->class) - return; pci_write_config_dword(dev, PCI_CB_LEGACY_MODE_BASE, 0); } -DECLARE_PCI_FIXUP_FINAL(PCI_ANY_ID, PCI_ANY_ID, quirk_cardbus_legacy); -DECLARE_PCI_FIXUP_RESUME_EARLY(PCI_ANY_ID, PCI_ANY_ID, quirk_cardbus_legacy); +DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_ANY_ID, PCI_ANY_ID, + PCI_CLASS_BRIDGE_CARDBUS, 8, quirk_cardbus_legacy); +DECLARE_PCI_FIXUP_CLASS_RESUME_EARLY(PCI_ANY_ID, PCI_ANY_ID, + PCI_CLASS_BRIDGE_CARDBUS, 8, quirk_cardbus_legacy); /* * Following the PCI ordering rules is optional on the AMD762. I'm not -- 1.7.7 ^ permalink raw reply related [flat|nested] 13+ messages in thread
* [PATCH 07/11] PCI: Use class for quirk for legacy ATA NO_D3 2012-02-24 7:46 [PATCH -v2 00/11] PCI: quirk related clean up Yinghai Lu ` (5 preceding siblings ...) 2012-02-24 7:46 ` [PATCH 06/11] PCI: Use class for quirk for cardbus_legacy Yinghai Lu @ 2012-02-24 7:46 ` Yinghai Lu 2012-02-24 7:46 ` [PATCH 08/11] PCI: Use class for quirk for netmos class fixup Yinghai Lu ` (3 subsequent siblings) 10 siblings, 0 replies; 13+ messages in thread From: Yinghai Lu @ 2012-02-24 7:46 UTC (permalink / raw) To: Jesse Barnes; +Cc: linux-pci, linux-kernel, Yinghai Lu Signed-off-by: Yinghai Lu <yinghai@kernel.org> --- drivers/pci/quirks.c | 17 ++++++++++------- 1 files changed, 10 insertions(+), 7 deletions(-) diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index f41e00d..a860812 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -1166,17 +1166,20 @@ DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801CA_10, qui static void __devinit quirk_no_ata_d3(struct pci_dev *pdev) { - /* Quirk the legacy ATA devices only. The AHCI ones are ok */ - if ((pdev->class >> 8) == PCI_CLASS_STORAGE_IDE) - pdev->dev_flags |= PCI_DEV_FLAGS_NO_D3; + pdev->dev_flags |= PCI_DEV_FLAGS_NO_D3; } -DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_SERVERWORKS, PCI_ANY_ID, quirk_no_ata_d3); -DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_ATI, PCI_ANY_ID, quirk_no_ata_d3); +/* Quirk the legacy ATA devices only. The AHCI ones are ok */ +DECLARE_PCI_FIXUP_CLASS_EARLY(PCI_VENDOR_ID_SERVERWORKS, PCI_ANY_ID, + PCI_CLASS_STORAGE_IDE, 8, quirk_no_ata_d3); +DECLARE_PCI_FIXUP_CLASS_EARLY(PCI_VENDOR_ID_ATI, PCI_ANY_ID, + PCI_CLASS_STORAGE_IDE, 8, quirk_no_ata_d3); /* ALi loses some register settings that we cannot then restore */ -DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_AL, PCI_ANY_ID, quirk_no_ata_d3); +DECLARE_PCI_FIXUP_CLASS_EARLY(PCI_VENDOR_ID_AL, PCI_ANY_ID, + PCI_CLASS_STORAGE_IDE, 8, quirk_no_ata_d3); /* VIA comes back fine but we need to keep it alive or ACPI GTM failures occur when mode detecting */ -DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_VIA, PCI_ANY_ID, quirk_no_ata_d3); +DECLARE_PCI_FIXUP_CLASS_EARLY(PCI_VENDOR_ID_VIA, PCI_ANY_ID, + PCI_CLASS_STORAGE_IDE, 8, quirk_no_ata_d3); /* This was originally an Alpha specific thing, but it really fits here. * The i82375 PCI/EISA bridge appears as non-classified. Fix that. -- 1.7.7 ^ permalink raw reply related [flat|nested] 13+ messages in thread
* [PATCH 08/11] PCI: Use class for quirk for netmos class fixup 2012-02-24 7:46 [PATCH -v2 00/11] PCI: quirk related clean up Yinghai Lu ` (6 preceding siblings ...) 2012-02-24 7:46 ` [PATCH 07/11] PCI: Use class for quirk for legacy ATA NO_D3 Yinghai Lu @ 2012-02-24 7:46 ` Yinghai Lu 2012-02-24 7:46 ` [PATCH 09/11] PCI: Use class for quirk for intel e100 interrupt fixup Yinghai Lu ` (2 subsequent siblings) 10 siblings, 0 replies; 13+ messages in thread From: Yinghai Lu @ 2012-02-24 7:46 UTC (permalink / raw) To: Jesse Barnes; +Cc: linux-pci, linux-kernel, Yinghai Lu Signed-off-by: Yinghai Lu <yinghai@kernel.org> --- drivers/pci/quirks.c | 6 +++--- 1 files changed, 3 insertions(+), 3 deletions(-) diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index a860812..03e455a 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -1878,8 +1878,7 @@ static void __devinit quirk_netmos(struct pci_dev *dev) case PCI_DEVICE_ID_NETMOS_9745: case PCI_DEVICE_ID_NETMOS_9845: case PCI_DEVICE_ID_NETMOS_9855: - if ((dev->class >> 8) == PCI_CLASS_COMMUNICATION_SERIAL && - num_parallel) { + if (num_parallel) { dev_info(&dev->dev, "Netmos %04x (%u parallel, " "%u serial); changing class SERIAL to OTHER " "(use parport_serial)\n", @@ -1889,7 +1888,8 @@ static void __devinit quirk_netmos(struct pci_dev *dev) } } } -DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_NETMOS, PCI_ANY_ID, quirk_netmos); +DECLARE_PCI_FIXUP_CLASS_HEADER(PCI_VENDOR_ID_NETMOS, PCI_ANY_ID, + PCI_CLASS_COMMUNICATION_SERIAL, 8, quirk_netmos); static void __devinit quirk_e100_interrupt(struct pci_dev *dev) { -- 1.7.7 ^ permalink raw reply related [flat|nested] 13+ messages in thread
* [PATCH 09/11] PCI: Use class for quirk for intel e100 interrupt fixup 2012-02-24 7:46 [PATCH -v2 00/11] PCI: quirk related clean up Yinghai Lu ` (7 preceding siblings ...) 2012-02-24 7:46 ` [PATCH 08/11] PCI: Use class for quirk for netmos class fixup Yinghai Lu @ 2012-02-24 7:46 ` Yinghai Lu 2012-02-24 7:46 ` [PATCH 10/11] PCI: Use class for quirk for ti816x class fixup Yinghai Lu 2012-02-24 7:46 ` [PATCH 11/11] PCI: Use class for quirk for usb host controller fixup Yinghai Lu 10 siblings, 0 replies; 13+ messages in thread From: Yinghai Lu @ 2012-02-24 7:46 UTC (permalink / raw) To: Jesse Barnes; +Cc: linux-pci, linux-kernel, Yinghai Lu Signed-off-by: Yinghai Lu <yinghai@kernel.org> --- drivers/pci/quirks.c | 3 ++- 1 files changed, 2 insertions(+), 1 deletions(-) diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 03e455a..91733a2 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -1957,7 +1957,8 @@ static void __devinit quirk_e100_interrupt(struct pci_dev *dev) iounmap(csr); } -DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_INTEL, PCI_ANY_ID, quirk_e100_interrupt); +DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_VENDOR_ID_INTEL, PCI_ANY_ID, + PCI_CLASS_NETWORK_ETHERNET, 8, quirk_e100_interrupt); /* * The 82575 and 82598 may experience data corruption issues when transitioning -- 1.7.7 ^ permalink raw reply related [flat|nested] 13+ messages in thread
* [PATCH 10/11] PCI: Use class for quirk for ti816x class fixup 2012-02-24 7:46 [PATCH -v2 00/11] PCI: quirk related clean up Yinghai Lu ` (8 preceding siblings ...) 2012-02-24 7:46 ` [PATCH 09/11] PCI: Use class for quirk for intel e100 interrupt fixup Yinghai Lu @ 2012-02-24 7:46 ` Yinghai Lu 2012-02-24 7:46 ` [PATCH 11/11] PCI: Use class for quirk for usb host controller fixup Yinghai Lu 10 siblings, 0 replies; 13+ messages in thread From: Yinghai Lu @ 2012-02-24 7:46 UTC (permalink / raw) To: Jesse Barnes; +Cc: linux-pci, linux-kernel, Yinghai Lu Signed-off-by: Yinghai Lu <yinghai@kernel.org> --- drivers/pci/quirks.c | 9 ++++----- 1 files changed, 4 insertions(+), 5 deletions(-) diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 91733a2..e198589 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -2822,12 +2822,11 @@ DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_INTEL, 0x3c28, vtd_mask_spec_errors); static void __devinit fixup_ti816x_class(struct pci_dev* dev) { /* TI 816x devices do not have class code set when in PCIe boot mode */ - if (dev->class == PCI_CLASS_NOT_DEFINED) { - dev_info(&dev->dev, "Setting PCI class for 816x PCIe device\n"); - dev->class = PCI_CLASS_MULTIMEDIA_VIDEO; - } + dev_info(&dev->dev, "Setting PCI class for 816x PCIe device\n"); + dev->class = PCI_CLASS_MULTIMEDIA_VIDEO; } -DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_TI, 0xb800, fixup_ti816x_class); +DECLARE_PCI_FIXUP_CLASS_EARLY(PCI_VENDOR_ID_TI, 0xb800, + PCI_CLASS_NOT_DEFINED, 0, fixup_ti816x_class); /* Some PCIe devices do not work reliably with the claimed maximum * payload size supported. -- 1.7.7 ^ permalink raw reply related [flat|nested] 13+ messages in thread
* [PATCH 11/11] PCI: Use class for quirk for usb host controller fixup 2012-02-24 7:46 [PATCH -v2 00/11] PCI: quirk related clean up Yinghai Lu ` (9 preceding siblings ...) 2012-02-24 7:46 ` [PATCH 10/11] PCI: Use class for quirk for ti816x class fixup Yinghai Lu @ 2012-02-24 7:46 ` Yinghai Lu 10 siblings, 0 replies; 13+ messages in thread From: Yinghai Lu @ 2012-02-24 7:46 UTC (permalink / raw) To: Jesse Barnes; +Cc: linux-pci, linux-kernel, Yinghai Lu Signed-off-by: Yinghai Lu <yinghai@kernel.org> --- drivers/usb/host/pci-quirks.c | 3 ++- 1 files changed, 2 insertions(+), 1 deletions(-) diff --git a/drivers/usb/host/pci-quirks.c b/drivers/usb/host/pci-quirks.c index caf8742..30f3aa0 100644 --- a/drivers/usb/host/pci-quirks.c +++ b/drivers/usb/host/pci-quirks.c @@ -876,4 +876,5 @@ static void __devinit quirk_usb_early_handoff(struct pci_dev *pdev) else if (pdev->class == PCI_CLASS_SERIAL_USB_XHCI) quirk_usb_handoff_xhci(pdev); } -DECLARE_PCI_FIXUP_FINAL(PCI_ANY_ID, PCI_ANY_ID, quirk_usb_early_handoff); +DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_ANY_ID, PCI_ANY_ID, + PCI_CLASS_SERIAL_USB, 8, quirk_usb_early_handoff); -- 1.7.7 ^ permalink raw reply related [flat|nested] 13+ messages in thread
end of thread, other threads:[~2012-02-24 22:35 UTC | newest] Thread overview: 13+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2012-02-24 7:46 [PATCH -v2 00/11] PCI: quirk related clean up Yinghai Lu 2012-02-24 7:46 ` [PATCH 01/11] PCI: Add class support in quirk handling Yinghai Lu 2012-02-24 22:35 ` Jesse Barnes 2012-02-24 7:46 ` [PATCH 02/11] PCI: Use class for quirk for via_no_dac Yinghai Lu 2012-02-24 7:46 ` [PATCH 03/11] PCI: Use class quirk for intel fix_transparent_bridge Yinghai Lu 2012-02-24 7:46 ` [PATCH 04/11] PCI: Use class for quirk for pci_fixup_video Yinghai Lu 2012-02-24 7:46 ` [PATCH 05/11] PCI: Use class for quirk for host bridge mmio_always_on Yinghai Lu 2012-02-24 7:46 ` [PATCH 06/11] PCI: Use class for quirk for cardbus_legacy Yinghai Lu 2012-02-24 7:46 ` [PATCH 07/11] PCI: Use class for quirk for legacy ATA NO_D3 Yinghai Lu 2012-02-24 7:46 ` [PATCH 08/11] PCI: Use class for quirk for netmos class fixup Yinghai Lu 2012-02-24 7:46 ` [PATCH 09/11] PCI: Use class for quirk for intel e100 interrupt fixup Yinghai Lu 2012-02-24 7:46 ` [PATCH 10/11] PCI: Use class for quirk for ti816x class fixup Yinghai Lu 2012-02-24 7:46 ` [PATCH 11/11] PCI: Use class for quirk for usb host controller fixup Yinghai Lu
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).