paravirt-spinlocks.c 925 B

123456789101112131415161718192021222324252627282930313233343536
  1. /*
  2. * Split spinlock implementation out into its own file, so it can be
  3. * compiled in a FTRACE-compatible way.
  4. */
  5. #include <linux/spinlock.h>
  6. #include <linux/export.h>
  7. #include <linux/jump_label.h>
  8. #include <asm/paravirt.h>
  9. __visible void __native_queued_spin_unlock(struct qspinlock *lock)
  10. {
  11. native_queued_spin_unlock(lock);
  12. }
  13. PV_CALLEE_SAVE_REGS_THUNK(__native_queued_spin_unlock);
  14. bool pv_is_native_spin_unlock(void)
  15. {
  16. return pv_lock_ops.queued_spin_unlock.func ==
  17. __raw_callee_save___native_queued_spin_unlock;
  18. }
  19. struct pv_lock_ops pv_lock_ops = {
  20. #ifdef CONFIG_SMP
  21. .queued_spin_lock_slowpath = native_queued_spin_lock_slowpath,
  22. .queued_spin_unlock = PV_CALLEE_SAVE(__native_queued_spin_unlock),
  23. .wait = paravirt_nop,
  24. .kick = paravirt_nop,
  25. #endif /* SMP */
  26. };
  27. EXPORT_SYMBOL(pv_lock_ops);
  28. struct static_key paravirt_ticketlocks_enabled = STATIC_KEY_INIT_FALSE;
  29. EXPORT_SYMBOL(paravirt_ticketlocks_enabled);