On 03/13/2013 10:33 AM, Seth Jennings wrote: > The periodic writeback that Rob mentions would go something like this > for zswap: > > --- > mm/filemap.c | 3 +-- > mm/zswap.c | 63 +++++++++++++++++++++++++++++++++++++++++++++++++++++----- > 2 files changed, 59 insertions(+), 7 deletions(-) > > diff --git a/mm/filemap.c b/mm/filemap.c > index 83efee7..fe63e95 100644 > --- a/mm/filemap.c > +++ b/mm/filemap.c > @@ -735,12 +735,11 @@ repeat: > if (page && !radix_tree_exception(page)) { > lock_page(page); > /* Has the page been truncated? */ > - if (unlikely(page->mapping != mapping)) { > + if (unlikely(page_mapping(page) != mapping)) { > unlock_page(page); > page_cache_release(page); > goto repeat; > } > - VM_BUG_ON(page->index != offset); A little followup here, previously we were using find_get_page() in zswap_get_swap_cache_page() and if the page was already in the swap cache, then we aborted the writeback of that entry. However, if we do wish to write the page back, as is the case in periodic writeback, we must find _and_ lock it which suggests using find_lock_page() instead. My first attempt to just do a s/find_get_page/find_lock_page/ failed because, for entries that were already in the swap cache, we would hang in the repeat loop of find_lock_page() forever because page->mapping of pages in the swap cache is not set to &swapper_space. However, there is logic in the page_mapping() function to handle swap cache entries, hence the change here. Also page->index != offset for swap cache pages so I just took out the VM_BUG_ON(). Another solution would be to just set the mapping and index fields of swap cache pages, if those fields (or fields in the same union) aren't being used already. Seth -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>