All of lore.kernel.org
 help / color / mirror / Atom feed
* [uml-devel] madvise(DONTNEED) on tmpfs pages instead of /dev/anon
@ 2005-08-10 19:36 Blaisorblade
  2005-08-12 16:38 ` [uml-devel] " Jeff Dike
  0 siblings, 1 reply; 5+ messages in thread
From: Blaisorblade @ 2005-08-10 19:36 UTC (permalink / raw)
  To: Jeff Dike, Rik van Riel; +Cc: user-mode-linux-devel

UML would need to free file-backed pages anonymously mapped from the host 
memory. In all relevant cases, those pages are file-backed from tmpfs (or 
ramfs, but that can also be excluded)

About this, I was thinking back to what Rik said in Ottawa at the OLS. He said 
"just use madvise(DONTNEED) on it", but I remarked that the pages were 
file-backed.

Actually, however, since backing store for tmpfs is just pagecache/swapcache 
memory,

I have the doubt that madvise(DONTNEED) already does what we need, and if not 
that it might be easily fixed (since zap_page_range->unmap_vmas -> 
unmap_page_range accept a range of pages to be flushed - that was a recent 
change from Hugh Dickins).

For UML, the patch to use this support should be trivial (given in 
pseudocode):

+//remember virt, is an address in the (guest) kernel page range
int physmem_remove_mapping(void *virt)
{
        struct phys_desc *desc;

        virt = (void *) ((unsigned long) virt & PAGE_MASK);
        desc = find_phys_mapping(virt);
-        if(desc == NULL)
-                return(0);
+        if(desc == NULL) {
+                madvise(virt, PAGE_SIZE, MADV_DONTNEED);
+                return 0;
+       }

        remove_mapping(desc);
        return(1);
}

-- 
Inform me of my mistakes, so I can keep imitating Homer Simpson's "Doh!".
Paolo Giarrusso, aka Blaisorblade (Skype ID "PaoloGiarrusso", ICQ 215621894)
http://www.user-mode-linux.org/~blaisorblade


	

	
		
___________________________________ 
Yahoo! Mail: gratis 1GB per i messaggi e allegati da 10MB 
http://mail.yahoo.it



-------------------------------------------------------
SF.Net email is Sponsored by the Better Software Conference & EXPO
September 19-22, 2005 * San Francisco, CA * Development Lifecycle Practices
Agile & Plan-Driven Development * Managing Projects & Teams * Testing & QA
Security * Process Improvement & Measurement * http://www.sqe.com/bsce5sf
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel

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

end of thread, other threads:[~2005-08-26 15:11 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-08-10 19:36 [uml-devel] madvise(DONTNEED) on tmpfs pages instead of /dev/anon Blaisorblade
2005-08-12 16:38 ` [uml-devel] " Jeff Dike
2005-08-12 17:00   ` Blaisorblade
2005-08-22 20:24     ` Jeff Dike
2005-08-26 15:06       ` Blaisorblade

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.