On 4/22/24 12:49, Keith Busch wrote: > On Mon, Apr 22, 2024 at 12:28:23PM -0400, Sean Anderson wrote: >> Sandisk SN530 NVMe drives have broken MSIs. On systems without MSI-X >> support, all commands time out resulting in the following message: >> >> nvme nvme0: I/O tag 12 (100c) QID 0 timeout, completion polled >> >> These timeouts cause the boot to take an excessively-long time (over 20 >> minutes) while the initial command queue is flushed. >> >> Address this by adding a quirk for drives with buggy MSIs. The lspci >> output for this device (recorded on a system with MSI-X support) is: > > Based on your description, the patch looks good. This will fallback to > legacy emulated pin interrupts, and that's better than timeout polling, > but will still appear sluggish compared to MSI's. Is there an errata > from the vendor on this? I'm just curious if the bug is at the Device ID > level, and not something we could constrain to a particular model or > firmware revision. I wasn't able to find any errata for this drive. I wasn't able to determine if there are any firmware updates for this drive (FWIW I have version "21160001"). I'll contact WD and see if they know about this issue. [1] https://www.westerndigital.com/products/internal-drives/pc-sn530-ssd >> 02:00.0 Non-Volatile memory controller: Sandisk Corp Device 5008 (rev 01) (prog-if 02 [NVM Express]) >> Subsystem: Sandisk Corp Device 5008 >> Flags: bus master, fast devsel, latency 0, IRQ 16, NUMA node 0 >> Memory at f7e00000 (64-bit, non-prefetchable) [size=16K] >> Memory at f7e04000 (64-bit, non-prefetchable) [size=256] >> Capabilities: [80] Power Management version 3 >> Capabilities: [90] MSI: Enable- Count=1/32 Maskable- 64bit+ >> Capabilities: [b0] MSI-X: Enable+ Count=17 Masked- > > Interesting, the MSI capability does look weird here. I've never seen > MSI-x count smaller than the MSI's. As long as both work, though, I > think nvme would actually prefer whichever is bigger! --Sean