frontswap.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef _LINUX_FRONTSWAP_H
  3. #define _LINUX_FRONTSWAP_H
  4. #include <linux/swap.h>
  5. #include <linux/mm.h>
  6. #include <linux/bitops.h>
  7. #include <linux/jump_label.h>
  8. struct frontswap_ops {
  9. void (*init)(unsigned); /* this swap type was just swapon'ed */
  10. int (*store)(unsigned, pgoff_t, struct page *); /* store a page */
  11. int (*load)(unsigned, pgoff_t, struct page *); /* load a page */
  12. void (*invalidate_page)(unsigned, pgoff_t); /* page no longer needed */
  13. void (*invalidate_area)(unsigned); /* swap type just swapoff'ed */
  14. struct frontswap_ops *next; /* private pointer to next ops */
  15. };
  16. extern void frontswap_register_ops(struct frontswap_ops *ops);
  17. extern void frontswap_shrink(unsigned long);
  18. extern unsigned long frontswap_curr_pages(void);
  19. extern void frontswap_writethrough(bool);
  20. #define FRONTSWAP_HAS_EXCLUSIVE_GETS
  21. extern void frontswap_tmem_exclusive_gets(bool);
  22. extern bool __frontswap_test(struct swap_info_struct *, pgoff_t);
  23. extern void __frontswap_init(unsigned type, unsigned long *map);
  24. extern int __frontswap_store(struct page *page);
  25. extern int __frontswap_load(struct page *page);
  26. extern void __frontswap_invalidate_page(unsigned, pgoff_t);
  27. extern void __frontswap_invalidate_area(unsigned);
  28. #ifdef CONFIG_FRONTSWAP
  29. extern struct static_key_false frontswap_enabled_key;
  30. static inline bool frontswap_enabled(void)
  31. {
  32. return static_branch_unlikely(&frontswap_enabled_key);
  33. }
  34. static inline bool frontswap_test(struct swap_info_struct *sis, pgoff_t offset)
  35. {
  36. return __frontswap_test(sis, offset);
  37. }
  38. static inline void frontswap_map_set(struct swap_info_struct *p,
  39. unsigned long *map)
  40. {
  41. p->frontswap_map = map;
  42. }
  43. static inline unsigned long *frontswap_map_get(struct swap_info_struct *p)
  44. {
  45. return p->frontswap_map;
  46. }
  47. #else
  48. /* all inline routines become no-ops and all externs are ignored */
  49. static inline bool frontswap_enabled(void)
  50. {
  51. return false;
  52. }
  53. static inline bool frontswap_test(struct swap_info_struct *sis, pgoff_t offset)
  54. {
  55. return false;
  56. }
  57. static inline void frontswap_map_set(struct swap_info_struct *p,
  58. unsigned long *map)
  59. {
  60. }
  61. static inline unsigned long *frontswap_map_get(struct swap_info_struct *p)
  62. {
  63. return NULL;
  64. }
  65. #endif
  66. static inline int frontswap_store(struct page *page)
  67. {
  68. if (frontswap_enabled())
  69. return __frontswap_store(page);
  70. return -1;
  71. }
  72. static inline int frontswap_load(struct page *page)
  73. {
  74. if (frontswap_enabled())
  75. return __frontswap_load(page);
  76. return -1;
  77. }
  78. static inline void frontswap_invalidate_page(unsigned type, pgoff_t offset)
  79. {
  80. if (frontswap_enabled())
  81. __frontswap_invalidate_page(type, offset);
  82. }
  83. static inline void frontswap_invalidate_area(unsigned type)
  84. {
  85. if (frontswap_enabled())
  86. __frontswap_invalidate_area(type);
  87. }
  88. static inline void frontswap_init(unsigned type, unsigned long *map)
  89. {
  90. #ifdef CONFIG_FRONTSWAP
  91. __frontswap_init(type, map);
  92. #endif
  93. }
  94. #endif /* _LINUX_FRONTSWAP_H */