blob: 7dc17e2456de141ef3241a73af02fbec9b9c1ee5 [file] [log] [blame]
Anton Vorontsov70ddf632013-04-29 15:08:31 -07001#ifndef __LINUX_VMPRESSURE_H
2#define __LINUX_VMPRESSURE_H
3
4#include <linux/mutex.h>
5#include <linux/list.h>
6#include <linux/workqueue.h>
7#include <linux/gfp.h>
8#include <linux/types.h>
9#include <linux/cgroup.h>
10
11struct vmpressure {
12 unsigned long scanned;
13 unsigned long reclaimed;
14 /* The lock is used to keep the scanned/reclaimed above in sync. */
Michal Hocko22f20202013-07-31 13:53:48 -070015 struct spinlock sr_lock;
Anton Vorontsov70ddf632013-04-29 15:08:31 -070016
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
22 struct work_struct work;
23};
24
25struct mem_cgroup;
26
27#ifdef CONFIG_MEMCG
28extern void vmpressure(gfp_t gfp, struct mem_cgroup *memcg,
29 unsigned long scanned, unsigned long reclaimed);
30extern void vmpressure_prio(gfp_t gfp, struct mem_cgroup *memcg, int prio);
31
32extern void vmpressure_init(struct vmpressure *vmpr);
Michal Hocko33cb8762013-07-31 13:53:51 -070033extern void vmpressure_cleanup(struct vmpressure *vmpr);
Anton Vorontsov70ddf632013-04-29 15:08:31 -070034extern struct vmpressure *memcg_to_vmpressure(struct mem_cgroup *memcg);
35extern struct cgroup_subsys_state *vmpressure_to_css(struct vmpressure *vmpr);
36extern struct vmpressure *css_to_vmpressure(struct cgroup_subsys_state *css);
37extern int vmpressure_register_event(struct cgroup *cg, struct cftype *cft,
38 struct eventfd_ctx *eventfd,
39 const char *args);
40extern void vmpressure_unregister_event(struct cgroup *cg, struct cftype *cft,
41 struct eventfd_ctx *eventfd);
42#else
43static inline void vmpressure(gfp_t gfp, struct mem_cgroup *memcg,
44 unsigned long scanned, unsigned long reclaimed) {}
45static inline void vmpressure_prio(gfp_t gfp, struct mem_cgroup *memcg,
46 int prio) {}
47#endif /* CONFIG_MEMCG */
48#endif /* __LINUX_VMPRESSURE_H */