Message ID | 20200217141031.22090-2-kai.heng.feng@canonical.com |
---|---|
State | New |
Headers | show |
Series | [1/1] UBUNTU: SAUCE: ata: ahci: Add sysfs attribute to show remapped NVMe device count | expand |
On Mon, Feb 17, 2020 at 10:10:31PM +0800, Kai-Heng Feng wrote: > BugLink: https://bugs.launchpad.net/bugs/1863621 > > Add a new sysfs attribute to show how many NVMe devices are remapped. > > Userspace like distro installer can use this info to ask user to change > the BIOS setting. > > Signed-off-by: Kai-Heng Feng <kai.heng.feng@canonical.com> We should be cautious about adding new usespace interfaces which are not upstream. Have you tried sending this patch upstream? If so, what was the response? Thanks, Seth
> On Feb 20, 2020, at 00:17, Seth Forshee <seth.forshee@canonical.com> wrote: > > On Mon, Feb 17, 2020 at 10:10:31PM +0800, Kai-Heng Feng wrote: >> BugLink: https://bugs.launchpad.net/bugs/1863621 >> >> Add a new sysfs attribute to show how many NVMe devices are remapped. >> >> Userspace like distro installer can use this info to ask user to change >> the BIOS setting. >> >> Signed-off-by: Kai-Heng Feng <kai.heng.feng@canonical.com> > > We should be cautious about adding new usespace interfaces which are not > upstream. Have you tried sending this patch upstream? Here's the link: https://lkml.org/lkml/2020/2/7/169 > If so, what was > the response? Currently no response. Just pinged them. Kai-Heng > > Thanks, > Seth
On Thu, Feb 20, 2020 at 01:59:26PM +0800, Kai-Heng Feng wrote: > > > > On Feb 20, 2020, at 00:17, Seth Forshee <seth.forshee@canonical.com> wrote: > > > > On Mon, Feb 17, 2020 at 10:10:31PM +0800, Kai-Heng Feng wrote: > >> BugLink: https://bugs.launchpad.net/bugs/1863621 > >> > >> Add a new sysfs attribute to show how many NVMe devices are remapped. > >> > >> Userspace like distro installer can use this info to ask user to change > >> the BIOS setting. > >> > >> Signed-off-by: Kai-Heng Feng <kai.heng.feng@canonical.com> > > > > We should be cautious about adding new usespace interfaces which are not > > upstream. Have you tried sending this patch upstream? > > Here's the link: > https://lkml.org/lkml/2020/2/7/169 > > > If so, what was > > the response? > > Currently no response. Just pinged them. Thanks, let's hold off for a little longer and see if you get a response.
Hi Seth, > On Feb 20, 2020, at 21:28, Seth Forshee <seth.forshee@canonical.com> wrote: > > On Thu, Feb 20, 2020 at 01:59:26PM +0800, Kai-Heng Feng wrote: >> >> >>> On Feb 20, 2020, at 00:17, Seth Forshee <seth.forshee@canonical.com> wrote: >>> >>> On Mon, Feb 17, 2020 at 10:10:31PM +0800, Kai-Heng Feng wrote: >>>> BugLink: https://bugs.launchpad.net/bugs/1863621 >>>> >>>> Add a new sysfs attribute to show how many NVMe devices are remapped. >>>> >>>> Userspace like distro installer can use this info to ask user to change >>>> the BIOS setting. >>>> >>>> Signed-off-by: Kai-Heng Feng <kai.heng.feng@canonical.com> >>> >>> We should be cautious about adding new usespace interfaces which are not >>> upstream. Have you tried sending this patch upstream? >> >> Here's the link: >> https://lkml.org/lkml/2020/2/7/169 >> >>> If so, what was >>> the response? >> >> Currently no response. Just pinged them. > > Thanks, let's hold off for a little longer and see if you get a > response. Seems like linux-ide mailing list and its maintainers are a little dormant recently. Can we merge this patch to Ubuntu kernel due to the silence? Kai-Heng
diff --git a/drivers/ata/ahci.c b/drivers/ata/ahci.c index 11ea1aff40db..cdbd995a7a6b 100644 --- a/drivers/ata/ahci.c +++ b/drivers/ata/ahci.c @@ -1488,7 +1488,7 @@ static irqreturn_t ahci_thunderx_irq_handler(int irq, void *dev_instance) static void ahci_remap_check(struct pci_dev *pdev, int bar, struct ahci_host_priv *hpriv) { - int i, count = 0; + int i; u32 cap; /* @@ -1509,13 +1509,14 @@ static void ahci_remap_check(struct pci_dev *pdev, int bar, continue; /* We've found a remapped device */ - count++; + hpriv->remapped_nvme++; } - if (!count) + if (!hpriv->remapped_nvme) return; - dev_warn(&pdev->dev, "Found %d remapped NVMe devices.\n", count); + dev_warn(&pdev->dev, "Found %u remapped NVMe devices.\n", + hpriv->remapped_nvme); dev_warn(&pdev->dev, "Switch your BIOS from RAID to AHCI mode to use them.\n"); @@ -1635,6 +1636,18 @@ static void ahci_intel_pcs_quirk(struct pci_dev *pdev, struct ahci_host_priv *hp } } +static ssize_t remapped_nvme_show(struct device *dev, + struct device_attribute *attr, + char *buf) +{ + struct ata_host *host = dev_get_drvdata(dev); + struct ahci_host_priv *hpriv = host->private_data; + + return sprintf(buf, "%u\n", hpriv->remapped_nvme); +} + +static DEVICE_ATTR_RO(remapped_nvme); + static int ahci_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) { unsigned int board_id = ent->driver_data; @@ -1735,6 +1748,10 @@ static int ahci_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) /* detect remapped nvme devices */ ahci_remap_check(pdev, ahci_pci_bar, hpriv); + sysfs_add_file_to_group(&pdev->dev.kobj, + &dev_attr_remapped_nvme.attr, + NULL); + /* must set flag prior to save config in order to take effect */ if (ahci_broken_devslp(pdev)) hpriv->flags |= AHCI_HFLAG_NO_DEVSLP; @@ -1886,6 +1903,9 @@ static void ahci_shutdown_one(struct pci_dev *pdev) static void ahci_remove_one(struct pci_dev *pdev) { + sysfs_remove_file_from_group(&pdev->dev.kobj, + &dev_attr_remapped_nvme.attr, + NULL); pm_runtime_get_noresume(&pdev->dev); ata_pci_remove_one(pdev); } diff --git a/drivers/ata/ahci.h b/drivers/ata/ahci.h index 3dbf398c92ea..d991dd46e89c 100644 --- a/drivers/ata/ahci.h +++ b/drivers/ata/ahci.h @@ -336,6 +336,7 @@ struct ahci_host_priv { u32 em_loc; /* enclosure management location */ u32 em_buf_sz; /* EM buffer size in byte */ u32 em_msg_type; /* EM message type */ + u32 remapped_nvme; /* NVMe remapped device count */ bool got_runtime_pm; /* Did we do pm_runtime_get? */ struct clk *clks[AHCI_MAX_CLKS]; /* Optional */ struct reset_control *rsts; /* Optional */
BugLink: https://bugs.launchpad.net/bugs/1863621 Add a new sysfs attribute to show how many NVMe devices are remapped. Userspace like distro installer can use this info to ask user to change the BIOS setting. Signed-off-by: Kai-Heng Feng <kai.heng.feng@canonical.com> --- drivers/ata/ahci.c | 28 ++++++++++++++++++++++++---- drivers/ata/ahci.h | 1 + 2 files changed, 25 insertions(+), 4 deletions(-)