goto after_clear_sn;
        }
 
-       /* The full case.  */
+       /* The full case.  Set the new destination and clear SN. */
+       dest = cpu_physical_id(cpu);
+       if (!x2apic_mode)
+               dest = (dest << 8) & 0xFF00;
+
        do {
                old.control = new.control = READ_ONCE(pi_desc->control);
 
-               dest = cpu_physical_id(cpu);
-
-               if (x2apic_mode)
-                       new.ndst = dest;
-               else
-                       new.ndst = (dest << 8) & 0xFF00;
-
+               new.ndst = dest;
                new.sn = 0;
        } while (cmpxchg64(&pi_desc->control, old.control,
                           new.control) != old.control);
        struct pi_desc old, new;
        unsigned int dest;
 
+       dest = cpu_physical_id(vcpu->cpu);
+       if (!x2apic_mode)
+               dest = (dest << 8) & 0xFF00;
+
        do {
                old.control = new.control = READ_ONCE(pi_desc->control);
                WARN(old.nv != POSTED_INTR_WAKEUP_VECTOR,
                     "Wakeup handler not enabled while the VCPU is blocked\n");
 
-               dest = cpu_physical_id(vcpu->cpu);
-
-               if (x2apic_mode)
-                       new.ndst = dest;
-               else
-                       new.ndst = (dest << 8) & 0xFF00;
+               new.ndst = dest;
 
                /* set 'NV' to 'notification vector' */
                new.nv = POSTED_INTR_VECTOR;