Skip to content

Commit 2fb1e94

Browse files
sambltcrkrcmar
authored andcommitted
KVM: PPC: Book3S: Fix server always zero from kvmppc_xive_get_xive()
In KVM's XICS-on-XIVE emulation, kvmppc_xive_get_xive() returns the value of state->guest_server as "server". However, this value is not set by it's counterpart kvmppc_xive_set_xive(). When the guest uses this interface to migrate interrupts away from a CPU that is going offline, it sees all interrupts as belonging to CPU 0, so they are left assigned to (now) offline CPUs. This patch removes the guest_server field from the state, and returns act_server in it's place (that is, the CPU actually handling the interrupt, which may differ from the one requested). Fixes: 5af5099 ("KVM: PPC: Book3S HV: Native usage of the XIVE interrupt controller") Cc: stable@vger.kernel.org Signed-off-by: Sam Bobroff <sam.bobroff@au1.ibm.com> Acked-by: Benjamin Herrenschmidt <benh@kernel.crashing.org> Signed-off-by: Radim Krčmář <rkrcmar@redhat.com>
1 parent 9e66317 commit 2fb1e94

File tree

2 files changed

+2
-4
lines changed

2 files changed

+2
-4
lines changed

arch/powerpc/kvm/book3s_xive.c

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -622,7 +622,7 @@ int kvmppc_xive_get_xive(struct kvm *kvm, u32 irq, u32 *server,
622622
return -EINVAL;
623623
state = &sb->irq_state[idx];
624624
arch_spin_lock(&sb->lock);
625-
*server = state->guest_server;
625+
*server = state->act_server;
626626
*priority = state->guest_priority;
627627
arch_spin_unlock(&sb->lock);
628628

@@ -1331,7 +1331,7 @@ static int xive_get_source(struct kvmppc_xive *xive, long irq, u64 addr)
13311331
xive->saved_src_count++;
13321332

13331333
/* Convert saved state into something compatible with xics */
1334-
val = state->guest_server;
1334+
val = state->act_server;
13351335
prio = state->saved_scan_prio;
13361336

13371337
if (prio == MASKED) {
@@ -1507,7 +1507,6 @@ static int xive_set_source(struct kvmppc_xive *xive, long irq, u64 addr)
15071507
/* First convert prio and mark interrupt as untargetted */
15081508
act_prio = xive_prio_from_guest(guest_prio);
15091509
state->act_priority = MASKED;
1510-
state->guest_server = server;
15111510

15121511
/*
15131512
* We need to drop the lock due to the mutex below. Hopefully

arch/powerpc/kvm/book3s_xive.h

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -35,7 +35,6 @@ struct kvmppc_xive_irq_state {
3535
struct xive_irq_data *pt_data; /* XIVE Pass-through associated data */
3636

3737
/* Targetting as set by guest */
38-
u32 guest_server; /* Current guest selected target */
3938
u8 guest_priority; /* Guest set priority */
4039
u8 saved_priority; /* Saved priority when masking */
4140

0 commit comments

Comments
 (0)