Whamcloud - gitweb
LU-936 Remove LUSTRE_KERNEL_VERSION
[fs/lustre-release.git] / lustre / include / linux / lustre_patchless_compat.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) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
28  * Use is subject to license terms.
29  *
30  * Copyright (c) 2011, Whamcloud, Inc.
31  */
32 /*
33  * This file is part of Lustre, http://www.lustre.org/
34  * Lustre is a trademark of Sun Microsystems, Inc.
35  */
36
37 #ifndef LUSTRE_PATCHLESS_COMPAT_H
38 #define LUSTRE_PATCHLESS_COMPAT_H
39
40 #include <linux/fs.h>
41
42 #ifndef HAVE_TRUNCATE_COMPLETE_PAGE
43 #include <linux/list.h>
44 #include <linux/mm.h>
45 #include <linux/hash.h>
46
47 #ifndef HAVE_CANCEL_DIRTY_PAGE /* 2.6.20 */
48 #define cancel_dirty_page(page, size) clear_page_dirty(page)
49 #endif
50
51 #ifndef HAVE_DELETE_FROM_PAGE_CACHE /* 2.6.39 */
52 #ifndef HAVE_REMOVE_FROM_PAGE_CACHE /* 2.6.35 - 2.6.38 */
53 #ifdef HAVE_NR_PAGECACHE /* 2.6.18 */
54 #define __dec_zone_page_state(page, flag) atomic_add(-1, &nr_pagecache);
55 #endif /* HAVE_NR_PAGECACHE */
56
57 /* XXX copy & paste from 2.6.15 kernel */
58 static inline void ll_remove_from_page_cache(struct page *page)
59 {
60         struct address_space *mapping = page->mapping;
61
62         BUG_ON(!PageLocked(page));
63
64 #ifdef HAVE_RW_TREE_LOCK
65         write_lock_irq(&mapping->tree_lock);
66 #else
67         cfs_spin_lock_irq(&mapping->tree_lock);
68 #endif
69         radix_tree_delete(&mapping->page_tree, page->index);
70         page->mapping = NULL;
71         mapping->nrpages--;
72         __dec_zone_page_state(page, NR_FILE_PAGES);
73
74 #ifdef HAVE_RW_TREE_LOCK
75         write_unlock_irq(&mapping->tree_lock);
76 #else
77         cfs_spin_unlock_irq(&mapping->tree_lock);
78 #endif
79 }
80 #else /* HAVE_REMOVE_FROM_PAGE_CACHE */
81 #define ll_remove_from_page_cache(page) remove_from_page_cache(page)
82 #endif /* !HAVE_REMOVE_FROM_PAGE_CACHE */
83
84 static inline void ll_delete_from_page_cache(struct page *page)
85 {
86         ll_remove_from_page_cache(page);
87         page_cache_release(page);
88 }
89 #else /* HAVE_DELETE_FROM_PAGE_CACHE */
90 #define ll_delete_from_page_cache(page) delete_from_page_cache(page)
91 #endif /* !HAVE_DELETE_FROM_PAGE_CACHE */
92
93 static inline void
94 truncate_complete_page(struct address_space *mapping, struct page *page)
95 {
96         if (page->mapping != mapping)
97                 return;
98
99         if (PagePrivate(page))
100                 page->mapping->a_ops->invalidatepage(page, 0);
101
102         cancel_dirty_page(page, PAGE_SIZE);
103         ClearPageMappedToDisk(page);
104         ll_delete_from_page_cache(page);
105 }
106 #endif /* !HAVE_TRUNCATE_COMPLETE_PAGE */
107
108 #if !defined(HAVE_D_REHASH_COND) && !defined(HAVE___D_REHASH)
109 /* megahack */
110 static inline void d_rehash_cond(struct dentry * entry, int lock)
111 {
112         if (!lock)
113                 spin_unlock(&dcache_lock);
114
115         d_rehash(entry);
116
117         if (!lock)
118                 spin_lock(&dcache_lock);
119 }
120
121 #define __d_rehash(dentry, lock) d_rehash_cond(dentry, lock)
122 #endif /* !HAVE_D_REHASH_COND && !HAVE___D_REHASH*/
123
124 #ifdef ATTR_OPEN
125 # define ATTR_FROM_OPEN ATTR_OPEN
126 #else
127 # ifndef ATTR_FROM_OPEN
128 #  define ATTR_FROM_OPEN 0
129 # endif
130 #endif /* ATTR_OPEN */
131
132 #ifndef ATTR_RAW
133 #define ATTR_RAW 0
134 #endif
135
136 #ifndef ATTR_CTIME_SET
137 /*
138  * set ATTR_CTIME_SET to a high value to avoid any risk of collision with other
139  * ATTR_* attributes (see bug 13828)
140  */
141 #define ATTR_CTIME_SET (1 << 28)
142 #endif
143
144 #endif /* LUSTRE_PATCHLESS_COMPAT_H */