Page MenuHomeFreeBSD

nvme_ctrlr_enable: Remove delays
ClosedPublic

Authored by imp on Oct 1 2021, 3:27 AM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 2, 3:02 PM
Unknown Object (File)
Dec 9 2024, 3:20 AM
Unknown Object (File)
Nov 14 2024, 10:35 PM
Unknown Object (File)
Nov 14 2024, 10:20 PM
Unknown Object (File)
Nov 14 2024, 10:02 PM
Unknown Object (File)
Nov 14 2024, 4:17 PM
Unknown Object (File)
Oct 24 2024, 6:46 AM
Unknown Object (File)
Oct 4 2024, 3:41 PM
Subscribers

Details

Summary

Remove delays after writing the administrative queue registers. These
delays are from the very earliest days of the driver (they are in the
first commit) and were most likely vestiges of the Chatham NVMe
prototype card that was used to create this driver. Many of the
workarounds necessary for it aren't necessary for standards compliant
cards. The original driver had other areas marked for Chatham, but these
were not. They are unneeded. There's three lines of supporting evidence.

First, the NVMe standards make no mention of a delay time after these
registers are written. Second, the Linux driver doesn't have them, even
as an option. Third, all my nvme cards work w/o them.

To be safe, add a write barrier between setting up the admin queue and
enabling the controller.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 41879
Build 38767: arc lint + arc unit

Event Timeline

imp requested review of this revision.Oct 1 2021, 3:27 AM

I also don't see a point in DELAY()'s. Just thinking would it be right to use bus_space_barrier() before cc write for some non-x86, since it depends on the other registers state?

This revision is now accepted and ready to land.Oct 1 2021, 2:19 PM

Doesn't build for me.

sys/dev/nvme/nvme_ctrlr.c
59
--- nvme_ctrlr.o ---
/usr/src/sys/dev/nvme/nvme_ctrlr.c:60:11: error: too few arguments to function call, expected 5, have 4
            flags);
                 ^
./x86/bus.h:1002:1: note: 'bus_space_barrier' declared here
bus_space_barrier(bus_space_tag_t tag __unused, bus_space_handle_t bsh __unused,
^
sys/dev/nvme/nvme_ctrlr.c
59

I'm an idiot... I got this too, fix it, but somehow uploaded the wrong one :(

this time with right barrier

This revision now requires review to proceed.Oct 1 2021, 4:38 PM
imp marked an inline comment as done.
This revision was not accepted when it landed; it landed in state Needs Review.Oct 1 2021, 4:56 PM
This revision was automatically updated to reflect the committed changes.