[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