Page MenuHomeFreeBSD

nvme: Always lock and only avoid processing for recovery state
ClosedPublic

Authored by imp on Jul 18 2024, 6:12 PM.
Tags
None
Referenced Files
F93748254: D46024.id141297.diff
Thu, Sep 12, 4:15 AM
Unknown Object (File)
Mon, Sep 9, 3:57 PM
Unknown Object (File)
Sun, Sep 8, 3:14 PM
Unknown Object (File)
Sat, Sep 7, 6:02 PM
Unknown Object (File)
Sat, Sep 7, 6:02 PM
Unknown Object (File)
Sat, Sep 7, 6:02 PM
Unknown Object (File)
Sat, Sep 7, 6:01 PM
Unknown Object (File)
Sat, Sep 7, 5:54 PM
Subscribers

Details

Summary

When we lose a race with the timeout code, shift towards waiting for
that timeout code to complete so we can acquire the lock. This way we
can make sure we're in 'normal' mode before processing I/O
completions. If we're not in 'normal' mode, then we're resetting and we
should avoid completions.

Sponsored by: Netflix

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

imp requested review of this revision.Jul 18 2024, 6:12 PM
gallatin added inline comments.
sys/dev/nvme/nvme_qpair.c
701

Speaking of name changes, with the direction you're heading in, I'd call this "event_lock" or something, rather than "recovery"

This revision is now accepted and ready to land.Jul 18 2024, 10:00 PM

Misc updates with testing

This revision now requires review to proceed.Jul 19 2024, 4:23 AM
This revision was not accepted when it landed; it landed in state Needs Review.Jul 23 2024, 11:04 PM
This revision was automatically updated to reflect the committed changes.