]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
ACPI: sysfs: manage sysfs attributes through device core
authorThomas Weißschuh <linux@weissschuh.net>
Tue, 9 Jul 2024 20:37:27 +0000 (22:37 +0200)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Fri, 2 Aug 2024 14:44:22 +0000 (16:44 +0200)
Now that the ACPI sysfs attributes are organized around an
attribute_group, the device core can manage them.

Signed-off-by: Thomas Weißschuh <linux@weissschuh.net>
Link: https://patch.msgid.link/20240709-acpi-sysfs-groups-v2-4-058ab0667fa8@weissschuh.net
[ rjw: Changelog edits ]
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
drivers/acpi/device_sysfs.c
drivers/acpi/internal.h
drivers/acpi/scan.c

index 4afc773383ad768dd4bcad7d3fe0edd8b285798c..0bff4a1654ed469c1536af3c4e5456af78fa6c87 100644 (file)
@@ -596,6 +596,11 @@ static const struct attribute_group acpi_group = {
        .is_visible = acpi_attr_is_visible,
 };
 
+const struct attribute_group *acpi_groups[] = {
+       &acpi_group,
+       NULL
+};
+
 /**
  * acpi_device_setup_files - Create sysfs attributes of an ACPI device.
  * @dev: ACPI device object.
@@ -604,8 +609,6 @@ int acpi_device_setup_files(struct acpi_device *dev)
 {
        int result = 0;
 
-       result = device_add_group(&dev->dev, &acpi_group);
-
        acpi_expose_nondev_subnodes(&dev->dev.kobj, &dev->data);
 
        return result;
@@ -618,5 +621,4 @@ int acpi_device_setup_files(struct acpi_device *dev)
 void acpi_device_remove_files(struct acpi_device *dev)
 {
        acpi_hide_nondev_subnodes(&dev->data);
-       device_remove_group(&dev->dev, &acpi_group);
 }
index 601b670356e50e141b172266cf0d3478978a17c4..8e1c21e45d0e4fc2861a841b518533dec6f42c10 100644 (file)
@@ -120,6 +120,7 @@ int acpi_tie_acpi_dev(struct acpi_device *adev);
 int acpi_device_add(struct acpi_device *device);
 int acpi_device_setup_files(struct acpi_device *dev);
 void acpi_device_remove_files(struct acpi_device *dev);
+extern const struct attribute_group *acpi_groups[];
 void acpi_device_add_finalize(struct acpi_device *device);
 void acpi_free_pnp_ids(struct acpi_device_pnp *pnp);
 bool acpi_device_is_enabled(const struct acpi_device *adev);
index 59771412686ba3613f7a280aeb6803ec2d155df8..14dba8f6faffd84841e29dd1129b7e81a7d6f696 100644 (file)
@@ -1822,6 +1822,7 @@ void acpi_init_device_object(struct acpi_device *device, acpi_handle handle,
        device->dev.parent = parent ? &parent->dev : NULL;
        device->dev.release = release;
        device->dev.bus = &acpi_bus_type;
+       device->dev.groups = acpi_groups;
        fwnode_init(&device->fwnode, &acpi_device_fwnode_ops);
        acpi_set_device_status(device, ACPI_STA_DEFAULT);
        acpi_device_get_busid(device);