Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Anton Vorontsov | 70ddf63 | 2013-04-29 15:08:31 -0700 | [diff] [blame] | 2 | #ifndef __LINUX_VMPRESSURE_H |
| 3 | #define __LINUX_VMPRESSURE_H |
| 4 | |
| 5 | #include <linux/mutex.h> |
| 6 | #include <linux/list.h> |
| 7 | #include <linux/workqueue.h> |
| 8 | #include <linux/gfp.h> |
| 9 | #include <linux/types.h> |
| 10 | #include <linux/cgroup.h> |
Tejun Heo | fba9480 | 2013-11-22 18:20:43 -0500 | [diff] [blame] | 11 | #include <linux/eventfd.h> |
Anton Vorontsov | 70ddf63 | 2013-04-29 15:08:31 -0700 | [diff] [blame] | 12 | |
| 13 | struct vmpressure { |
| 14 | unsigned long scanned; |
| 15 | unsigned long reclaimed; |
Johannes Weiner | 8e8ae64 | 2016-01-14 15:21:32 -0800 | [diff] [blame] | 16 | |
| 17 | unsigned long tree_scanned; |
| 18 | unsigned long tree_reclaimed; |
Anton Vorontsov | 70ddf63 | 2013-04-29 15:08:31 -0700 | [diff] [blame] | 19 | /* The lock is used to keep the scanned/reclaimed above in sync. */ |
Sebastian Andrzej Siewior | 51b1762 | 2019-07-11 20:54:52 -0700 | [diff] [blame] | 20 | spinlock_t sr_lock; |
Anton Vorontsov | 70ddf63 | 2013-04-29 15:08:31 -0700 | [diff] [blame] | 21 | |
| 22 | /* The list of vmpressure_event structs. */ |
| 23 | struct list_head events; |
| 24 | /* Have to grab the lock on events traversal or modifications. */ |
| 25 | struct mutex events_lock; |
| 26 | |
| 27 | struct work_struct work; |
| 28 | }; |
| 29 | |
| 30 | struct mem_cgroup; |
| 31 | |
| 32 | #ifdef CONFIG_MEMCG |
Johannes Weiner | 8e8ae64 | 2016-01-14 15:21:32 -0800 | [diff] [blame] | 33 | extern void vmpressure(gfp_t gfp, struct mem_cgroup *memcg, bool tree, |
Anton Vorontsov | 70ddf63 | 2013-04-29 15:08:31 -0700 | [diff] [blame] | 34 | unsigned long scanned, unsigned long reclaimed); |
| 35 | extern void vmpressure_prio(gfp_t gfp, struct mem_cgroup *memcg, int prio); |
| 36 | |
| 37 | extern void vmpressure_init(struct vmpressure *vmpr); |
Michal Hocko | 33cb876 | 2013-07-31 13:53:51 -0700 | [diff] [blame] | 38 | extern void vmpressure_cleanup(struct vmpressure *vmpr); |
Anton Vorontsov | 70ddf63 | 2013-04-29 15:08:31 -0700 | [diff] [blame] | 39 | extern struct vmpressure *memcg_to_vmpressure(struct mem_cgroup *memcg); |
| 40 | extern struct cgroup_subsys_state *vmpressure_to_css(struct vmpressure *vmpr); |
Tejun Heo | 59b6f87 | 2013-11-22 18:20:43 -0500 | [diff] [blame] | 41 | extern int vmpressure_register_event(struct mem_cgroup *memcg, |
Anton Vorontsov | 70ddf63 | 2013-04-29 15:08:31 -0700 | [diff] [blame] | 42 | struct eventfd_ctx *eventfd, |
| 43 | const char *args); |
Tejun Heo | 59b6f87 | 2013-11-22 18:20:43 -0500 | [diff] [blame] | 44 | extern void vmpressure_unregister_event(struct mem_cgroup *memcg, |
Anton Vorontsov | 70ddf63 | 2013-04-29 15:08:31 -0700 | [diff] [blame] | 45 | struct eventfd_ctx *eventfd); |
| 46 | #else |
Johannes Weiner | 8e8ae64 | 2016-01-14 15:21:32 -0800 | [diff] [blame] | 47 | static inline void vmpressure(gfp_t gfp, struct mem_cgroup *memcg, bool tree, |
Anton Vorontsov | 70ddf63 | 2013-04-29 15:08:31 -0700 | [diff] [blame] | 48 | unsigned long scanned, unsigned long reclaimed) {} |
| 49 | static inline void vmpressure_prio(gfp_t gfp, struct mem_cgroup *memcg, |
| 50 | int prio) {} |
| 51 | #endif /* CONFIG_MEMCG */ |
| 52 | #endif /* __LINUX_VMPRESSURE_H */ |