])
])
+# truncate_complete_page() was exported from RHEL5/SLES10/SLES11
+# remove_from_page_cache() was exported between 2.6.35 and 2.6.38
+# delete_from_page_cache() is exported from 2.6.39
AC_DEFUN([LC_EXPORT_TRUNCATE_COMPLETE_PAGE],
-[LB_CHECK_SYMBOL_EXPORT([truncate_complete_page],
-[mm/truncate.c],[
-AC_DEFINE(HAVE_TRUNCATE_COMPLETE_PAGE, 1,
- [kernel export truncate_complete_page])
-],[
-])
-])
+ [LB_CHECK_SYMBOL_EXPORT([truncate_complete_page],
+ [mm/truncate.c],
+ [AC_DEFINE(HAVE_TRUNCATE_COMPLETE_PAGE, 1,
+ [kernel export truncate_complete_page])])
+ LB_CHECK_SYMBOL_EXPORT([remove_from_page_cache],
+ [mm/filemap.c],
+ [AC_DEFINE(HAVE_REMOVE_FROM_PAGE_CACHE, 1,
+ [kernel export remove_from_page_cache])])
+ LB_CHECK_SYMBOL_EXPORT([delete_from_page_cache],
+ [mm/filemap.c],
+ [AC_DEFINE(HAVE_DELETE_FROM_PAGE_CACHE, 1,
+ [kernel export delete_from_page_cache])])
+ ])
AC_DEFUN([LC_EXPORT_TRUNCATE_RANGE],
[LB_CHECK_SYMBOL_EXPORT([truncate_inode_pages_range],
(inode)->i_mapping->a_ops->writepage(page, NULL)
#define ll_invalidate_inode_pages(inode) \
invalidate_inode_pages((inode)->i_mapping)
-#define ll_truncate_complete_page(page) \
- truncate_complete_page(page->mapping, page)
#define ll_vfs_create(a,b,c,d) vfs_create(a,b,c,d)
#define ll_dev_t dev_t
#include <linux/mm.h>
#include <linux/hash.h>
+#ifndef HAVE_CANCEL_DIRTY_PAGE /* 2.6.20 */
+#define cancel_dirty_page(page, size) clear_page_dirty(page)
+#endif
+
+#ifndef HAVE_DELETE_FROM_PAGE_CACHE /* 2.6.39 */
+#ifndef HAVE_REMOVE_FROM_PAGE_CACHE /* 2.6.35 - 2.6.38 */
+#ifdef HAVE_NR_PAGECACHE /* 2.6.18 */
+#define __dec_zone_page_state(page, flag) atomic_add(-1, &nr_pagecache);
+#endif /* HAVE_NR_PAGECACHE */
+
/* XXX copy & paste from 2.6.15 kernel */
static inline void ll_remove_from_page_cache(struct page *page)
{
radix_tree_delete(&mapping->page_tree, page->index);
page->mapping = NULL;
mapping->nrpages--;
-#ifdef HAVE_NR_PAGECACHE
- atomic_add(-1, &nr_pagecache); // XXX pagecache_acct(-1);
-#else
__dec_zone_page_state(page, NR_FILE_PAGES);
-#endif
#ifdef HAVE_RW_TREE_LOCK
write_unlock_irq(&mapping->tree_lock);
#else
spin_unlock_irq(&mapping->tree_lock);
#endif
}
+#else /* HAVE_REMOVE_FROM_PAGE_CACHE */
+#define ll_remove_from_page_cache(page) remove_from_page_cache(page)
+#endif /* !HAVE_REMOVE_FROM_PAGE_CACHE */
+
+static inline void ll_delete_from_page_cache(struct page *page)
+{
+ ll_remove_from_page_cache(page);
+ page_cache_release(page);
+}
+#else /* HAVE_DELETE_FROM_PAGE_CACHE */
+#define ll_delete_from_page_cache(page) delete_from_page_cache(page)
+#endif /* !HAVE_DELETE_FROM_PAGE_CACHE */
static inline void
truncate_complete_page(struct address_space *mapping, struct page *page)
if (PagePrivate(page))
page->mapping->a_ops->invalidatepage(page, 0);
-#ifdef HAVE_CANCEL_DIRTY_PAGE
cancel_dirty_page(page, PAGE_SIZE);
-#else
- clear_page_dirty(page);
-#endif
ClearPageMappedToDisk(page);
- ll_remove_from_page_cache(page);
- page_cache_release(page); /* pagecache ref */
+ ll_delete_from_page_cache(page);
}
-#endif /* HAVE_TRUNCATE_COMPLETE_PAGE */
+#endif /* !HAVE_TRUNCATE_COMPLETE_PAGE */
#if !defined(HAVE_D_REHASH_COND) && !defined(HAVE___D_REHASH)
/* megahack */
if (*hash > *end || (*end != *start && *hash == *end)) {
kunmap(page);
lock_page(page);
- ll_truncate_complete_page(page);
+ truncate_complete_page(page->mapping, page);
unlock_page(page);
page_cache_release(page);
page = NULL;
CDEBUG(D_INFO, "Stale readpage page %p: %#lx != %#lx\n",
page, (unsigned long)lhash, (unsigned long)start);
lock_page(page);
- ll_truncate_complete_page(page);
+ truncate_complete_page(page->mapping, page);
unlock_page(page);
page_cache_release(page);
} else {
LL_CDEBUG_PAGE(D_PAGE, page, "truncating\n");
if (llap)
ll_ra_accounting(llap, page->mapping);
- ll_truncate_complete_page(page);
+ truncate_complete_page(page->mapping, page);
}
EXIT;
out:
~CFS_PAGE_MASK);
if (!PageDirty(page) && !page_mapped(page)) {
ll_ra_accounting(llap, page->mapping);
- ll_truncate_complete_page(page);
+ truncate_complete_page(page->mapping, page);
++count;
} else {
LL_CDEBUG_PAGE(D_PAGE, page,
/* File with no objects - one big hole */
/* We use this just for remove_from_page_cache that is not
* exported, we'd make page back up to date. */
- ll_truncate_complete_page(page);
+ truncate_complete_page(page->mapping, page);
clear_page(kmap(page));
kunmap(page);
SetPageUptodate(page);