On 5/11/2025 10:10 PM, Nicholas Piggin wrote:
Group interrupts should not be taken from the backlog and presented
if they are precluded by CPPR.
Reviewed-by: Michael Kowal <[email protected]>
Thanks MAK
Fixes: 855434b3b8 ("ppc/xive2: Process group backlog when pushing an OS
context")
Signed-off-by: Nicholas Piggin <[email protected]>
---
hw/intc/xive2.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/hw/intc/xive2.c b/hw/intc/xive2.c
index 1971c05fa1..8ede95b671 100644
--- a/hw/intc/xive2.c
+++ b/hw/intc/xive2.c
@@ -845,7 +845,9 @@ static void xive2_tctx_need_resend(Xive2Router *xrtr,
XiveTCTX *tctx,
group_prio = xive2_presenter_backlog_scan(xptr, nvp_blk, nvp_idx,
first_group, &group_level);
regs[TM_LSMFB] = group_prio;
- if (regs[TM_LGS] && group_prio < backlog_prio) {
+ if (regs[TM_LGS] && group_prio < backlog_prio &&
+ group_prio < regs[TM_CPPR]) {
+
/* VP can take a group interrupt */
xive2_presenter_backlog_decr(xptr, nvp_blk, nvp_idx,
group_prio, group_level);