diff options
Diffstat (limited to 'drivers/pci/quirks.c')
-rw-r--r-- | drivers/pci/quirks.c | 46 |
1 files changed, 30 insertions, 16 deletions
diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 2a7521677541..51c4a4409e8c 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c | |||
@@ -2879,20 +2879,34 @@ DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, 0x65f9, quirk_intel_mc_errata); | |||
2879 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, 0x65fa, quirk_intel_mc_errata); | 2879 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, 0x65fa, quirk_intel_mc_errata); |
2880 | 2880 | ||
2881 | 2881 | ||
2882 | static void do_one_fixup_debug(void (*fn)(struct pci_dev *dev), struct pci_dev *dev) | 2882 | static ktime_t fixup_debug_start(struct pci_dev *dev, |
2883 | void (*fn)(struct pci_dev *dev)) | ||
2883 | { | 2884 | { |
2884 | ktime_t calltime, delta, rettime; | 2885 | ktime_t calltime = ktime_set(0, 0); |
2886 | |||
2887 | dev_dbg(&dev->dev, "calling %pF\n", fn); | ||
2888 | if (initcall_debug) { | ||
2889 | pr_debug("calling %pF @ %i for %s\n", | ||
2890 | fn, task_pid_nr(current), dev_name(&dev->dev)); | ||
2891 | calltime = ktime_get(); | ||
2892 | } | ||
2893 | |||
2894 | return calltime; | ||
2895 | } | ||
2896 | |||
2897 | static void fixup_debug_report(struct pci_dev *dev, ktime_t calltime, | ||
2898 | void (*fn)(struct pci_dev *dev)) | ||
2899 | { | ||
2900 | ktime_t delta, rettime; | ||
2885 | unsigned long long duration; | 2901 | unsigned long long duration; |
2886 | 2902 | ||
2887 | printk(KERN_DEBUG "calling %pF @ %i for %s\n", | 2903 | if (initcall_debug) { |
2888 | fn, task_pid_nr(current), dev_name(&dev->dev)); | 2904 | rettime = ktime_get(); |
2889 | calltime = ktime_get(); | 2905 | delta = ktime_sub(rettime, calltime); |
2890 | fn(dev); | 2906 | duration = (unsigned long long) ktime_to_ns(delta) >> 10; |
2891 | rettime = ktime_get(); | 2907 | pr_debug("pci fixup %pF returned after %lld usecs for %s\n", |
2892 | delta = ktime_sub(rettime, calltime); | 2908 | fn, duration, dev_name(&dev->dev)); |
2893 | duration = (unsigned long long) ktime_to_ns(delta) >> 10; | 2909 | } |
2894 | printk(KERN_DEBUG "pci fixup %pF returned after %lld usecs for %s\n", | ||
2895 | fn, duration, dev_name(&dev->dev)); | ||
2896 | } | 2910 | } |
2897 | 2911 | ||
2898 | /* | 2912 | /* |
@@ -2932,6 +2946,8 @@ DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_INTEL, 0x010a, disable_igfx_irq); | |||
2932 | static void pci_do_fixups(struct pci_dev *dev, struct pci_fixup *f, | 2946 | static void pci_do_fixups(struct pci_dev *dev, struct pci_fixup *f, |
2933 | struct pci_fixup *end) | 2947 | struct pci_fixup *end) |
2934 | { | 2948 | { |
2949 | ktime_t calltime; | ||
2950 | |||
2935 | for (; f < end; f++) | 2951 | for (; f < end; f++) |
2936 | if ((f->class == (u32) (dev->class >> f->class_shift) || | 2952 | if ((f->class == (u32) (dev->class >> f->class_shift) || |
2937 | f->class == (u32) PCI_ANY_ID) && | 2953 | f->class == (u32) PCI_ANY_ID) && |
@@ -2939,11 +2955,9 @@ static void pci_do_fixups(struct pci_dev *dev, struct pci_fixup *f, | |||
2939 | f->vendor == (u16) PCI_ANY_ID) && | 2955 | f->vendor == (u16) PCI_ANY_ID) && |
2940 | (f->device == dev->device || | 2956 | (f->device == dev->device || |
2941 | f->device == (u16) PCI_ANY_ID)) { | 2957 | f->device == (u16) PCI_ANY_ID)) { |
2942 | dev_dbg(&dev->dev, "calling %pF\n", f->hook); | 2958 | calltime = fixup_debug_start(dev, f->hook); |
2943 | if (initcall_debug) | 2959 | f->hook(dev); |
2944 | do_one_fixup_debug(f->hook, dev); | 2960 | fixup_debug_report(dev, calltime, f->hook); |
2945 | else | ||
2946 | f->hook(dev); | ||
2947 | } | 2961 | } |
2948 | } | 2962 | } |
2949 | 2963 | ||