Whamcloud - gitweb
619efc9fd91e7e73b8bc13c65bbd0a5aa35f7074
[fs/lustre-release.git] / libcfs / include / libcfs / winnt / winnt-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 /*
31  * This file is part of Lustre, http://www.lustre.org/
32  * Lustre is a trademark of Sun Microsystems, Inc.
33  *
34  * libcfs/include/libcfs/winnt/winnt-mem.h
35  *
36  * Basic library routines of memory manipulation routines.
37  */
38
39 #ifndef __LIBCFS_WINNT_CFS_MEM_H__
40 #define __LIBCFS_WINNT_CFS_MEM_H__
41
42 #ifndef __LIBCFS_LIBCFS_H__
43 #error Do not #include this file directly. #include <libcfs/libcfs.h> instead
44 #endif
45
46 #include <libcfs/winnt/portals_utils.h>
47
48 #ifdef __KERNEL__
49
50 typedef struct cfs_mem_cache cfs_mem_cache_t;
51
52 /*
53  * page definitions
54  */
55
56 #define CFS_PAGE_SIZE                   PAGE_SIZE
57 #define CFS_PAGE_SHIFT                  PAGE_SHIFT
58 #define CFS_PAGE_MASK                   (~(PAGE_SIZE - 1))
59
60 typedef struct cfs_page {
61     void *          addr;
62     cfs_atomic_t    count;
63     void *          private;
64     void *          mapping;
65     __u32           index;
66     __u32           flags;
67 } cfs_page_t;
68
69 #define page cfs_page
70
71 #ifndef page_private
72 #define page_private(page) ((page)->private)
73 #define set_page_private(page, v) ((page)->private = (v))
74 #endif
75
76 #define page_count(page) (0)
77
78 #define PG_locked                0      /* Page is locked. Don't touch. */
79 #define PG_error                 1
80 #define PG_referenced            2
81 #define PG_uptodate              3
82
83 #define PG_dirty                 4
84 #define PG_lru                   5
85 #define PG_active                6
86 #define PG_slab                  7      /* slab debug (Suparna wants this) */
87
88 #define PG_owner_priv_1          8      /* Owner use. If pagecache, fs may use*/
89 #define PG_arch_1                9
90 #define PG_reserved             10
91 #define PG_private              11      /* If pagecache, has fs-private data */
92
93 #define PG_writeback            12      /* Page is under writeback */
94 #define PG_compound             14      /* Part of a compound page */
95 #define PG_swapcache            15      /* Swap page: swp_entry_t in private */
96
97 #define PG_mappedtodisk         16      /* Has blocks allocated on-disk */
98 #define PG_reclaim              17      /* To be reclaimed asap */
99 #define PG_buddy                19      /* Page is free, on buddy lists */
100
101 #define PG_virt         31  /* addr is not */
102
103 #ifndef arch_set_page_uptodate
104 #define arch_set_page_uptodate(page)
105 #endif
106
107 /* Make it prettier to test the above... */
108 #define UnlockPage(page)        unlock_page(page)
109 #define Page_Uptodate(page)     cfs_test_bit(PG_uptodate, &(page)->flags)
110 #define SetPageUptodate(page) \
111         do {                                                            \
112                 arch_set_page_uptodate(page);                           \
113                 cfs_set_bit(PG_uptodate, &(page)->flags);               \
114         } while (0)
115 #define ClearPageUptodate(page) cfs_clear_bit(PG_uptodate, &(page)->flags)
116 #define PageDirty(page)         cfs_test_bit(PG_dirty, &(page)->flags)
117 #define SetPageDirty(page)      cfs_set_bit(PG_dirty, &(page)->flags)
118 #define ClearPageDirty(page)    cfs_clear_bit(PG_dirty, &(page)->flags)
119 #define PageLocked(page)        cfs_test_bit(PG_locked, &(page)->flags)
120 #define LockPage(page)          cfs_set_bit(PG_locked, &(page)->flags)
121 #define TryLockPage(page)       cfs_test_and_set_bit(PG_locked, &(page)->flags)
122 #define PageChecked(page)       cfs_test_bit(PG_checked, &(page)->flags)
123 #define SetPageChecked(page)    cfs_set_bit(PG_checked, &(page)->flags)
124 #define ClearPageChecked(page)  cfs_clear_bit(PG_checked, &(page)->flags)
125 #define PageLaunder(page)       cfs_test_bit(PG_launder, &(page)->flags)
126 #define SetPageLaunder(page)    cfs_set_bit(PG_launder, &(page)->flags)
127 #define ClearPageLaunder(page)  cfs_clear_bit(PG_launder, &(page)->flags)
128 #define ClearPageArch1(page)    cfs_clear_bit(PG_arch_1, &(page)->flags)
129
130 #define PageError(page)         cfs_test_bit(PG_error, &(page)->flags)
131 #define SetPageError(page)      cfs_set_bit(PG_error, &(page)->flags)
132 #define ClearPageError(page)    cfs_clear_bit(PG_error, &(page)->flags)
133 #define PageReferenced(page)    cfs_test_bit(PG_referenced, &(page)->flags)
134 #define SetPageReferenced(page) cfs_set_bit(PG_referenced, &(page)->flags)
135 #define ClearPageReferenced(page) cfs_clear_bit(PG_referenced, &(page)->flags)
136
137 #define PageActive(page)        cfs_test_bit(PG_active, &(page)->flags)
138 #define SetPageActive(page)     cfs_set_bit(PG_active, &(page)->flags)
139 #define ClearPageActive(page)   cfs_clear_bit(PG_active, &(page)->flags)
140
141 #define PageWriteback(page)     cfs_test_bit(PG_writeback, &(page)->flags)
142 #define TestSetPageWriteback(page) cfs_test_and_set_bit(PG_writeback,   \
143                                                         &(page)->flags)
144 #define TestClearPageWriteback(page) cfs_test_and_clear_bit(PG_writeback, \
145                                                         &(page)->flags)
146
147 #define __GFP_FS    (1)
148 #define GFP_KERNEL  (2)
149 #define GFP_ATOMIC  (4)
150
151 cfs_page_t *cfs_alloc_page(int flags);
152 void cfs_free_page(cfs_page_t *pg);
153 void cfs_release_page(cfs_page_t *pg);
154 cfs_page_t * virt_to_page(void * addr);
155 int cfs_mem_is_in_cache(const void *addr, const cfs_mem_cache_t *kmem);
156
157 #define page_cache_get(a) do {} while (0)
158 #define page_cache_release(a) do {} while (0)
159
160 static inline void *cfs_page_address(cfs_page_t *page)
161 {
162     return page->addr;
163 }
164
165 static inline void *cfs_kmap(cfs_page_t *page)
166 {
167     return page->addr;
168 }
169
170 static inline void cfs_kunmap(cfs_page_t *page)
171 {
172     return;
173 }
174
175 static inline void cfs_get_page(cfs_page_t *page)
176 {
177     cfs_atomic_inc(&page->count);
178 }
179
180 static inline void cfs_put_page(cfs_page_t *page)
181 {
182     cfs_atomic_dec(&page->count);
183 }
184
185 static inline int cfs_page_count(cfs_page_t *page)
186 {
187     return cfs_atomic_read(&page->count);
188 }
189
190 #define cfs_page_index(p)       ((p)->index)
191
192 /*
193  * Memory allocator
194  */
195
196 #define CFS_ALLOC_ATOMIC_TRY    (0)
197 extern void *cfs_alloc(size_t nr_bytes, u_int32_t flags);
198 extern void  cfs_free(void *addr);
199
200 #define kmalloc cfs_alloc
201
202 extern void *cfs_alloc_large(size_t nr_bytes);
203 extern void  cfs_free_large(void *addr);
204
205 /*
206  * SLAB allocator
207  */
208
209 #define CFS_SLAB_HWCACHE_ALIGN          0
210
211 /* The cache name is limited to 20 chars */
212
213 struct cfs_mem_cache {
214     char                    name[20];
215     ulong_ptr_t             flags;
216     NPAGED_LOOKASIDE_LIST   npll;
217 };
218
219
220 extern cfs_mem_cache_t *cfs_mem_cache_create (const char *, size_t, size_t,
221                                               unsigned long);
222 extern int cfs_mem_cache_destroy (cfs_mem_cache_t * );
223 extern void *cfs_mem_cache_alloc (cfs_mem_cache_t *, int);
224 extern void cfs_mem_cache_free (cfs_mem_cache_t *, void *);
225
226 /*
227  * shrinker 
228  */
229 typedef int (*shrink_callback)(int nr_to_scan, gfp_t gfp_mask);
230 struct cfs_shrinker {
231         shrink_callback cb;
232         int seeks;      /* seeks to recreate an obj */
233
234         /* These are for internal use */
235         cfs_list_t list;
236         long nr;        /* objs pending delete */
237 };
238
239 struct cfs_shrinker *cfs_set_shrinker(int seeks, shrink_callback cb);
240 void cfs_remove_shrinker(struct cfs_shrinker *s);
241
242 int start_shrinker_timer();
243 void stop_shrinker_timer();
244
245 /*
246  * Page allocator slabs 
247  */
248
249 extern cfs_mem_cache_t *cfs_page_t_slab;
250 extern cfs_mem_cache_t *cfs_page_p_slab;
251
252
253 #define CFS_DECL_MMSPACE
254 #define CFS_MMSPACE_OPEN    do {} while(0)
255 #define CFS_MMSPACE_CLOSE   do {} while(0)
256
257
258 #define cfs_mb()     do {} while(0)
259 #define rmb()        cfs_mb()
260 #define wmb()        cfs_mb()
261
262 /*
263  * MM defintions from (linux/mm.h)
264  */
265
266 #define CFS_DEFAULT_SEEKS 2 /* shrink seek */
267
268 #else  /* !__KERNEL__ */
269
270 #include "../user-mem.h"
271
272 /* page alignmed buffer allocation */
273 void* pgalloc(size_t factor);
274 void  pgfree(void * page);
275
276 #endif /* __KERNEL__ */
277
278 #endif /* __WINNT_CFS_MEM_H__ */