2006-10-19 09:35:08

by Muli Ben-Yehuda

[permalink] [raw]
Subject: [PATCH] [x86-64] Calgary: increase PHB1 split transaction timeout

This patch increases the timeout for PCI split transactions on PHB1 on
the first Calgary to work around an issue with the aic94xx
adapter. Fixes kernel.org bugzilla #7180
(http://bugzilla.kernel.org/show_bug.cgi?id=7180)

Based on excellent debugging and a patch by Darrick J. Wong
<[email protected]>

Signed-off-by: Muli Ben-Yehuda <[email protected]>
Signed-off-by: Jon Mason <[email protected]>
Acked-by: Darrick J. Wong <[email protected]>

diff -r 3f7bc84201e7 -r 39faf4c673f9 arch/x86_64/kernel/pci-calgary.c
--- a/arch/x86_64/kernel/pci-calgary.c Wed Oct 18 09:14:19 2006 +0200
+++ b/arch/x86_64/kernel/pci-calgary.c Thu Oct 19 11:29:33 2006 +0200
@@ -52,7 +52,8 @@
#define ONE_BASED_CHASSIS_NUM 1

/* register offsets inside the host bridge space */
-#define PHB_CSR_OFFSET 0x0110
+#define CALGARY_CONFIG_REG 0x0108
+#define PHB_CSR_OFFSET 0x0110 /* Channel Status */
#define PHB_PLSSR_OFFSET 0x0120
#define PHB_CONFIG_RW_OFFSET 0x0160
#define PHB_IOBASE_BAR_LOW 0x0170
@@ -83,6 +84,8 @@
#define TAR_VALID 0x0000000000000008UL
/* CSR (Channel/DMA Status Register) */
#define CSR_AGENT_MASK 0xffe0ffff
+/* CCR (Calgary Configuration Register) */
+#define CCR_2SEC_TIMEOUT 0x000000000000000EUL

#define MAX_NUM_OF_PHBS 8 /* how many PHBs in total? */
#define MAX_NUM_CHASSIS 8 /* max number of chassis */
@@ -732,6 +735,38 @@ static void calgary_watchdog(unsigned lo
}
}

+static void __init calgary_increase_split_completion_timeout(void __iomem *bbar,
+ unsigned char busnum)
+{
+ u64 val64;
+ void __iomem *target;
+ unsigned long phb_shift = -1;
+ u64 mask;
+
+ switch (busno_to_phbid(busnum)) {
+ case 0: phb_shift = (63 - 19);
+ break;
+ case 1: phb_shift = (63 - 23);
+ break;
+ case 2: phb_shift = (63 - 27);
+ break;
+ case 3: phb_shift = (63 - 35);
+ break;
+ default:
+ BUG_ON(busno_to_phbid(busnum));
+ }
+
+ target = calgary_reg(bbar, CALGARY_CONFIG_REG);
+ val64 = be64_to_cpu(readq(target));
+
+ /* zero out this PHB's timer bits */
+ mask = ~(0xFUL << phb_shift);
+ val64 &= mask;
+ val64 |= (CCR_2SEC_TIMEOUT << phb_shift);
+ writeq(cpu_to_be64(val64), target);
+ readq(target); /* flush */
+}
+
static void __init calgary_enable_translation(struct pci_dev *dev)
{
u32 val32;
@@ -755,6 +790,13 @@ static void __init calgary_enable_transl

writel(cpu_to_be32(val32), target);
readl(target); /* flush */
+
+ /*
+ * Give split completion a longer timeout on bus 1 for aic94xx
+ * http://bugzilla.kernel.org/show_bug.cgi?id=7180
+ */
+ if (busnum == 1)
+ calgary_increase_split_completion_timeout(bbar, busnum);

init_timer(&tbl->watchdog_timer);
tbl->watchdog_timer.function = &calgary_watchdog;


2006-10-20 12:53:37

by Andi Kleen

[permalink] [raw]
Subject: Re: [PATCH] [x86-64] Calgary: increase PHB1 split transaction timeout

On Thursday 19 October 2006 11:35, Muli Ben-Yehuda wrote:
> This patch increases the timeout for PCI split transactions on PHB1 on
> the first Calgary to work around an issue with the aic94xx
> adapter. Fixes kernel.org bugzilla #7180
> (http://bugzilla.kernel.org/show_bug.cgi?id=7180)

Needed for .19 i guess?

-Andi

2006-10-20 13:18:33

by Muli Ben-Yehuda

[permalink] [raw]
Subject: Re: [PATCH] [x86-64] Calgary: increase PHB1 split transaction timeout

On Fri, Oct 20, 2006 at 02:53:25PM +0200, Andi Kleen wrote:
> On Thursday 19 October 2006 11:35, Muli Ben-Yehuda wrote:
> > This patch increases the timeout for PCI split transactions on PHB1 on
> > the first Calgary to work around an issue with the aic94xx
> > adapter. Fixes kernel.org bugzilla #7180
> > (http://bugzilla.kernel.org/show_bug.cgi?id=7180)
>
> Needed for .19 i guess?

That would be best, since it's a very low risk bug fix. It's not
critical though - it only hit one machine that we know of.

Thanks,
Muli