On Wed 23-04-14 13:11:20, Hugh Dickins wrote: > On Wed, 23 Apr 2014, Jan Kara wrote: > > Now I'm not sure how to fix Linus' patches. For all I care we could just > > rip out pte dirty bit handling for file mappings. However last time I > > suggested this you corrected me that tmpfs & ramfs need this. I assume this > > is still the case - however, given we unconditionally mark the page dirty > > for write faults, where exactly do we need this? > > Good, Linus has already replied to you on this this: you appear to be > suggesting that there would be no issue, and Linus's patches would not > be needed at all, if only tmpfs and ramfs played by the others' rules. No, that's not what I wanted to say. I wanted to say - keep Linus' patches and additionally rip out pte dirty bit handling for "normal" filesystems to not confuse filesystems with dirty pages where they don't expect them. But after reading replies and thinking about it even that is not enough because then we would again miss writes done by other cpus after we tore down rmap but before we flushed TLBs. > But (sadly) I don't think that's so: just because zap_pte_range()'s > current "if (pte_dirty) set_page_dirty" does nothing on most filesystems, > does not imply that nothing needs to be done on most filesystems, now > that we're alert to the delayed TLB flushing issue. > > Just to answer your (interesting but irrelevant!) question about tmpfs > and ramfs: their issue is with read faults which bring in a zeroed page, > with page and pte not marked dirty. If userspace modifies that page, the > pte_dirty needs to be propagated through to PageDirty, to prevent page > reclaim from simply freeing the apparently clean page. Ah, I keep forgetting about that vma_wants_writenotify() thing in mmap which changes whether a shared page is mapped RW or RO on read fault. Honza -- Jan Kara <jack@xxxxxxx> SUSE Labs, CR -- 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>