aboutsummaryrefslogtreecommitdiffstats
path: root/arch/ia64/kvm
diff options
context:
space:
mode:
Diffstat (limited to 'arch/ia64/kvm')
-rw-r--r--arch/ia64/kvm/kvm-ia64.c29
1 files changed, 14 insertions, 15 deletions
diff --git a/arch/ia64/kvm/kvm-ia64.c b/arch/ia64/kvm/kvm-ia64.c
index d1f7bcda2c7f..5c766bd82b05 100644
--- a/arch/ia64/kvm/kvm-ia64.c
+++ b/arch/ia64/kvm/kvm-ia64.c
@@ -337,13 +337,12 @@ static struct kvm_vcpu *lid_to_vcpu(struct kvm *kvm, unsigned long id,
337{ 337{
338 union ia64_lid lid; 338 union ia64_lid lid;
339 int i; 339 int i;
340 struct kvm_vcpu *vcpu;
340 341
341 for (i = 0; i < atomic_read(&kvm->online_vcpus); i++) { 342 kvm_for_each_vcpu(i, vcpu, kvm) {
342 if (kvm->vcpus[i]) { 343 lid.val = VCPU_LID(vcpu);
343 lid.val = VCPU_LID(kvm->vcpus[i]); 344 if (lid.id == id && lid.eid == eid)
344 if (lid.id == id && lid.eid == eid) 345 return vcpu;
345 return kvm->vcpus[i];
346 }
347 } 346 }
348 347
349 return NULL; 348 return NULL;
@@ -409,21 +408,21 @@ static int handle_global_purge(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
409 struct kvm *kvm = vcpu->kvm; 408 struct kvm *kvm = vcpu->kvm;
410 struct call_data call_data; 409 struct call_data call_data;
411 int i; 410 int i;
411 struct kvm_vcpu *vcpui;
412 412
413 call_data.ptc_g_data = p->u.ptc_g_data; 413 call_data.ptc_g_data = p->u.ptc_g_data;
414 414
415 for (i = 0; i < atomic_read(&kvm->online_vcpus); i++) { 415 kvm_for_each_vcpu(i, vcpui, kvm) {
416 if (!kvm->vcpus[i] || kvm->vcpus[i]->arch.mp_state == 416 if (vcpui->arch.mp_state == KVM_MP_STATE_UNINITIALIZED ||
417 KVM_MP_STATE_UNINITIALIZED || 417 vcpu == vcpui)
418 vcpu == kvm->vcpus[i])
419 continue; 418 continue;
420 419
421 if (waitqueue_active(&kvm->vcpus[i]->wq)) 420 if (waitqueue_active(&vcpui->wq))
422 wake_up_interruptible(&kvm->vcpus[i]->wq); 421 wake_up_interruptible(&vcpui->wq);
423 422
424 if (kvm->vcpus[i]->cpu != -1) { 423 if (vcpui->cpu != -1) {
425 call_data.vcpu = kvm->vcpus[i]; 424 call_data.vcpu = vcpui;
426 smp_call_function_single(kvm->vcpus[i]->cpu, 425 smp_call_function_single(vcpui->cpu,
427 vcpu_global_purge, &call_data, 1); 426 vcpu_global_purge, &call_data, 1);
428 } else 427 } else
429 printk(KERN_WARNING"kvm: Uninit vcpu received ipi!\n"); 428 printk(KERN_WARNING"kvm: Uninit vcpu received ipi!\n");