diff options
author | Radim Krčmář <rkrcmar@redhat.com> | 2016-03-02 16:56:52 -0500 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2016-03-04 03:30:25 -0500 |
commit | a0aace5ac0efdb2bcb71e10d9c9ca6a851fa59f9 (patch) | |
tree | f91033e50e172a450daeff324a4dc9f1e880fa1f /arch/x86/kvm/i8254.c | |
parent | ab4c14763b434d48bc7732e475ff4d5b6b9d3e3b (diff) |
KVM: i8254: turn kvm_kpit_state.reinject into atomic_t
Document possible races between readers and concurrent update to the
ioctl.
Suggested-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Radim Krčmář <rkrcmar@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'arch/x86/kvm/i8254.c')
-rw-r--r-- | arch/x86/kvm/i8254.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/arch/x86/kvm/i8254.c b/arch/x86/kvm/i8254.c index 68af4445d51d..219ef855aae5 100644 --- a/arch/x86/kvm/i8254.c +++ b/arch/x86/kvm/i8254.c | |||
@@ -264,7 +264,7 @@ static void pit_do_work(struct kthread_work *work) | |||
264 | int i; | 264 | int i; |
265 | struct kvm_kpit_state *ps = &pit->pit_state; | 265 | struct kvm_kpit_state *ps = &pit->pit_state; |
266 | 266 | ||
267 | if (ps->reinject && !atomic_xchg(&ps->irq_ack, 0)) | 267 | if (atomic_read(&ps->reinject) && !atomic_xchg(&ps->irq_ack, 0)) |
268 | return; | 268 | return; |
269 | 269 | ||
270 | kvm_set_irq(kvm, pit->irq_source_id, 0, 1, false); | 270 | kvm_set_irq(kvm, pit->irq_source_id, 0, 1, false); |
@@ -289,7 +289,7 @@ static enum hrtimer_restart pit_timer_fn(struct hrtimer *data) | |||
289 | struct kvm_kpit_state *ps = container_of(data, struct kvm_kpit_state, timer); | 289 | struct kvm_kpit_state *ps = container_of(data, struct kvm_kpit_state, timer); |
290 | struct kvm_pit *pt = pit_state_to_pit(ps); | 290 | struct kvm_pit *pt = pit_state_to_pit(ps); |
291 | 291 | ||
292 | if (ps->reinject) | 292 | if (atomic_read(&ps->reinject)) |
293 | atomic_inc(&ps->pending); | 293 | atomic_inc(&ps->pending); |
294 | 294 | ||
295 | queue_kthread_work(&pt->worker, &pt->expired); | 295 | queue_kthread_work(&pt->worker, &pt->expired); |
@@ -312,7 +312,7 @@ void kvm_pit_set_reinject(struct kvm_pit *pit, bool reinject) | |||
312 | struct kvm_kpit_state *ps = &pit->pit_state; | 312 | struct kvm_kpit_state *ps = &pit->pit_state; |
313 | struct kvm *kvm = pit->kvm; | 313 | struct kvm *kvm = pit->kvm; |
314 | 314 | ||
315 | if (ps->reinject == reinject) | 315 | if (atomic_read(&ps->reinject) == reinject) |
316 | return; | 316 | return; |
317 | 317 | ||
318 | if (reinject) { | 318 | if (reinject) { |
@@ -325,7 +325,7 @@ void kvm_pit_set_reinject(struct kvm_pit *pit, bool reinject) | |||
325 | kvm_unregister_irq_mask_notifier(kvm, 0, &pit->mask_notifier); | 325 | kvm_unregister_irq_mask_notifier(kvm, 0, &pit->mask_notifier); |
326 | } | 326 | } |
327 | 327 | ||
328 | ps->reinject = reinject; | 328 | atomic_set(&ps->reinject, reinject); |
329 | } | 329 | } |
330 | 330 | ||
331 | static void create_pit_timer(struct kvm_pit *pit, u32 val, int is_period) | 331 | static void create_pit_timer(struct kvm_pit *pit, u32 val, int is_period) |