lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Date: Mon, 29 Jan 2007 15:50:43 -0800 From: Stephen Hemminger <shemminger@...ux-foundation.org> To: unlisted-recipients:; (no To-header on input) Cc: Frédéric Riss <frederic.riss@...il.com>, Linus Torvalds <torvalds@...ux-foundation.org>, Linux Kernel Mailing List <linux-kernel@...r.kernel.org>, Jeff Garzik <jeff@...zik.org>, netdev@...r.kernel.org Subject: [PATCH] block MSI on Sony The Sony VAIO BIOS resets to INTx on resume. This happens after device resume, so device irq's get misrouted. This hack turns off MSI on this laptop, until power management initialization order is fixed. Signed-off-by: Stephen Hemminger <shemminger@...ux-foundation.org> --- drivers/pci/quirks.c | 32 ++++++++++++++++++++++++++++++++ 1 files changed, 32 insertions(+), 0 deletions(-) diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index ef882a8..9a64179 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -21,6 +21,7 @@ #include <linux/pci.h> #include <linux/init.h> #include <linux/delay.h> #include <linux/acpi.h> +#include <linux/dmi.h> #include "pci.h" /* The Mellanox Tavor device gives false positive parity errors @@ -1779,6 +1780,37 @@ static void __devinit quirk_nvidia_ck804 } DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_NVIDIA, PCI_DEVICE_ID_NVIDIA_CK804_PCIE, quirk_nvidia_ck804_msi_ht_cap); + +/* On Sony VAIO laptop, BIOS resets MSI during resume. */ +static __initdata struct dmi_system_id sony_dmi_table[] = { + { + .ident = "Sony Vaio", + .matches = { + DMI_MATCH(DMI_SYS_VENDOR, "Sony Corporation"), + DMI_MATCH(DMI_PRODUCT_NAME, "PCG-"), + }, + }, + { + .ident = "Sony Vaio", + .matches = { + DMI_MATCH(DMI_SYS_VENDOR, "Sony Corporation"), + DMI_MATCH(DMI_PRODUCT_NAME, "VGN-"), + }, + }, + { } +}; + +static void __init quirk_sony_msi(struct pci_dev *dev) +{ + if (!dmi_check_system(sony_dmi_table)) + return; + + pci_msi_quirk = 1; + printk(KERN_WARNING "PCI: MSI sony quirk detected. pci_msi_quirk set.\n"); +} +DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801BA_6, + quirk_sony_msi); + #endif /* CONFIG_PCI_MSI */ EXPORT_SYMBOL(pcie_mch_quirk); -- 1.4.1 - To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to majordomo@...r.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists