1 /* -*- mode: c; c-basic-offset: 8; indent-tabs-mode: nil; -*-
2 * vim:expandtab:shiftwidth=8:tabstop=8:
6 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License version 2 only,
10 * as published by the Free Software Foundation.
12 * This program is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * General Public License version 2 for more details (a copy is included
16 * in the LICENSE file that accompanied this code).
18 * You should have received a copy of the GNU General Public License
19 * version 2 along with this program; If not, see
20 * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf
22 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
23 * CA 95054 USA or visit www.sun.com if you need additional information or
29 * Copyright 2008 Sun Microsystems, Inc. All rights reserved
30 * Use is subject to license terms.
33 * This file is part of Lustre, http://www.lustre.org/
34 * Lustre is a trademark of Sun Microsystems, Inc.
37 #ifndef LUSTRE_PATCHLESS_COMPAT_H
38 #define LUSTRE_PATCHLESS_COMPAT_H
40 #include <linux/lustre_version.h>
43 #ifndef HAVE_TRUNCATE_COMPLETE_PAGE
44 #include <linux/list.h>
46 #include <linux/hash.h>
48 /* XXX copy & paste from 2.6.15 kernel */
49 static inline void ll_remove_from_page_cache(struct page *page)
51 struct address_space *mapping = page->mapping;
53 BUG_ON(!PageLocked(page));
55 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15))
56 write_lock_irq(&mapping->tree_lock);
58 spin_lock_irq(&mapping->tree_lock);
60 radix_tree_delete(&mapping->page_tree, page->index);
63 #ifdef HAVE_NR_PAGECACHE
64 atomic_add(-1, &nr_pagecache); // XXX pagecache_acct(-1);
66 __dec_zone_page_state(page, NR_FILE_PAGES);
69 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15))
70 write_unlock_irq(&mapping->tree_lock);
72 spin_unlock_irq(&mapping->tree_lock);
77 truncate_complete_page(struct address_space *mapping, struct page *page)
79 if (page->mapping != mapping)
82 if (PagePrivate(page))
83 page->mapping->a_ops->invalidatepage(page, 0);
85 #ifdef HAVE_CANCEL_DIRTY_PAGE
86 cancel_dirty_page(page, PAGE_SIZE);
88 clear_page_dirty(page);
90 ClearPageUptodate(page);
91 ClearPageMappedToDisk(page);
92 ll_remove_from_page_cache(page);
93 page_cache_release(page); /* pagecache ref */
95 #endif /* HAVE_TRUNCATE_COMPLETE_PAGE */
97 #if !defined(HAVE_D_REHASH_COND) && !defined(HAVE___D_REHASH)
99 static inline void d_rehash_cond(struct dentry * entry, int lock)
102 spin_unlock(&dcache_lock);
107 spin_lock(&dcache_lock);
110 #define __d_rehash(dentry, lock) d_rehash_cond(dentry, lock)
111 #endif /* !HAVE_D_REHASH_COND && !HAVE___D_REHASH*/
114 # define ATTR_FROM_OPEN ATTR_OPEN
116 # ifndef ATTR_FROM_OPEN
117 # define ATTR_FROM_OPEN 0
119 #endif /* ATTR_OPEN */
125 #ifndef ATTR_CTIME_SET
127 * set ATTR_CTIME_SET to a high value to avoid any risk of collision with other
128 * ATTR_* attributes (see bug 13828)
130 #define ATTR_CTIME_SET (1 << 28)
133 #endif /* LUSTRE_PATCHLESS_COMPAT_H */