vmpressure.h 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  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. struct vmpressure {
  10. unsigned long scanned;
  11. unsigned long reclaimed;
  12. /* The lock is used to keep the scanned/reclaimed above in sync. */
  13. struct spinlock sr_lock;
  14. /* The list of vmpressure_event structs. */
  15. struct list_head events;
  16. /* Have to grab the lock on events traversal or modifications. */
  17. struct mutex events_lock;
  18. struct work_struct work;
  19. };
  20. struct mem_cgroup;
  21. #ifdef CONFIG_MEMCG
  22. extern void vmpressure(gfp_t gfp, struct mem_cgroup *memcg,
  23. unsigned long scanned, unsigned long reclaimed);
  24. extern void vmpressure_prio(gfp_t gfp, struct mem_cgroup *memcg, int prio);
  25. extern void vmpressure_init(struct vmpressure *vmpr);
  26. extern void vmpressure_cleanup(struct vmpressure *vmpr);
  27. extern struct vmpressure *memcg_to_vmpressure(struct mem_cgroup *memcg);
  28. extern struct cgroup_subsys_state *vmpressure_to_css(struct vmpressure *vmpr);
  29. extern struct vmpressure *css_to_vmpressure(struct cgroup_subsys_state *css);
  30. extern int vmpressure_register_event(struct cgroup *cg, struct cftype *cft,
  31. struct eventfd_ctx *eventfd,
  32. const char *args);
  33. extern void vmpressure_unregister_event(struct cgroup *cg, struct cftype *cft,
  34. struct eventfd_ctx *eventfd);
  35. #else
  36. static inline void vmpressure(gfp_t gfp, struct mem_cgroup *memcg,
  37. unsigned long scanned, unsigned long reclaimed) {}
  38. static inline void vmpressure_prio(gfp_t gfp, struct mem_cgroup *memcg,
  39. int prio) {}
  40. #endif /* CONFIG_MEMCG */
  41. #endif /* __LINUX_VMPRESSURE_H */