diff options
| author | Greg Kurz | 2021-11-09 19:35:22 +0100 |
|---|---|---|
| committer | Paolo Bonzini | 2021-11-10 13:20:15 +0100 |
| commit | ef149763a8fcce70b85dfda27cc1222ecf765750 (patch) | |
| tree | b63ade31a861723451db40bb192d9f060c5f3066 /accel | |
| parent | target/i386: sgx: mark device not user creatable (diff) | |
| download | qemu-ef149763a8fcce70b85dfda27cc1222ecf765750.tar.gz qemu-ef149763a8fcce70b85dfda27cc1222ecf765750.tar.xz qemu-ef149763a8fcce70b85dfda27cc1222ecf765750.zip | |
rcu: Introduce force_rcu notifier
The drain_rcu_call() function can be blocked as long as an RCU reader
stays in a read-side critical section. This is typically what happens
when a TCG vCPU is executing a busy loop. It can deadlock the QEMU
monitor as reported in https://gitlab.com/qemu-project/qemu/-/issues/650 .
This can be avoided by allowing drain_rcu_call() to enforce an RCU grace
period. Since each reader might need to do specific actions to end a
read-side critical section, do it with notifiers.
Prepare ground for this by adding a notifier list to the RCU reader
struct and use it in wait_for_readers() if drain_rcu_call() is in
progress. An API is added for readers to register their notifiers.
This is largely based on a draft from Paolo Bonzini.
Suggested-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Greg Kurz <groug@kaod.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20211109183523.47726-2-groug@kaod.org>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'accel')
0 files changed, 0 insertions, 0 deletions
