diff options
author | Hugh Dickins <hugh@veritas.com> | 2009-01-06 17:39:34 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-01-06 18:59:03 -0500 |
commit | 7b1fe59793e61f826bef053107b57b23954833bb (patch) | |
tree | 0ac769c48123c5d0770b0a0f88bad9e6318b83ed /mm/swapfile.c | |
parent | ab967d86015a19777955370deebc8262d50fed63 (diff) |
mm: reuse_swap_page replaces can_share_swap_page
A good place to free up old swap is where do_wp_page(), or do_swap_page(),
is about to redirty the page: the data on disk is then stale and won't be
read again; and if we do decide to write the page out later, using the
previous swap location makes an unnecessary disk seek very likely.
So give can_share_swap_page() the side-effect of delete_from_swap_cache()
when it safely can. And can_share_swap_page() was always a misleading
name, the more so if it has a side-effect: rename it reuse_swap_page().
Irrelevant cleanup nearby: remove swap_token_default_timeout definition
from swap.h: it's used nowhere.
Signed-off-by: Hugh Dickins <hugh@veritas.com>
Cc: Lee Schermerhorn <lee.schermerhorn@hp.com>
Acked-by: Rik van Riel <riel@redhat.com>
Cc: Nick Piggin <nickpiggin@yahoo.com.au>
Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Cc: Robin Holt <holt@sgi.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm/swapfile.c')
-rw-r--r-- | mm/swapfile.c | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/mm/swapfile.c b/mm/swapfile.c index 214e90b94946..bfd4ee59cb88 100644 --- a/mm/swapfile.c +++ b/mm/swapfile.c | |||
@@ -326,17 +326,24 @@ static inline int page_swapcount(struct page *page) | |||
326 | } | 326 | } |
327 | 327 | ||
328 | /* | 328 | /* |
329 | * We can use this swap cache entry directly | 329 | * We can write to an anon page without COW if there are no other references |
330 | * if there are no other references to it. | 330 | * to it. And as a side-effect, free up its swap: because the old content |
331 | * on disk will never be read, and seeking back there to write new content | ||
332 | * later would only waste time away from clustering. | ||
331 | */ | 333 | */ |
332 | int can_share_swap_page(struct page *page) | 334 | int reuse_swap_page(struct page *page) |
333 | { | 335 | { |
334 | int count; | 336 | int count; |
335 | 337 | ||
336 | VM_BUG_ON(!PageLocked(page)); | 338 | VM_BUG_ON(!PageLocked(page)); |
337 | count = page_mapcount(page); | 339 | count = page_mapcount(page); |
338 | if (count <= 1 && PageSwapCache(page)) | 340 | if (count <= 1 && PageSwapCache(page)) { |
339 | count += page_swapcount(page); | 341 | count += page_swapcount(page); |
342 | if (count == 1 && !PageWriteback(page)) { | ||
343 | delete_from_swap_cache(page); | ||
344 | SetPageDirty(page); | ||
345 | } | ||
346 | } | ||
340 | return count == 1; | 347 | return count == 1; |
341 | } | 348 | } |
342 | 349 | ||