linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
* strange locking __find_get_swapcache_page()
@ 2001-07-30 19:10 Rik van Riel
  2001-07-31  1:44 ` Linus Torvalds
  0 siblings, 1 reply; 5+ messages in thread
From: Rik van Riel @ 2001-07-30 19:10 UTC (permalink / raw)
  To: Linus Torvalds; +Cc: linux-mm, Andrea Arcangeli, Andrew Morton, Marcelo Tosatti

Hi,

I've encountered a suspicious piece of code in filemap.c:

struct page * __find_get_swapcache_page( ... )
...
        /*
         * We need the LRU lock to protect against page_launder().
         */

        spin_lock(&pagecache_lock);
        page = __find_page_nolock(mapping, offset, *hash);
        if (page) {
                spin_lock(&pagemap_lru_lock);
                if (PageSwapCache(page))
                        page_cache_get(page);
                else
                        page = NULL;
                spin_unlock(&pagemap_lru_lock);
        }
        spin_unlock(&pagecache_lock);


Question is ... WHY do we need the pagemap_lru_lock ?

Page_launder() never removes the page from the swap
cache, that is only done by reclaim_page(), and done
while holding the pagecache_lock.

The other places where pages are removed from the
swap cache (tmpfs and free_page_and_swap_cache)
also hold the pagecache_lock.

Taking the pagemap_lru_lock seems unneeded to me...

regards,

Rik
--
Executive summary of a recent Microsoft press release:
   "we are concerned about the GNU General Public License (GPL)"


		http://www.surriel.com/
http://www.conectiva.com/	http://distro.conectiva.com/


--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org.  For more info on Linux MM,
see: http://www.linux-mm.org/

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2001-07-31 17:16 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2001-07-30 19:10 strange locking __find_get_swapcache_page() Rik van Riel
2001-07-31  1:44 ` Linus Torvalds
2001-07-31  9:51   ` Rik van Riel
2001-07-31 10:19   ` Andrew Morton
2001-07-31 17:16     ` Linus Torvalds

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox