diff options
| author | Pallipadi, Venkatesh <venkatesh.pallipadi@intel.com> | 2010-01-21 14:09:52 -0500 |
|---|---|---|
| committer | Ingo Molnar <mingo@elte.hu> | 2010-01-23 00:21:58 -0500 |
| commit | 73472a46b5b28116b145fb5fc05242c1aa8e1461 (patch) | |
| tree | bbcb6174edb2ea3c94e64bbfe7f92f3f128d96d3 | |
| parent | 3a5fc0e40cb467e692737bc798bc99773c81e1e2 (diff) | |
x86: Disable HPET MSI on ATI SB700/SB800
HPET MSI on platforms with ATI SB700/SB800 as they seem to have some
side-effects on floppy DMA. Do not use HPET MSI on such platforms.
Original problem report from Mark Hounschell
http://lkml.indiana.edu/hypermail/linux/kernel/0912.2/01118.html
[ This patch needs to go to stable as well. But, there are some
conflicts that prevents the patch from going as is. I can
rebase/resubmit to stable once the patch goes upstream.
hpa: still Cc:'ing stable@ as an FYI. ]
Tested-by: Mark Hounschell <markh@compro.net>
Signed-off-by: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>
Cc: <stable@kernel.org>
LKML-Reference: <20100121190952.GA32523@linux-os.sc.intel.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
| -rw-r--r-- | arch/x86/include/asm/hpet.h | 1 | ||||
| -rw-r--r-- | arch/x86/kernel/hpet.c | 8 | ||||
| -rw-r--r-- | arch/x86/kernel/quirks.c | 13 |
3 files changed, 22 insertions, 0 deletions
diff --git a/arch/x86/include/asm/hpet.h b/arch/x86/include/asm/hpet.h index 5d89fd2a3690..1d5c08a1bdfd 100644 --- a/arch/x86/include/asm/hpet.h +++ b/arch/x86/include/asm/hpet.h | |||
| @@ -67,6 +67,7 @@ extern unsigned long hpet_address; | |||
| 67 | extern unsigned long force_hpet_address; | 67 | extern unsigned long force_hpet_address; |
| 68 | extern u8 hpet_blockid; | 68 | extern u8 hpet_blockid; |
| 69 | extern int hpet_force_user; | 69 | extern int hpet_force_user; |
| 70 | extern u8 hpet_msi_disable; | ||
| 70 | extern int is_hpet_enabled(void); | 71 | extern int is_hpet_enabled(void); |
| 71 | extern int hpet_enable(void); | 72 | extern int hpet_enable(void); |
| 72 | extern void hpet_disable(void); | 73 | extern void hpet_disable(void); |
diff --git a/arch/x86/kernel/hpet.c b/arch/x86/kernel/hpet.c index ba6e65884603..ad80a1c718c6 100644 --- a/arch/x86/kernel/hpet.c +++ b/arch/x86/kernel/hpet.c | |||
| @@ -34,6 +34,8 @@ | |||
| 34 | */ | 34 | */ |
| 35 | unsigned long hpet_address; | 35 | unsigned long hpet_address; |
| 36 | u8 hpet_blockid; /* OS timer block num */ | 36 | u8 hpet_blockid; /* OS timer block num */ |
| 37 | u8 hpet_msi_disable; | ||
| 38 | |||
| 37 | #ifdef CONFIG_PCI_MSI | 39 | #ifdef CONFIG_PCI_MSI |
| 38 | static unsigned long hpet_num_timers; | 40 | static unsigned long hpet_num_timers; |
| 39 | #endif | 41 | #endif |
| @@ -596,6 +598,9 @@ static void hpet_msi_capability_lookup(unsigned int start_timer) | |||
| 596 | unsigned int num_timers_used = 0; | 598 | unsigned int num_timers_used = 0; |
| 597 | int i; | 599 | int i; |
| 598 | 600 | ||
| 601 | if (hpet_msi_disable) | ||
| 602 | return; | ||
| 603 | |||
| 599 | if (boot_cpu_has(X86_FEATURE_ARAT)) | 604 | if (boot_cpu_has(X86_FEATURE_ARAT)) |
| 600 | return; | 605 | return; |
| 601 | id = hpet_readl(HPET_ID); | 606 | id = hpet_readl(HPET_ID); |
| @@ -928,6 +933,9 @@ static __init int hpet_late_init(void) | |||
| 928 | hpet_reserve_platform_timers(hpet_readl(HPET_ID)); | 933 | hpet_reserve_platform_timers(hpet_readl(HPET_ID)); |
| 929 | hpet_print_config(); | 934 | hpet_print_config(); |
| 930 | 935 | ||
| 936 | if (hpet_msi_disable) | ||
| 937 | return 0; | ||
| 938 | |||
| 931 | if (boot_cpu_has(X86_FEATURE_ARAT)) | 939 | if (boot_cpu_has(X86_FEATURE_ARAT)) |
| 932 | return 0; | 940 | return 0; |
| 933 | 941 | ||
diff --git a/arch/x86/kernel/quirks.c b/arch/x86/kernel/quirks.c index 18093d7498f0..12e9feaa2f7a 100644 --- a/arch/x86/kernel/quirks.c +++ b/arch/x86/kernel/quirks.c | |||
| @@ -491,6 +491,19 @@ void force_hpet_resume(void) | |||
| 491 | break; | 491 | break; |
| 492 | } | 492 | } |
| 493 | } | 493 | } |
| 494 | |||
| 495 | /* | ||
| 496 | * HPET MSI on some boards (ATI SB700/SB800) has side effect on | ||
| 497 | * floppy DMA. Disable HPET MSI on such platforms. | ||
| 498 | */ | ||
| 499 | static void force_disable_hpet_msi(struct pci_dev *unused) | ||
| 500 | { | ||
| 501 | hpet_msi_disable = 1; | ||
| 502 | } | ||
| 503 | |||
| 504 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_ATI, PCI_DEVICE_ID_ATI_SBX00_SMBUS, | ||
| 505 | force_disable_hpet_msi); | ||
| 506 | |||
| 494 | #endif | 507 | #endif |
| 495 | 508 | ||
| 496 | #if defined(CONFIG_PCI) && defined(CONFIG_NUMA) | 509 | #if defined(CONFIG_PCI) && defined(CONFIG_NUMA) |
