[Skiboot] [PATCH v3] xive/p9: Enforce thread enablement before TIMA accesses
Cédric Le Goater
clg at kaod.org
Wed Aug 5 03:01:11 AEST 2020
To activate the HW thread context ring, and its associated thread
interrupt registers, a thread needs to raise the VT bit in word2. This
requires access to the TIMA and this access is only granted if the
thread was first enabled at the XIVE IC level.
This is done in a sequence in xive_cpu_callin() but there is a chance
that the accesses done on the TIMA do not see the update of the enable
register.
To make sure that the enablement has completed, add an extra load on
the PC_THREAD_EN_REGx register. This guarantees that the TIMA accesses
will see the latest state of the enable register.
Signed-off-by: Cédric Le Goater <clg at kaod.org>
---
v3: Commit log improvement
v2: Fix compilation
hw/xive.c | 15 +++++++++++++++
1 file changed, 15 insertions(+)
diff --git a/hw/xive.c b/hw/xive.c
index 8d6095c02e7e..f393695b8ce4 100644
--- a/hw/xive.c
+++ b/hw/xive.c
@@ -2741,6 +2741,7 @@ static void xive_reset_enable_thread(struct cpu_thread *c)
struct proc_chip *chip = get_chip(c->chip_id);
struct xive *x = chip->xive;
uint32_t fc, bit;
+ uint64_t enable;
/* Get fused core number */
fc = (c->pir >> 3) & 0xf;
@@ -2752,9 +2753,23 @@ static void xive_reset_enable_thread(struct cpu_thread *c)
if (fc < 8) {
xive_regw(x, PC_THREAD_EN_REG0_CLR, PPC_BIT(bit));
xive_regw(x, PC_THREAD_EN_REG0_SET, PPC_BIT(bit));
+
+ /*
+ * To guarantee that the TIMA accesses will see the
+ * latest state of the enable register, add an extra
+ * load on PC_THREAD_EN_REG.
+ */
+ enable = xive_regr(x, PC_THREAD_EN_REG0);
+ if (!(enable & PPC_BIT(bit)))
+ xive_cpu_err(c, "Failed to enable thread\n");
} else {
xive_regw(x, PC_THREAD_EN_REG1_CLR, PPC_BIT(bit));
xive_regw(x, PC_THREAD_EN_REG1_SET, PPC_BIT(bit));
+
+ /* Same as above */
+ enable = xive_regr(x, PC_THREAD_EN_REG1);
+ if (!(enable & PPC_BIT(bit)))
+ xive_cpu_err(c, "Failed to enable thread\n");
}
}
--
2.25.4
More information about the Skiboot
mailing list