Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Quick fix for lingering snapdir unmount problems #14462

Merged
merged 1 commit into from
Feb 14, 2023

Conversation

rincebrain
Copy link
Contributor

Unfortunately, even after e79b680, I still, much more rarely, tripped asserts when playing with many ctldir mounts at once.

Since this appears to happen if we dispatched twice too fast trying to do the unmount, and one started before this one, just ignore it. We don't actually need to do anything if someone already started doing it for us, and if that one somehow fails, we'll eventually do it again.

(n.b. - I've been running this patch for almost a year at this point and not had any issues with it, I just literally forgot I never upstreamed it until someone complained about hitting this on master yesterday. Whoopsie.)

Motivation and Context

#11632 kept happening to me, albeit much more rarely.

Description

Just...don't care if we realize someone started the unmount before us.

How Has This Been Tested?

I haven't seen that assert from #11632 trip since I applied this patch, and it's been almost a year.

Types of changes

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Performance enhancement (non-breaking change which improves efficiency)
  • Code cleanup (non-breaking change which makes code smaller or more readable)
  • Breaking change (fix or feature that would cause existing functionality to change)
  • Library ABI change (libzfs, libzfs_core, libnvpair, libuutil and libzfsbootenv)
  • Documentation (a change to man pages or other documentation)

Checklist:

Unfortunately, even after e79b680, I still, much more rarely,
tripped asserts when playing with many ctldir mounts at once.

Since this appears to happen if we dispatched twice too fast, just
ignore it. We don't actually need to do anything if someone already
started doing it for us.

Signed-off-by: Rich Ercolani <[email protected]>
@rincebrain rincebrain force-pushed the ctldir_once_and_for_all branch from 32a5da2 to f918334 Compare February 5, 2023 15:23
Copy link
Contributor

@behlendorf behlendorf left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This makes good sense to me.

@behlendorf behlendorf added the Status: Code Review Needed Ready for review and testing label Feb 6, 2023
@rincebrain rincebrain marked this pull request as ready for review February 6, 2023 18:45
@behlendorf behlendorf added Status: Accepted Ready to integrate (reviewed, tested) and removed Status: Code Review Needed Ready for review and testing labels Feb 14, 2023
@behlendorf behlendorf merged commit cfd5757 into openzfs:master Feb 14, 2023
lundman pushed a commit to openzfsonwindows/openzfs that referenced this pull request Mar 3, 2023
Unfortunately, even after e79b680, I still, much more rarely,
tripped asserts when playing with many ctldir mounts at once.

Since this appears to happen if we dispatched twice too fast, just
ignore it. We don't actually need to do anything if someone already
started doing it for us.

Reviewed-by: Brian Behlendorf <[email protected]>
Signed-off-by: Rich Ercolani <[email protected]>
Closes openzfs#14462
rincebrain added a commit to rincebrain/zfs that referenced this pull request Aug 18, 2023
Unfortunately, even after e79b680, I still, much more rarely,
tripped asserts when playing with many ctldir mounts at once.

Since this appears to happen if we dispatched twice too fast, just
ignore it. We don't actually need to do anything if someone already
started doing it for us.

Reviewed-by: Brian Behlendorf <[email protected]>
Signed-off-by: Rich Ercolani <[email protected]>
Closes openzfs#14462
rincebrain added a commit to rincebrain/zfs that referenced this pull request Aug 18, 2023
Unfortunately, even after e79b680, I still, much more rarely,
tripped asserts when playing with many ctldir mounts at once.

Since this appears to happen if we dispatched twice too fast, just
ignore it. We don't actually need to do anything if someone already
started doing it for us.

Reviewed-by: Brian Behlendorf <[email protected]>
Signed-off-by: Rich Ercolani <[email protected]>
Closes openzfs#14462
behlendorf pushed a commit that referenced this pull request Aug 25, 2023
Unfortunately, even after e79b680, I still, much more rarely,
tripped asserts when playing with many ctldir mounts at once.

Since this appears to happen if we dispatched twice too fast, just
ignore it. We don't actually need to do anything if someone already
started doing it for us.

Reviewed-by: Brian Behlendorf <[email protected]>
Signed-off-by: Rich Ercolani <[email protected]>
Closes #14462
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Status: Accepted Ready to integrate (reviewed, tested)
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants