Page MenuHomeFreeBSD

zfs_mount(MS_REMOUNT): protect zfs_(un)register_callbacks calls
ClosedPublic

Authored by avg on Jun 19 2015, 7:30 AM.
Tags
None
Referenced Files
F107924690: D2865.id6320.diff
Sun, Jan 19, 12:42 PM
Unknown Object (File)
Fri, Jan 17, 8:05 PM
Unknown Object (File)
Wed, Jan 15, 5:49 AM
Unknown Object (File)
Oct 11 2024, 7:51 AM
Unknown Object (File)
Oct 11 2024, 7:51 AM
Unknown Object (File)
Oct 11 2024, 7:01 AM
Unknown Object (File)
Oct 9 2024, 2:53 PM
Unknown Object (File)
Oct 6 2024, 12:41 PM
Subscribers

Details

Summary

We now take z_teardown_lock as a writer to ensure that there is no
I/O while the filesystem state is in a flux.
Also, zfs_suspend_fs() -> zfsvfs_teardown() call zfs_unregister_callbacks()
and zfs_resume_fs() -> zfsvfs_setup() call zfs_unregister_callbacks().
Previously there was no synchronization between those calls and the calls
in the re-mounting case. That could lead to concurrent execution
and a crash.

https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=180060
http://article.gmane.org/gmane.os.illumos.zfs/2833

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
No Lint Coverage
Unit
No Test Coverage

Event Timeline

avg retitled this revision from to zfs_mount(MS_REMOUNT): protect zfs_(un)register_callbacks calls.
avg updated this object.
avg edited the test plan for this revision. (Show Details)
avg added a reviewer: mahrens.
avg added a subscriber: ZFS.
sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_vfsops.c
1256

I wonder if we should mark zfs_unregister_callbacks static, just like zfs_register_callbacks? (Or is this intentional to make them DTrace proble eligible?)

1934

I'm not very convinced that we can safely do unregister without having z_teardown_lock held here... If it's safe, maybe we should document it in the comment?

sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_vfsops.c
1256

It looks like this function can be made static, but I'd do it as a separate commit.

1934

If !unmounting we, in fact, do hold the lock here.
And if unmounting then no other thread can operate on the filesystem because of z_unmounted.
See line 1886 above and 1918 too.

delphij edited edge metadata.
This revision is now accepted and ready to land.Jun 19 2015, 6:42 PM
pho edited edge metadata.

No problems seen with the few zfs tests I have.

mahrens edited edge metadata.
will edited edge metadata.

LGTM.