Page MenuHomeFreeBSD

tmpfs: reimplement the mtime scan to use the lazy list
AbandonedPublic

Authored by mjg on Jan 30 2020, 4:24 AM.
Tags
None
Referenced Files
F107098532: D23423.diff
Fri, Jan 10, 2:24 AM
Unknown Object (File)
Wed, Jan 8, 4:35 AM
Unknown Object (File)
Sat, Jan 4, 8:34 PM
Unknown Object (File)
Tue, Dec 17, 11:44 PM
Unknown Object (File)
Fri, Dec 13, 1:32 PM
Unknown Object (File)
Dec 1 2024, 4:14 AM
Unknown Object (File)
Nov 24 2024, 5:53 PM
Unknown Object (File)
Nov 23 2024, 5:39 AM

Details

Reviewers
kib
jeff
Summary

Vast majority of vnodes are not mmaped for writing and the entire list scan is highly wasteful.

Keep a hold on the vnode to prevent it from disappearing before we managed to inspect it.

Diff Detail

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

Event Timeline

sys/fs/tmpfs/tmpfs_vnops.c
1387

I think that good enough substitute for this flag is just tn_obj->ref_count > 1. It might be slightly too aggressive causing false positives (both transient and e.g. CoW ro) but it has a nice property of reducing to false for non-reclaimed vnode when the last mapping is destroyed.

sys/fs/tmpfs/tmpfs_vnops.c
1387

you mean to denote the extra hold with increased obj->ref_count? i don't see how to verify we got it against said counter.

BTW, why not use lazy list processing for mtime update, and remove tmpfs_update_mtime() ?

sys/fs/tmpfs/tmpfs_vnops.c
1387

No, I mean that use obj->ref_count > 1 as the indicator of the presence of a mapping, instead of the flag.

So the original code had:

+               /*
+                * Handle lazy updates of mtime from writes to mmaped
+                * regions.  Use MNT_VNODE_FOREACH_ALL instead of
+                * MNT_VNODE_FOREACH_ACTIVE, since unmap of the
+                * tmpfs-backed vnode does not call vinactive(), due
+                * to vm object type is OBJT_SWAP.
+                */

In the patch the problem is combated with putting the vnode on the lazy list with an explicit hold. Should the mapping disappear, we will find it anyway and remove the extra attachment. However, the vnode may be put on the list for other reasons (in particular just being opened for writing) and consequently there needs to be a way to denote that there is an extra hold. As such, inspecting the write count is in my opinion insufficient.