soundwire: sysfs: move sdw_slave_dev_attr_group into the existing list of groups
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 30 Jan 2024 18:46:28 +0000 (10:46 -0800)
committerVinod Koul <vkoul@kernel.org>
Thu, 28 Mar 2024 18:08:47 +0000 (23:38 +0530)
The sysfs logic already creates a list of groups for the device, so add
the sdw_slave_dev_attr_group group to that list instead of having to do
a two-step process of adding a group list and then an individual group.

This is a step on the way to moving all of the sysfs attribute handling
into the default driver core attribute group logic so that the soundwire
core does not have to do any of it manually.

Cc: Vinod Koul <vkoul@kernel.org>
Cc: Bard Liao <yung-chuan.liao@linux.intel.com>
Cc: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Cc: Sanyog Kale <sanyog.r.kale@intel.com>
Cc: alsa-devel@alsa-project.org
Cc: linux-kernel@vger.kernel.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Reviewed-by: Dan Williams <dan.j.williams@intel.com>
Tested-By: Vijendar Mukunda <Vijendar.Mukunda@amd.com>
Link: https://lore.kernel.org/r/2024013029-afternoon-suitably-cb59@gregkh
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/soundwire/sysfs_slave.c

index 3210359cd94428d1eb1ebfc251a05af6216ebc3d..83e3f6cc325008a33e5b41631998f7429d04058e 100644 (file)
@@ -105,7 +105,10 @@ static struct attribute *slave_attrs[] = {
        &dev_attr_modalias.attr,
        NULL,
 };
-ATTRIBUTE_GROUPS(slave);
+
+static const struct attribute_group slave_attr_group = {
+       .attrs = slave_attrs,
+};
 
 static struct attribute *slave_dev_attrs[] = {
        &dev_attr_mipi_revision.attr,
@@ -190,6 +193,12 @@ static const struct attribute_group dp0_group = {
        .name = "dp0",
 };
 
+static const struct attribute_group *slave_groups[] = {
+       &slave_attr_group,
+       &sdw_slave_dev_attr_group,
+       NULL,
+};
+
 int sdw_slave_sysfs_init(struct sdw_slave *slave)
 {
        int ret;
@@ -198,10 +207,6 @@ int sdw_slave_sysfs_init(struct sdw_slave *slave)
        if (ret < 0)
                return ret;
 
-       ret = devm_device_add_group(&slave->dev, &sdw_slave_dev_attr_group);
-       if (ret < 0)
-               return ret;
-
        if (slave->prop.dp0_prop) {
                ret = devm_device_add_group(&slave->dev, &dp0_group);
                if (ret < 0)