diff options
| -rw-r--r-- | arch/x86/xen/spinlock.c | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/arch/x86/xen/spinlock.c b/arch/x86/xen/spinlock.c index 47ae032f8d97..8b54603ce816 100644 --- a/arch/x86/xen/spinlock.c +++ b/arch/x86/xen/spinlock.c | |||
| @@ -367,6 +367,13 @@ void __cpuinit xen_init_lock_cpu(int cpu) | |||
| 367 | WARN(per_cpu(lock_kicker_irq, cpu) > 0, "spinlock on CPU%d exists on IRQ%d!\n", | 367 | WARN(per_cpu(lock_kicker_irq, cpu) > 0, "spinlock on CPU%d exists on IRQ%d!\n", |
| 368 | cpu, per_cpu(lock_kicker_irq, cpu)); | 368 | cpu, per_cpu(lock_kicker_irq, cpu)); |
| 369 | 369 | ||
| 370 | /* | ||
| 371 | * See git commit f10cd522c5fbfec9ae3cc01967868c9c2401ed23 | ||
| 372 | * (xen: disable PV spinlocks on HVM) | ||
| 373 | */ | ||
| 374 | if (xen_hvm_domain()) | ||
| 375 | return; | ||
| 376 | |||
| 370 | name = kasprintf(GFP_KERNEL, "spinlock%d", cpu); | 377 | name = kasprintf(GFP_KERNEL, "spinlock%d", cpu); |
| 371 | irq = bind_ipi_to_irqhandler(XEN_SPIN_UNLOCK_VECTOR, | 378 | irq = bind_ipi_to_irqhandler(XEN_SPIN_UNLOCK_VECTOR, |
| 372 | cpu, | 379 | cpu, |
| @@ -385,12 +392,26 @@ void __cpuinit xen_init_lock_cpu(int cpu) | |||
| 385 | 392 | ||
| 386 | void xen_uninit_lock_cpu(int cpu) | 393 | void xen_uninit_lock_cpu(int cpu) |
| 387 | { | 394 | { |
| 395 | /* | ||
| 396 | * See git commit f10cd522c5fbfec9ae3cc01967868c9c2401ed23 | ||
| 397 | * (xen: disable PV spinlocks on HVM) | ||
| 398 | */ | ||
| 399 | if (xen_hvm_domain()) | ||
| 400 | return; | ||
| 401 | |||
| 388 | unbind_from_irqhandler(per_cpu(lock_kicker_irq, cpu), NULL); | 402 | unbind_from_irqhandler(per_cpu(lock_kicker_irq, cpu), NULL); |
| 389 | per_cpu(lock_kicker_irq, cpu) = -1; | 403 | per_cpu(lock_kicker_irq, cpu) = -1; |
| 390 | } | 404 | } |
| 391 | 405 | ||
| 392 | void __init xen_init_spinlocks(void) | 406 | void __init xen_init_spinlocks(void) |
| 393 | { | 407 | { |
| 408 | /* | ||
| 409 | * See git commit f10cd522c5fbfec9ae3cc01967868c9c2401ed23 | ||
| 410 | * (xen: disable PV spinlocks on HVM) | ||
| 411 | */ | ||
| 412 | if (xen_hvm_domain()) | ||
| 413 | return; | ||
| 414 | |||
| 394 | BUILD_BUG_ON(sizeof(struct xen_spinlock) > sizeof(arch_spinlock_t)); | 415 | BUILD_BUG_ON(sizeof(struct xen_spinlock) > sizeof(arch_spinlock_t)); |
| 395 | 416 | ||
| 396 | pv_lock_ops.spin_is_locked = xen_spin_is_locked; | 417 | pv_lock_ops.spin_is_locked = xen_spin_is_locked; |
