Page MenuHomeFreeBSD

For unlinked files, do not msync(2) or sync on inactivation.
ClosedPublic

Authored by kib on Sep 19 2017, 8:55 AM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 9, 10:19 AM
Unknown Object (File)
Mon, Jan 6, 8:53 AM
Unknown Object (File)
Sat, Jan 4, 6:04 AM
Unknown Object (File)
Wed, Jan 1, 1:51 AM
Unknown Object (File)
Tue, Dec 31, 2:44 AM
Unknown Object (File)
Mon, Dec 30, 1:55 AM
Unknown Object (File)
Sun, Dec 29, 2:56 AM
Unknown Object (File)
Sat, Dec 28, 2:53 AM
Subscribers

Details

Summary

One consequence of the patch is that msyncing unlinked file mappings no longer reduces the amount of the dirty memory in the system, but I do not think that there are users of msync(2) that utilize it for such side-effect.

The patch is reported to significantly help with the firefox performance.

PR: 222356

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 11628

Event Timeline

As long as the page daemon will still launder the pages when we are short of memory, I don't see a problem with msync() ignoring them.

In D12411#257518, @alc wrote:

As long as the page daemon will still launder the pages when we are short of memory, I don't see a problem with msync() ignoring them.

Yes, this only prevents syncing on explicit msync(2), and on the vnode inactivation. Since the inactivation for unlinked UFS vnode triggers reclamation, the writes there are discarded immediately after finished.

alc added inline comments.
sys/kern/vfs_subr.c
3058

Since "obj" is no longer used unconditionally, I would write "(obj = vp->v_object) != NULL" here.

This revision is now accepted and ready to land.Sep 19 2017, 4:15 PM
This revision was automatically updated to reflect the committed changes.