small bug fixes

-----BEGIN PGP SIGNATURE-----
 
 iQFIBAABCAAyFiEE8TM4V0tmI4mGbHaCv/vSX3jHroMFAmQRo3EUHHBib256aW5p
 QHJlZGhhdC5jb20ACgkQv/vSX3jHroO7wwgAp2IGW9TDAElFgPZ3n8XyoJ6Lnr6i
 Le3L+fQbYuy6uCU7zkboWgFqqNRLkd1nxHPkRgxb5oJ8pnXLCrdG+2d9UDgfMFqZ
 3ankE+De70j7f7r0M5Ifmfyf7QHhNhnbuguoovi6S9bdJ5aO2nZmsm/T41Bth/uU
 SKx+SCVMzpPGLJv0iZishw2seZj0h9QBgyitsE8MdLjnhe5KD4XOWs4+E263pb6L
 G6ai7T++vQSRqCQ8YVBr7Az41vkvzuqkybAXFTl/QLd2rVQROAqoOpn+wPq4cH46
 xf6LscXqE9lrWr/UJnDPNiyKmsY5baLyB6Ri/rQn8VvTyfyHC9JtDoDclQ==
 =mnvI
 -----END PGP SIGNATURE-----

Merge tag 'for-upstream' of https://gitlab.com/bonzini/qemu into staging

small bug fixes

# -----BEGIN PGP SIGNATURE-----
#
# iQFIBAABCAAyFiEE8TM4V0tmI4mGbHaCv/vSX3jHroMFAmQRo3EUHHBib256aW5p
# QHJlZGhhdC5jb20ACgkQv/vSX3jHroO7wwgAp2IGW9TDAElFgPZ3n8XyoJ6Lnr6i
# Le3L+fQbYuy6uCU7zkboWgFqqNRLkd1nxHPkRgxb5oJ8pnXLCrdG+2d9UDgfMFqZ
# 3ankE+De70j7f7r0M5Ifmfyf7QHhNhnbuguoovi6S9bdJ5aO2nZmsm/T41Bth/uU
# SKx+SCVMzpPGLJv0iZishw2seZj0h9QBgyitsE8MdLjnhe5KD4XOWs4+E263pb6L
# G6ai7T++vQSRqCQ8YVBr7Az41vkvzuqkybAXFTl/QLd2rVQROAqoOpn+wPq4cH46
# xf6LscXqE9lrWr/UJnDPNiyKmsY5baLyB6Ri/rQn8VvTyfyHC9JtDoDclQ==
# =mnvI
# -----END PGP SIGNATURE-----
# gpg: Signature made Wed 15 Mar 2023 10:52:33 GMT
# gpg:                using RSA key F13338574B662389866C7682BFFBD25F78C7AE83
# gpg:                issuer "pbonzini@redhat.com"
# gpg: Good signature from "Paolo Bonzini <bonzini@gnu.org>" [full]
# gpg:                 aka "Paolo Bonzini <pbonzini@redhat.com>" [full]
# Primary key fingerprint: 46F5 9FBD 57D6 12E7 BFD4  E2F7 7E15 100C CD36 69B1
#      Subkey fingerprint: F133 3857 4B66 2389 866C  7682 BFFB D25F 78C7 AE83

* tag 'for-upstream' of https://gitlab.com/bonzini/qemu:
  vl: defuse PID file path resolve error
  hw/intc/ioapic: Update KVM routes before redelivering IRQ, on RTE update
  docs/devel: clarify further the semantics of RMW operations
  Fix build without CONFIG_XEN_EMU

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
Peter Maydell 2023-03-15 17:19:41 +00:00
commit be4033d76e
4 changed files with 20 additions and 12 deletions

View File

@ -469,13 +469,19 @@ and memory barriers, and the equivalents in QEMU:
In QEMU, the second kind is named ``atomic_OP_fetch``. In QEMU, the second kind is named ``atomic_OP_fetch``.
- different atomic read-modify-write operations in Linux imply - different atomic read-modify-write operations in Linux imply
a different set of memory barriers; in QEMU, all of them enforce a different set of memory barriers. In QEMU, all of them enforce
sequential consistency. sequential consistency: there is a single order in which the
program sees them happen.
- in QEMU, ``qatomic_read()`` and ``qatomic_set()`` do not participate in - however, according to the C11 memory model that QEMU uses, this order
the ordering enforced by read-modify-write operations. does not propagate to other memory accesses on either side of the
This is because QEMU uses the C11 memory model. The following example read-modify-write operation. As far as those are concerned, the
is correct in Linux but not in QEMU: operation consist of just a load-acquire followed by a store-release.
Stores that precede the RMW operation, and loads that follow it, can
still be reordered and will happen *in the middle* of the read-modify-write
operation!
Therefore, the following example is correct in Linux but not in QEMU:
+----------------------------------+--------------------------------+ +----------------------------------+--------------------------------+
| Linux (correct) | QEMU (incorrect) | | Linux (correct) | QEMU (incorrect) |

View File

@ -405,6 +405,7 @@ ioapic_mem_write(void *opaque, hwaddr addr, uint64_t val,
s->ioredtbl[index] |= ro_bits; s->ioredtbl[index] |= ro_bits;
s->irq_eoi[index] = 0; s->irq_eoi[index] = 0;
ioapic_fix_edge_remote_irr(&s->ioredtbl[index]); ioapic_fix_edge_remote_irr(&s->ioredtbl[index]);
ioapic_update_kvm_routes(s);
ioapic_service(s); ioapic_service(s);
} }
} }
@ -417,8 +418,6 @@ ioapic_mem_write(void *opaque, hwaddr addr, uint64_t val,
ioapic_eoi_broadcast(val); ioapic_eoi_broadcast(val);
break; break;
} }
ioapic_update_kvm_routes(s);
} }
static const MemoryRegionOps ioapic_io_ops = { static const MemoryRegionOps ioapic_io_ops = {

View File

@ -2465,10 +2465,11 @@ static void qemu_maybe_daemonize(const char *pid_file)
pid_file_realpath = g_malloc0(PATH_MAX); pid_file_realpath = g_malloc0(PATH_MAX);
if (!realpath(pid_file, pid_file_realpath)) { if (!realpath(pid_file, pid_file_realpath)) {
error_report("cannot resolve PID file path: %s: %s", if (errno != ENOENT) {
pid_file, strerror(errno)); warn_report("not removing PID file on exit: cannot resolve PID "
unlink(pid_file); "file path: %s: %s", pid_file, strerror(errno));
exit(1); }
return;
} }
qemu_unlink_pidfile_notifier = (struct UnlinkPidfileNotifier) { qemu_unlink_pidfile_notifier = (struct UnlinkPidfileNotifier) {

View File

@ -4991,6 +4991,7 @@ MemTxAttrs kvm_arch_post_run(CPUState *cpu, struct kvm_run *run)
kvm_rate_limit_on_bus_lock(); kvm_rate_limit_on_bus_lock();
} }
#ifdef CONFIG_XEN_EMU
/* /*
* If the callback is asserted as a GSI (or PCI INTx) then check if * If the callback is asserted as a GSI (or PCI INTx) then check if
* vcpu_info->evtchn_upcall_pending has been cleared, and deassert * vcpu_info->evtchn_upcall_pending has been cleared, and deassert
@ -5001,6 +5002,7 @@ MemTxAttrs kvm_arch_post_run(CPUState *cpu, struct kvm_run *run)
if (x86_cpu->env.xen_callback_asserted) { if (x86_cpu->env.xen_callback_asserted) {
kvm_xen_maybe_deassert_callback(cpu); kvm_xen_maybe_deassert_callback(cpu);
} }
#endif
/* We need to protect the apic state against concurrent accesses from /* We need to protect the apic state against concurrent accesses from
* different threads in case the userspace irqchip is used. */ * different threads in case the userspace irqchip is used. */