]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
PCI/sysfs: Warn about BAR resize failure in __resource_resize_store()
authorKrzysztof Wilczyński <kwilczynski@kernel.org>
Fri, 8 May 2026 04:35:27 +0000 (04:35 +0000)
committerBjorn Helgaas <bhelgaas@google.com>
Tue, 23 Jun 2026 20:19:08 +0000 (15:19 -0500)
Add a pci_warn() to __resource_resize_store(), so that BAR resize failures
are visible to the user, which can help troubleshoot any potential resource
resize issues.

While at it, rename the resource_resize_is_visible() to
resource_resize_attr_is_visible() along with the corresponding group
variable to align with the naming convention used by the resource attribute
groups.

Also, change the order of pci_dev_groups[] such that the resize group is
now located alongside the other resource groups.

Signed-off-by: Krzysztof Wilczyński <kwilczynski@kernel.org>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Tested-by: Shivaprasad G Bhat <sbhat@linux.ibm.com>
Link: https://patch.msgid.link/20260508043543.217179-9-kwilczynski@kernel.org
drivers/pci/pci-sysfs.c

index 3bb808e0e80aebf55e45ad077c0edd8b31456b6a..3db44df63b537a6109ac7323c3abcbb36d0a171c 100644 (file)
@@ -1679,6 +1679,9 @@ static ssize_t __resource_resize_store(struct device *dev, int n,
        sysfs_remove_groups(&pdev->dev.kobj, pci_dev_resource_attr_groups);
 
        ret = pci_resize_resource(pdev, n, size, 0);
+       if (ret)
+               pci_warn(pdev, "Failed to resize BAR %d: %pe\n",
+                        n, ERR_PTR(ret));
 
        pci_assign_unassigned_bus_resources(bus);
 
@@ -1726,7 +1729,7 @@ static struct attribute *resource_resize_attrs[] = {
        NULL,
 };
 
-static umode_t resource_resize_is_visible(struct kobject *kobj,
+static umode_t resource_resize_attr_is_visible(struct kobject *kobj,
                                          struct attribute *a, int n)
 {
        struct pci_dev *pdev = to_pci_dev(kobj_to_dev(kobj));
@@ -1734,9 +1737,9 @@ static umode_t resource_resize_is_visible(struct kobject *kobj,
        return pci_rebar_get_current_size(pdev, n) < 0 ? 0 : a->mode;
 }
 
-static const struct attribute_group pci_dev_resource_resize_group = {
+static const struct attribute_group pci_dev_resource_resize_attr_group = {
        .attrs = resource_resize_attrs,
-       .is_visible = resource_resize_is_visible,
+       .is_visible = resource_resize_attr_is_visible,
 };
 
 int __must_check pci_create_sysfs_dev_files(struct pci_dev *pdev)
@@ -1857,6 +1860,7 @@ const struct attribute_group *pci_dev_groups[] = {
        &pci_dev_resource_uc_attr_group,
        &pci_dev_resource_wc_attr_group,
 #endif
+       &pci_dev_resource_resize_attr_group,
        &pci_dev_config_attr_group,
        &pci_dev_rom_attr_group,
        &pci_dev_reset_attr_group,
@@ -1868,7 +1872,6 @@ const struct attribute_group *pci_dev_groups[] = {
 #ifdef CONFIG_ACPI
        &pci_dev_acpi_attr_group,
 #endif
-       &pci_dev_resource_resize_group,
        ARCH_PCI_DEV_GROUPS
        NULL,
 };