[PATCH] nvme-pci: expose active quirks in sysfs

Maurizio Lombardi mlombard at bsdbackstore.eu
Wed Oct 29 23:57:54 PDT 2025


On Thu Oct 30, 2025 at 7:55 AM CET, Maurizio Lombardi wrote:
> On Thu Oct 30, 2025 at 7:46 AM CET, Chaitanya Kulkarni wrote:
>> On 10/29/25 23:18, Maurizio Lombardi wrote:
>>
>> how about something like this totally untested ?
>>
>> drivers/nvme/host/pci.c | 64 +++++++++++++++++++++++++++++++++++++++++
>>   1 file changed, 64 insertions(+)
>>
>> diff --git a/drivers/nvme/host/pci.c b/drivers/nvme/host/pci.c
>> index c916176bd9f0..ea9904e2dbd9 100644
>> --- a/drivers/nvme/host/pci.c
>> +++ b/drivers/nvme/host/pci.c
>> @@ -2497,6 +2497,69 @@ static ssize_t cmbsz_show(struct device *dev, 
>> struct device_attribute *attr,
>>   }
>>   static DEVICE_ATTR_RO(cmbsz);
>>
>> +static const struct {
>> +    unsigned long quirk;
>> +    const char *name;
>> +} nvme_quirk_info[] = {
>> +    { NVME_QUIRK_STRIPE_SIZE,        "STRIPE_SIZE" },
>> +    { NVME_QUIRK_IDENTIFY_CNS,        "IDENTIFY_CNS" },
>> +    { NVME_QUIRK_DEALLOCATE_ZEROES,        "DEALLOCATE_ZEROES" },
>> +    { NVME_QUIRK_DELAY_BEFORE_CHK_RDY, "DELAY_BEFORE_CHK_RDY" },
>> +    { NVME_QUIRK_NO_APST,            "NO_APST" },
>> +    { NVME_QUIRK_NO_DEEPEST_PS,        "NO_DEEPEST_PS" },
>> +    { NVME_QUIRK_QDEPTH_ONE,        "QDEPTH_ONE" },
>> +    { NVME_QUIRK_MEDIUM_PRIO_SQ,        "MEDIUM_PRIO_SQ" },
>> +    { NVME_QUIRK_IGNORE_DEV_SUBNQN,        "IGNORE_DEV_SUBNQN" },
>> +    { NVME_QUIRK_DISABLE_WRITE_ZEROES, "DISABLE_WRITE_ZEROES" },
>> +    { NVME_QUIRK_SIMPLE_SUSPEND,        "SIMPLE_SUSPEND" },
>> +    { NVME_QUIRK_SINGLE_VECTOR,        "SINGLE_VECTOR" },
>> +    { NVME_QUIRK_128_BYTES_SQES,        "128_BYTES_SQES" },
>> +    { NVME_QUIRK_SHARED_TAGS,        "SHARED_TAGS" },
>> +    { NVME_QUIRK_NO_TEMP_THRESH_CHANGE, "NO_TEMP_THRESH_CHANGE" },
>> +    { NVME_QUIRK_NO_NS_DESC_LIST,        "NO_NS_DESC_LIST" },
>> +    { NVME_QUIRK_DMA_ADDRESS_BITS_48,    "DMA_ADDRESS_BITS_48" },
>> +    { NVME_QUIRK_SKIP_CID_GEN,        "SKIP_CID_GEN" },
>> +    { NVME_QUIRK_BOGUS_NID,            "BOGUS_NID" },
>> +    { NVME_QUIRK_NO_SECONDARY_TEMP_THRESH, "NO_SECONDARY_TEMP_THRESH" },
>> +    { NVME_QUIRK_FORCE_NO_SIMPLE_SUSPEND, "FORCE_NO_SIMPLE_SUSPEND" },
>> +    { NVME_QUIRK_BROKEN_MSI,        "BROKEN_MSI" },
>> +    { NVME_QUIRK_DMAPOOL_ALIGN_512,        "DMAPOOL_ALIGN_512" },
>> +};
>
> Hmm, NVME_QUIRK_DMAPOOL_ALIGN_512 is "1 << 22", wouldn't this create 
> an enormous array?

Sorry, my mistake, this is completely ok.

So yes, it would be fine, the only drawback is that with the switch()
the compiler would raise a warning if someone adds a new quirk and
forgets to add its name to the nvme_quirk_name() function.

>
> Maurizio
>
>> +
>> +static int nvme_get_quirks_string(unsigned long quirks, char *buf, 
>> size_t buf_len)
>> +{
>> +    size_t len = 0;
>> +    int i;
>> +
>> +    if (!quirks) {
>> +        len = scnprintf(buf, buf_len, "No quirks enabled\n");
>> +        return len;
>> +    }
>> +
>> +    len += scnprintf(buf + len, buf_len - len, "Active quirks:\n");
>> +
>> +    for (i = 0; i < ARRAY_SIZE(nvme_quirk_info); i++) {
>> +        if (quirks & nvme_quirk_info[i].quirk)
>> +            len += scnprintf(buf + len, buf_len - len, " %s\n",
>> +                     nvme_quirk_info[i].name);
>> +    }
>> +
>> +    return len;
>> +}
>> +
>> +static ssize_t quirks_show(struct device *dev, struct device_attribute 
>> *attr,
>> +               char *buf)
>> +{
>> +    struct nvme_dev *ndev = to_nvme_dev(dev_get_drvdata(dev));
>> +    int len;
>> +
>> +    len = sysfs_emit(buf, "0x%016lx\n\n", ndev->ctrl.quirks);
>> +    len += nvme_get_quirks_string(ndev->ctrl.quirks, buf + len, 
>> PAGE_SIZE - len);
>> +
>> +    return len;
>> +}
>> +static DEVICE_ATTR_RO(quirks);
>> +
>>   static ssize_t hmb_show(struct device *dev, struct device_attribute *attr,
>>               char *buf)
>>   {
>> @@ -2557,6 +2620,7 @@ static struct attribute *nvme_pci_attrs[] = {
>>       &dev_attr_cmbloc.attr,
>>       &dev_attr_cmbsz.attr,
>>       &dev_attr_hmb.attr,
>> +    &dev_attr_quirks.attr,
>>       NULL,
>>   };




More information about the Linux-nvme mailing list