jump_label_ratelimit.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef _LINUX_JUMP_LABEL_RATELIMIT_H
  3. #define _LINUX_JUMP_LABEL_RATELIMIT_H
  4. #include <linux/jump_label.h>
  5. #include <linux/workqueue.h>
  6. #if defined(CONFIG_JUMP_LABEL)
  7. struct static_key_deferred {
  8. struct static_key key;
  9. unsigned long timeout;
  10. struct delayed_work work;
  11. };
  12. struct static_key_true_deferred {
  13. struct static_key_true key;
  14. unsigned long timeout;
  15. struct delayed_work work;
  16. };
  17. struct static_key_false_deferred {
  18. struct static_key_false key;
  19. unsigned long timeout;
  20. struct delayed_work work;
  21. };
  22. #define static_key_slow_dec_deferred(x) \
  23. __static_key_slow_dec_deferred(&(x)->key, &(x)->work, (x)->timeout)
  24. #define static_branch_slow_dec_deferred(x) \
  25. __static_key_slow_dec_deferred(&(x)->key.key, &(x)->work, (x)->timeout)
  26. #define static_key_deferred_flush(x) \
  27. __static_key_deferred_flush((x), &(x)->work)
  28. extern void
  29. __static_key_slow_dec_deferred(struct static_key *key,
  30. struct delayed_work *work,
  31. unsigned long timeout);
  32. extern void __static_key_deferred_flush(void *key, struct delayed_work *work);
  33. extern void
  34. jump_label_rate_limit(struct static_key_deferred *key, unsigned long rl);
  35. extern void jump_label_update_timeout(struct work_struct *work);
  36. #define DEFINE_STATIC_KEY_DEFERRED_TRUE(name, rl) \
  37. struct static_key_true_deferred name = { \
  38. .key = { STATIC_KEY_INIT_TRUE }, \
  39. .timeout = (rl), \
  40. .work = __DELAYED_WORK_INITIALIZER((name).work, \
  41. jump_label_update_timeout, \
  42. 0), \
  43. }
  44. #define DEFINE_STATIC_KEY_DEFERRED_FALSE(name, rl) \
  45. struct static_key_false_deferred name = { \
  46. .key = { STATIC_KEY_INIT_FALSE }, \
  47. .timeout = (rl), \
  48. .work = __DELAYED_WORK_INITIALIZER((name).work, \
  49. jump_label_update_timeout, \
  50. 0), \
  51. }
  52. #else /* !CONFIG_JUMP_LABEL */
  53. struct static_key_deferred {
  54. struct static_key key;
  55. };
  56. struct static_key_true_deferred {
  57. struct static_key_true key;
  58. };
  59. struct static_key_false_deferred {
  60. struct static_key_false key;
  61. };
  62. #define DEFINE_STATIC_KEY_DEFERRED_TRUE(name, rl) \
  63. struct static_key_true_deferred name = { STATIC_KEY_TRUE_INIT }
  64. #define DEFINE_STATIC_KEY_DEFERRED_FALSE(name, rl) \
  65. struct static_key_false_deferred name = { STATIC_KEY_FALSE_INIT }
  66. #define static_branch_slow_dec_deferred(x) static_branch_dec(&(x)->key)
  67. static inline void static_key_slow_dec_deferred(struct static_key_deferred *key)
  68. {
  69. STATIC_KEY_CHECK_USE(key);
  70. static_key_slow_dec(&key->key);
  71. }
  72. static inline void static_key_deferred_flush(void *key)
  73. {
  74. STATIC_KEY_CHECK_USE(key);
  75. }
  76. static inline void
  77. jump_label_rate_limit(struct static_key_deferred *key,
  78. unsigned long rl)
  79. {
  80. STATIC_KEY_CHECK_USE(key);
  81. }
  82. #endif /* CONFIG_JUMP_LABEL */
  83. #define static_branch_deferred_inc(x) static_branch_inc(&(x)->key)
  84. #endif /* _LINUX_JUMP_LABEL_RATELIMIT_H */