Whamcloud - gitweb
LU-4423 libcfs: Merge linux-proc.c into module.c
[fs/lustre-release.git] / libcfs / include / libcfs / linux / linux-mem.h
1 /*
2  * GPL HEADER START
3  *
4  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 only,
8  * as published by the Free Software Foundation.
9  *
10  * This program is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13  * General Public License version 2 for more details (a copy is included
14  * in the LICENSE file that accompanied this code).
15  *
16  * You should have received a copy of the GNU General Public License
17  * version 2 along with this program; If not, see
18  * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf
19  *
20  * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
21  * CA 95054 USA or visit www.sun.com if you need additional information or
22  * have any questions.
23  *
24  * GPL HEADER END
25  */
26 /*
27  * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
28  * Use is subject to license terms.
29  *
30  * Copyright (c) 2011, 2014, Intel Corporation.
31  */
32 /*
33  * This file is part of Lustre, http://www.lustre.org/
34  * Lustre is a trademark of Sun Microsystems, Inc.
35  *
36  * libcfs/include/libcfs/linux/linux-mem.h
37  *
38  * Basic library routines.
39  */
40
41 #ifndef __LIBCFS_LINUX_CFS_MEM_H__
42 #define __LIBCFS_LINUX_CFS_MEM_H__
43
44 #ifndef __LIBCFS_LIBCFS_H__
45 #error Do not #include this file directly. #include <libcfs/libcfs.h> instead
46 #endif
47
48 #ifndef __KERNEL__
49 #error This include is only for kernel use.
50 #endif
51
52 #include <linux/mm.h>
53 #include <linux/vmalloc.h>
54 #include <linux/pagemap.h>
55 #include <linux/slab.h>
56 #ifdef HAVE_MM_INLINE
57 # include <linux/mm_inline.h>
58 #endif
59
60 /* GFP_IOFS was added in 2.6.33 kernel */
61 #ifndef GFP_IOFS
62 #define GFP_IOFS       (__GFP_IO | __GFP_FS)
63 #endif
64
65 /*
66  * Shrinker
67  */
68 #ifdef HAVE_SHRINK_CONTROL
69 # define SHRINKER_ARGS(sc, nr_to_scan, gfp_mask)  \
70                        struct shrinker *shrinker, \
71                        struct shrink_control *sc
72 # define shrink_param(sc, var) ((sc)->var)
73 #else
74 struct shrink_control {
75         gfp_t gfp_mask;
76         unsigned long nr_to_scan;
77 };
78 # ifdef HAVE_SHRINKER_WANT_SHRINK_PTR
79 #  define SHRINKER_ARGS(sc, nr_to_scan, gfp_mask)  \
80                         struct shrinker *shrinker, \
81                         int nr_to_scan, gfp_t gfp_mask
82 # else
83 #  define SHRINKER_ARGS(sc, nr_to_scan, gfp_mask)  \
84                         int nr_to_scan, gfp_t gfp_mask
85 # endif
86         /* avoid conflict with spl mm_compat.h */
87 # define HAVE_SHRINK_CONTROL_STRUCT 1
88 # define shrink_param(sc, var) (var)
89 #endif
90
91 #ifdef HAVE_SHRINKER_COUNT
92 struct shrinker_var {
93         unsigned long (*count)(struct shrinker *,
94                                struct shrink_control *sc);
95         unsigned long (*scan)(struct shrinker *,
96                               struct shrink_control *sc);
97 };
98 # define DEF_SHRINKER_VAR(name, shrink, count_obj, scan_obj) \
99             struct shrinker_var name = { .count = count_obj, .scan = scan_obj }
100 #else
101 struct shrinker_var {
102         int (*shrink)(SHRINKER_ARGS(sc, nr_to_scan, gfp_mask));
103 };
104 # define DEF_SHRINKER_VAR(name, shrinker, count, scan) \
105             struct shrinker_var name = { .shrink = shrinker }
106 # define SHRINK_STOP (~0UL)
107 #endif
108
109 static inline
110 struct shrinker *set_shrinker(int seek, struct shrinker_var *var)
111 {
112         struct shrinker *s;
113
114         s = kzalloc(sizeof(*s), GFP_KERNEL);
115         if (s == NULL)
116                 return (NULL);
117
118 #ifdef HAVE_SHRINKER_COUNT
119         s->count_objects = var->count;
120         s->scan_objects = var->scan;
121 #else
122         s->shrink = var->shrink;
123 #endif
124         s->seeks = seek;
125
126         register_shrinker(s);
127
128         return s;
129 }
130
131 static inline
132 void remove_shrinker(struct shrinker *shrinker)
133 {
134         if (shrinker == NULL)
135                 return;
136
137         unregister_shrinker(shrinker);
138         kfree(shrinker);
139 }
140
141 #endif /* __LINUX_CFS_MEM_H__ */