diff options
| -rw-r--r-- | virt/kvm/kvm_main.c | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c index 30b36368fcdf..904d7b7bd780 100644 --- a/virt/kvm/kvm_main.c +++ b/virt/kvm/kvm_main.c | |||
| @@ -105,10 +105,11 @@ static void ack_flush(void *_completed) | |||
| 105 | 105 | ||
| 106 | void kvm_flush_remote_tlbs(struct kvm *kvm) | 106 | void kvm_flush_remote_tlbs(struct kvm *kvm) |
| 107 | { | 107 | { |
| 108 | int i, cpu; | 108 | int i, cpu, me; |
| 109 | cpumask_t cpus; | 109 | cpumask_t cpus; |
| 110 | struct kvm_vcpu *vcpu; | 110 | struct kvm_vcpu *vcpu; |
| 111 | 111 | ||
| 112 | me = get_cpu(); | ||
| 112 | cpus_clear(cpus); | 113 | cpus_clear(cpus); |
| 113 | for (i = 0; i < KVM_MAX_VCPUS; ++i) { | 114 | for (i = 0; i < KVM_MAX_VCPUS; ++i) { |
| 114 | vcpu = kvm->vcpus[i]; | 115 | vcpu = kvm->vcpus[i]; |
| @@ -117,21 +118,24 @@ void kvm_flush_remote_tlbs(struct kvm *kvm) | |||
| 117 | if (test_and_set_bit(KVM_REQ_TLB_FLUSH, &vcpu->requests)) | 118 | if (test_and_set_bit(KVM_REQ_TLB_FLUSH, &vcpu->requests)) |
| 118 | continue; | 119 | continue; |
| 119 | cpu = vcpu->cpu; | 120 | cpu = vcpu->cpu; |
| 120 | if (cpu != -1 && cpu != raw_smp_processor_id()) | 121 | if (cpu != -1 && cpu != me) |
| 121 | cpu_set(cpu, cpus); | 122 | cpu_set(cpu, cpus); |
| 122 | } | 123 | } |
| 123 | if (cpus_empty(cpus)) | 124 | if (cpus_empty(cpus)) |
| 124 | return; | 125 | goto out; |
| 125 | ++kvm->stat.remote_tlb_flush; | 126 | ++kvm->stat.remote_tlb_flush; |
| 126 | smp_call_function_mask(cpus, ack_flush, NULL, 1); | 127 | smp_call_function_mask(cpus, ack_flush, NULL, 1); |
| 128 | out: | ||
| 129 | put_cpu(); | ||
| 127 | } | 130 | } |
| 128 | 131 | ||
| 129 | void kvm_reload_remote_mmus(struct kvm *kvm) | 132 | void kvm_reload_remote_mmus(struct kvm *kvm) |
| 130 | { | 133 | { |
| 131 | int i, cpu; | 134 | int i, cpu, me; |
| 132 | cpumask_t cpus; | 135 | cpumask_t cpus; |
| 133 | struct kvm_vcpu *vcpu; | 136 | struct kvm_vcpu *vcpu; |
| 134 | 137 | ||
| 138 | me = get_cpu(); | ||
| 135 | cpus_clear(cpus); | 139 | cpus_clear(cpus); |
| 136 | for (i = 0; i < KVM_MAX_VCPUS; ++i) { | 140 | for (i = 0; i < KVM_MAX_VCPUS; ++i) { |
| 137 | vcpu = kvm->vcpus[i]; | 141 | vcpu = kvm->vcpus[i]; |
| @@ -140,12 +144,14 @@ void kvm_reload_remote_mmus(struct kvm *kvm) | |||
| 140 | if (test_and_set_bit(KVM_REQ_MMU_RELOAD, &vcpu->requests)) | 144 | if (test_and_set_bit(KVM_REQ_MMU_RELOAD, &vcpu->requests)) |
| 141 | continue; | 145 | continue; |
| 142 | cpu = vcpu->cpu; | 146 | cpu = vcpu->cpu; |
| 143 | if (cpu != -1 && cpu != raw_smp_processor_id()) | 147 | if (cpu != -1 && cpu != me) |
| 144 | cpu_set(cpu, cpus); | 148 | cpu_set(cpu, cpus); |
| 145 | } | 149 | } |
| 146 | if (cpus_empty(cpus)) | 150 | if (cpus_empty(cpus)) |
| 147 | return; | 151 | goto out; |
| 148 | smp_call_function_mask(cpus, ack_flush, NULL, 1); | 152 | smp_call_function_mask(cpus, ack_flush, NULL, 1); |
| 153 | out: | ||
| 154 | put_cpu(); | ||
| 149 | } | 155 | } |
| 150 | 156 | ||
| 151 | 157 | ||
