rcutree.h 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * Read-Copy Update mechanism for mutual exclusion (tree-based version)
  4. *
  5. * Copyright IBM Corporation, 2008
  6. *
  7. * Author: Dipankar Sarma <dipankar@in.ibm.com>
  8. * Paul E. McKenney <paulmck@linux.ibm.com> Hierarchical algorithm
  9. *
  10. * Based on the original work by Paul McKenney <paulmck@linux.ibm.com>
  11. * and inputs from Rusty Russell, Andrea Arcangeli and Andi Kleen.
  12. *
  13. * For detailed explanation of Read-Copy Update mechanism see -
  14. * Documentation/RCU
  15. */
  16. #ifndef __LINUX_RCUTREE_H
  17. #define __LINUX_RCUTREE_H
  18. void rcu_softirq_qs(void);
  19. void rcu_note_context_switch(bool preempt);
  20. int rcu_needs_cpu(u64 basem, u64 *nextevt);
  21. void rcu_cpu_stall_reset(void);
  22. /*
  23. * Note a virtualization-based context switch. This is simply a
  24. * wrapper around rcu_note_context_switch(), which allows TINY_RCU
  25. * to save a few bytes. The caller must have disabled interrupts.
  26. */
  27. static inline void rcu_virt_note_context_switch(int cpu)
  28. {
  29. rcu_note_context_switch(false);
  30. }
  31. void synchronize_rcu_expedited(void);
  32. void kfree_call_rcu(struct rcu_head *head, rcu_callback_t func);
  33. void rcu_barrier(void);
  34. bool rcu_eqs_special_set(int cpu);
  35. unsigned long get_state_synchronize_rcu(void);
  36. void cond_synchronize_rcu(unsigned long oldstate);
  37. void rcu_idle_enter(void);
  38. void rcu_idle_exit(void);
  39. void rcu_irq_enter(void);
  40. void rcu_irq_exit(void);
  41. void rcu_irq_enter_irqson(void);
  42. void rcu_irq_exit_irqson(void);
  43. void exit_rcu(void);
  44. void rcu_scheduler_starting(void);
  45. extern int rcu_scheduler_active __read_mostly;
  46. void rcu_end_inkernel_boot(void);
  47. bool rcu_is_watching(void);
  48. #ifndef CONFIG_PREEMPTION
  49. void rcu_all_qs(void);
  50. #endif
  51. /* RCUtree hotplug events */
  52. int rcutree_prepare_cpu(unsigned int cpu);
  53. int rcutree_online_cpu(unsigned int cpu);
  54. int rcutree_offline_cpu(unsigned int cpu);
  55. int rcutree_dead_cpu(unsigned int cpu);
  56. int rcutree_dying_cpu(unsigned int cpu);
  57. void rcu_cpu_starting(unsigned int cpu);
  58. #endif /* __LINUX_RCUTREE_H */