aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kvm/i8254.c
diff options
context:
space:
mode:
authorRadim Krčmář <rkrcmar@redhat.com>2016-03-02 16:56:44 -0500
committerPaolo Bonzini <pbonzini@redhat.com>2016-03-04 03:29:58 -0500
commitb39c90b6560c4458d46cb243abea0dcb7bc126d1 (patch)
tree0504d13b96b7006735826f3fbbfbb5ac21bd4dc0 /arch/x86/kvm/i8254.c
parent09edea72b7f9fd8a8d26c1f7504d989b9773ee5e (diff)
KVM: i8254: remove unnecessary uses of PIT state lock
- kvm_create_pit had to lock only because it exposed kvm->arch.vpit very early, but initialization doesn't use kvm->arch.vpit since the last patch, so we can drop locking. - kvm_free_pit is only run after there are no users of KVM and therefore is the sole actor. - Locking in kvm_vm_ioctl_reinject doesn't do anything, because reinject is only protected at that place. - kvm_pit_reset isn't used anywhere and its locking can be dropped if we hide it. Removing useless locking allows to see what actually is being protected by PIT state lock (values accessible from the guest). 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.c9
1 files changed, 1 insertions, 8 deletions
diff --git a/arch/x86/kvm/i8254.c b/arch/x86/kvm/i8254.c
index 2afe09b054e7..b8582fbe4fcf 100644
--- a/arch/x86/kvm/i8254.c
+++ b/arch/x86/kvm/i8254.c
@@ -607,12 +607,11 @@ static int speaker_ioport_read(struct kvm_vcpu *vcpu,
607 return 0; 607 return 0;
608} 608}
609 609
610void kvm_pit_reset(struct kvm_pit *pit) 610static void kvm_pit_reset(struct kvm_pit *pit)
611{ 611{
612 int i; 612 int i;
613 struct kvm_kpit_channel_state *c; 613 struct kvm_kpit_channel_state *c;
614 614
615 mutex_lock(&pit->pit_state.lock);
616 pit->pit_state.flags = 0; 615 pit->pit_state.flags = 0;
617 for (i = 0; i < 3; i++) { 616 for (i = 0; i < 3; i++) {
618 c = &pit->pit_state.channels[i]; 617 c = &pit->pit_state.channels[i];
@@ -620,7 +619,6 @@ void kvm_pit_reset(struct kvm_pit *pit)
620 c->gate = (i != 2); 619 c->gate = (i != 2);
621 pit_load_count(pit, i, 0); 620 pit_load_count(pit, i, 0);
622 } 621 }
623 mutex_unlock(&pit->pit_state.lock);
624 622
625 kvm_pit_reset_reinject(pit); 623 kvm_pit_reset_reinject(pit);
626} 624}
@@ -663,7 +661,6 @@ struct kvm_pit *kvm_create_pit(struct kvm *kvm, u32 flags)
663 } 661 }
664 662
665 mutex_init(&pit->pit_state.lock); 663 mutex_init(&pit->pit_state.lock);
666 mutex_lock(&pit->pit_state.lock);
667 664
668 pid = get_pid(task_tgid(current)); 665 pid = get_pid(task_tgid(current));
669 pid_nr = pid_vnr(pid); 666 pid_nr = pid_vnr(pid);
@@ -673,7 +670,6 @@ struct kvm_pit *kvm_create_pit(struct kvm *kvm, u32 flags)
673 pit->worker_task = kthread_run(kthread_worker_fn, &pit->worker, 670 pit->worker_task = kthread_run(kthread_worker_fn, &pit->worker,
674 "kvm-pit/%d", pid_nr); 671 "kvm-pit/%d", pid_nr);
675 if (IS_ERR(pit->worker_task)) { 672 if (IS_ERR(pit->worker_task)) {
676 mutex_unlock(&pit->pit_state.lock);
677 kvm_free_irq_source_id(kvm, pit->irq_source_id); 673 kvm_free_irq_source_id(kvm, pit->irq_source_id);
678 kfree(pit); 674 kfree(pit);
679 return NULL; 675 return NULL;
@@ -689,7 +685,6 @@ struct kvm_pit *kvm_create_pit(struct kvm *kvm, u32 flags)
689 pit_state->irq_ack_notifier.irq_acked = kvm_pit_ack_irq; 685 pit_state->irq_ack_notifier.irq_acked = kvm_pit_ack_irq;
690 kvm_register_irq_ack_notifier(kvm, &pit_state->irq_ack_notifier); 686 kvm_register_irq_ack_notifier(kvm, &pit_state->irq_ack_notifier);
691 pit_state->reinject = true; 687 pit_state->reinject = true;
692 mutex_unlock(&pit->pit_state.lock);
693 688
694 kvm_pit_reset(pit); 689 kvm_pit_reset(pit);
695 690
@@ -737,13 +732,11 @@ void kvm_free_pit(struct kvm *kvm)
737 &kvm->arch.vpit->mask_notifier); 732 &kvm->arch.vpit->mask_notifier);
738 kvm_unregister_irq_ack_notifier(kvm, 733 kvm_unregister_irq_ack_notifier(kvm,
739 &kvm->arch.vpit->pit_state.irq_ack_notifier); 734 &kvm->arch.vpit->pit_state.irq_ack_notifier);
740 mutex_lock(&kvm->arch.vpit->pit_state.lock);
741 timer = &kvm->arch.vpit->pit_state.timer; 735 timer = &kvm->arch.vpit->pit_state.timer;
742 hrtimer_cancel(timer); 736 hrtimer_cancel(timer);
743 flush_kthread_work(&kvm->arch.vpit->expired); 737 flush_kthread_work(&kvm->arch.vpit->expired);
744 kthread_stop(kvm->arch.vpit->worker_task); 738 kthread_stop(kvm->arch.vpit->worker_task);
745 kvm_free_irq_source_id(kvm, kvm->arch.vpit->irq_source_id); 739 kvm_free_irq_source_id(kvm, kvm->arch.vpit->irq_source_id);
746 mutex_unlock(&kvm->arch.vpit->pit_state.lock);
747 kfree(kvm->arch.vpit); 740 kfree(kvm->arch.vpit);
748 } 741 }
749} 742}