public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] Update MCP55 quirk to not affect non HyperTransport variants
@ 2010-12-08 14:47 Neil Horman
  2010-12-08 16:44 ` Vivek Goyal
                   ` (2 more replies)
  0 siblings, 3 replies; 6+ messages in thread
From: Neil Horman @ 2010-12-08 14:47 UTC (permalink / raw)
  To: linux-kernel; +Cc: Neil Horman, linux-pci, kexec, Vivek Goyal, Jesse Barnes

I wrote this quirk awhile ago to properly setup MCP55 chips on hypertransport
busses so that interrupts reached whatever cpu happend to boot the kdump kernel.
while that works well, it was recently shown to me that a a non-hypertransport
variant of the MCP55 exists, and on those system the register that this quirk
manipulates causes hangs if you write to it.  Since the quirk was only meant to
handle errors found on MCP55 chips that have a HT interface, this patch adds a
filter to make sure the chip is an HT capable before making the needed register
adjustment.  This lets the broken MCP55s work with kdump while not breaking the
non-HT variants.

Resolves https://bugzilla.kernel.org/show_bug.cgi?id=23952

Tested successfully by the reporter and myself.

Reported-by: Mathieu Bérard <mathieu@mberard.eu>
CC: linux-pci@vger.kernel.org
CC: kexec@lists.infradead.org
CC: Vivek Goyal <vgoyal@redhat.com>
CC: Jesse Barnes <jbarnes@virtuousgeek.org>
Signed-off-by: Neil Horman <nhorman@tuxdriver.com>
---
 drivers/pci/quirks.c |    3 +++
 1 files changed, 3 insertions(+), 0 deletions(-)

diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c
index 6f9350c..313c0bd 100644
--- a/drivers/pci/quirks.c
+++ b/drivers/pci/quirks.c
@@ -2329,6 +2329,9 @@ static void __devinit nvbridge_check_legacy_irq_routing(struct pci_dev *dev)
 {
 	u32 cfg;
 
+	if (!pci_find_capability(dev, PCI_CAP_ID_HT))
+		return;
+
 	pci_read_config_dword(dev, 0x74, &cfg);
 
 	if (cfg & ((1 << 2) | (1 << 15))) {
-- 
1.7.2.3


^ permalink raw reply related	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2010-12-10 20:32 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-12-08 14:47 [PATCH] Update MCP55 quirk to not affect non HyperTransport variants Neil Horman
2010-12-08 16:44 ` Vivek Goyal
2010-12-08 17:21   ` Neil Horman
2010-12-09 23:40 ` Andrew Morton
2010-12-10 11:54   ` Neil Horman
2010-12-10 20:32 ` Jesse Barnes

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox