evtchn/fifo: use stable fields when recording "last queue" information
authorJan Beulich <jbeulich@suse.com>
Fri, 2 Oct 2020 06:37:35 +0000 (08:37 +0200)
committerJan Beulich <jbeulich@suse.com>
Fri, 2 Oct 2020 06:37:35 +0000 (08:37 +0200)
Both evtchn->priority and evtchn->notify_vcpu_id could change behind the
back of evtchn_fifo_set_pending(), as for it - in the case of
interdomain channels - only the remote side's per-channel lock is held.
Neither the queue's priority nor the vCPU's vcpu_id fields have similar
properties, so they seem better suited for the purpose. In particular
they reflect the respective evtchn fields' values at the time they were
used to determine queue and vCPU.

Signed-off-by: Jan Beulich <jbeulich@suse.com>
Reviewed-by: Julien Grall <jgrall@amazon.com>
Reviewed-by: Paul Durrant <paul@xen.org>
xen/common/event_fifo.c

index 68d0c7a6323a4090f5ecae57c427409caa5004d2..27ab3a1c3f161436039aee2ab2753988f227d08f 100644 (file)
@@ -225,8 +225,8 @@ static void evtchn_fifo_set_pending(struct vcpu *v, struct evtchn *evtchn)
         /* Moved to a different queue? */
         if ( old_q != q )
         {
-            evtchn->last_vcpu_id = evtchn->notify_vcpu_id;
-            evtchn->last_priority = evtchn->priority;
+            evtchn->last_vcpu_id = v->vcpu_id;
+            evtchn->last_priority = q->priority;
 
             spin_unlock_irqrestore(&old_q->lock, flags);
             spin_lock_irqsave(&q->lock, flags);