* Re: msync() needed before munmap() when writing to shared mapping? [not found] ` <20040416154652.7ab27e79.akpm@osdl.org> @ 2004-04-16 23:10 ` Jamie Lokier 2004-04-16 23:59 ` Andrew Morton 0 siblings, 1 reply; 2+ messages in thread From: Jamie Lokier @ 2004-04-16 23:10 UTC (permalink / raw) To: Andrew Morton; +Cc: linux-kernel, linux-mm Andrew Morton wrote: > Jamie Lokier <jamie@shareable.org> wrote: > > I've followed the logic from do_munmap() and it looks good: > > unmap_vmas->zap_pte_range->page_remove_rmap->set_page_dirty. > > > > Can someone confirm this is correct, please? > > yup, zap_pte_range() transfers pte dirtiness into pagecache dirtiness when > tearing down the mapping, leaving the dirty page floating about in > pagecache for kupdate/kswapd/fsync to catch. Longstanding behaviour. Thanks. A related question. The comment for MADV_DONTNEED says: * NB: This interface discards data rather than pushes it out to swap, * as some implementations do. This has performance implications for * applications like large transactional databases which want to discard * pages in anonymous maps after committing to backing store the data * that was kept in them. There is no reason to write this data out to * the swap area if the application is discarding it. * * An interface that causes the system to free clean pages and flush * dirty pages is already available as msync(MS_INVALIDATE). MADV_DONTNEED calls zap_page_range(). That propagates dirtiness into the pagecache. So it *doesn't* "discard data rather than push it out to swap", if the same dirty data is mapped elsewhere e.g. as a shared anonymous mapping, does it? The comment also mentions MS_INVALIDATE, but MS_INVALIDATE doesn't do what the comment says and doesn't implement anything like POSIX either. (Linux's MS_INVALIDATE is practically equivalent to MS_ASYNC). Is there a call which does what the command about MS_INVALIDATE says, i.e. free clean pages and flush dirty ones? Thanks, -- Jamie -- 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/ . Don't email: <a href=mailto:"aart@kvack.org"> aart@kvack.org </a> ^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: msync() needed before munmap() when writing to shared mapping? 2004-04-16 23:10 ` msync() needed before munmap() when writing to shared mapping? Jamie Lokier @ 2004-04-16 23:59 ` Andrew Morton 0 siblings, 0 replies; 2+ messages in thread From: Andrew Morton @ 2004-04-16 23:59 UTC (permalink / raw) To: Jamie Lokier; +Cc: linux-kernel, linux-mm Jamie Lokier <jamie@shareable.org> wrote: > > ... > A related question. The comment for MADV_DONTNEED says: > > * NB: This interface discards data rather than pushes it out to swap, > * as some implementations do. This has performance implications for > * applications like large transactional databases which want to discard > * pages in anonymous maps after committing to backing store the data > * that was kept in them. There is no reason to write this data out to > * the swap area if the application is discarding it. > * > * An interface that causes the system to free clean pages and flush > * dirty pages is already available as msync(MS_INVALIDATE). > > MADV_DONTNEED calls zap_page_range(). > That propagates dirtiness into the pagecache. > > So it *doesn't* "discard data rather than push it out to swap", if the > same dirty data is mapped elsewhere e.g. as a shared anonymous > mapping, does it? Sure. If some other process is using the same pages we don't go toss them away. > The comment also mentions MS_INVALIDATE, but MS_INVALIDATE doesn't do > what the comment says and doesn't implement anything like POSIX > either. (Linux's MS_INVALIDATE is practically equivalent to MS_ASYNC). Seems that way - MS_INVALIDATE will simply propagate pte dirtiness into page dirtiness. For non-file-backed mappings it is a no-op. > Is there a call which does what the command about MS_INVALIDATE says, > i.e. free clean pages and flush dirty ones? Not really. What is a clean anonymous page? If it's ever been written to, it's conceptually dirty, whether or not it is physically dirty. ie: if you invalidate it, you've lost your data. I guess you could get a similar result by munmap() and then mmapping it again. -- 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/ . Don't email: <a href=mailto:"aart@kvack.org"> aart@kvack.org </a> ^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2004-04-16 23:59 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
[not found] <20040416220223.GA27084@mail.shareable.org>
[not found] ` <20040416154652.7ab27e79.akpm@osdl.org>
2004-04-16 23:10 ` msync() needed before munmap() when writing to shared mapping? Jamie Lokier
2004-04-16 23:59 ` Andrew Morton
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox