Kristen Accardi <[EMAIL PROTECTED]> wrote:
>
> ...
> On the 6700/6702 PXH part, a MSI may get corrupted if an ACPI hotplug
> driver and SHPC driver in MSI mode are used together.  This patch will
> prevent MSI from being enabled for the SHPC.  
> 
> I made this patch more generic than just shpc because I thought it was
> possible that other devices in the system might need to add themselves
> to the msi black list.
> 
> diff -uprN -X linux-2.6.13-rc4/Documentation/dontdiff 
> linux-2.6.13-rc4/drivers/pci/msi.c linux-2.6.13-rc4-pxhquirk/drivers/pci/msi.c
> --- linux-2.6.13-rc4/drivers/pci/msi.c        2005-07-28 15:44:44.000000000 
> -0700
> +++ linux-2.6.13-rc4-pxhquirk/drivers/pci/msi.c       2005-08-05 
> 11:38:00.000000000 -0700
> @@ -38,6 +38,32 @@ int vector_irq[NR_VECTORS] = { [0 ... NR
>  u8 irq_vector[NR_IRQ_VECTORS] = { FIRST_DEVICE_VECTOR , 0 };
>  #endif
>  
> +
> +LIST_HEAD(msi_quirk_list);
> +

Can't this have static scope?

> +struct msi_quirk 
> +{
> +     struct list_head list;
> +     struct pci_dev *dev;
> +};

We normally do

        struct msi_quirk {

> +
> +int msi_add_quirk(struct pci_dev *dev)
> +{
> +     struct msi_quirk *quirk;
> +
> +     quirk = (struct msi_quirk *) kmalloc(sizeof(*quirk), GFP_KERNEL);

kmalloc() returns void*, hence no typecast is needed.  In fact it's
undesirable because the cast defeats all typechecking.

> +     if (!quirk)
> +             return -ENOMEM;
> +     
> +     INIT_LIST_HEAD(&quirk->list);
> +     quirk->dev = dev;
> +     list_add(&quirk->list, &msi_quirk_list);
> +     return 0;
> +}

Does the list not need any locking?

> --- linux-2.6.13-rc4/drivers/pci/quirks.c     2005-07-28 15:44:44.000000000 
> -0700
> +++ linux-2.6.13-rc4-pxhquirk/drivers/pci/quirks.c    2005-08-05 
> 11:54:15.000000000 -0700
> @@ -21,6 +21,10 @@
>  #include <linux/acpi.h>
>  #include "pci.h"
>  
> +
> +void disable_msi_mode(struct pci_dev *dev, int pos, int type);
> +int msi_add_quirk(struct pci_dev *dev);
> +

Please put these declarations in a .h file which is visible to the
implementations and to all users.

> +static void __devinit quirk_pcie_pxh(struct pci_dev *dev)
> +{
> +     disable_msi_mode(dev, pci_find_capability(dev, PCI_CAP_ID_MSI),
> +                                     PCI_CAP_ID_MSI);
> +     if (!msi_add_quirk(dev)) 
> +             printk(KERN_WARNING "PCI: PXH quirk detected, disabling MSI for 
> SHPC device\n");
> +     else {
> +             pci_msi_quirk = 1;
> +             printk(KERN_WARNING "PCI: PXH quirk detected, unable to disable 
> MSI for SHPC device, disabling MSI for all devices\n");
> +     }

Some people use 80-column xterms.   Break the strings up thusly:

                printk(KERN_WARNING "PCI: PXH quirk detected, disabling "
                                "MSI for SHPC device\n");


-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to