vmpressure.h 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. #ifndef __LINUX_VMPRESSURE_H
  2. #define __LINUX_VMPRESSURE_H
  3. #include <linux/mutex.h>
  4. #include <linux/list.h>
  5. #include <linux/workqueue.h>
  6. #include <linux/gfp.h>
  7. #include <linux/types.h>
  8. #include <linux/cgroup.h>
  9. #include <linux/eventfd.h>
  10. struct vmpressure {
  11. unsigned long scanned;
  12. unsigned long reclaimed;
  13. unsigned long tree_scanned;
  14. unsigned long tree_reclaimed;
  15. /* The lock is used to keep the scanned/reclaimed above in sync. */
  16. struct spinlock sr_lock;
  17. /* The list of vmpressure_event structs. */
  18. struct list_head events;
  19. /* Have to grab the lock on events traversal or modifications. */
  20. struct mutex events_lock;
  21. struct work_struct work;
  22. };
  23. struct mem_cgroup;
  24. #ifdef CONFIG_MEMCG
  25. extern void vmpressure(gfp_t gfp, struct mem_cgroup *memcg, bool tree,
  26. unsigned long scanned, unsigned long reclaimed);
  27. extern void vmpressure_prio(gfp_t gfp, struct mem_cgroup *memcg, int prio);
  28. extern void vmpressure_init(struct vmpressure *vmpr);
  29. extern void vmpressure_cleanup(struct vmpressure *vmpr);
  30. extern struct vmpressure *memcg_to_vmpressure(struct mem_cgroup *memcg);
  31. extern struct cgroup_subsys_state *vmpressure_to_css(struct vmpressure *vmpr);
  32. extern int vmpressure_register_event(struct mem_cgroup *memcg,
  33. struct eventfd_ctx *eventfd,
  34. const char *args);
  35. extern void vmpressure_unregister_event(struct mem_cgroup *memcg,
  36. struct eventfd_ctx *eventfd);
  37. #else
  38. static inline void vmpressure(gfp_t gfp, struct mem_cgroup *memcg, bool tree,
  39. unsigned long scanned, unsigned long reclaimed) {}
  40. static inline void vmpressure_prio(gfp_t gfp, struct mem_cgroup *memcg,
  41. int prio) {}
  42. #endif /* CONFIG_MEMCG */
  43. #endif /* __LINUX_VMPRESSURE_H */