]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
remoteproc: uclass: Modify uc_pdata->name to use combination of device name and devic...
authorMD Danish Anwar <danishanwar@ti.com>
Wed, 7 Aug 2024 09:08:29 +0000 (14:38 +0530)
committerTom Rini <trini@konsulko.com>
Tue, 27 Aug 2024 17:17:39 +0000 (11:17 -0600)
uc_pdata->name is populated from device tree property "remoteproc-name".
For those devcices that don't set "remoteproc-name", uc_pdata->name
falls back to dev->name.

If two devices have same name, this will result into uc_pdata->name not
being unique and rproc_init() will fail.

Fix this by using combination of dev->name and dev->parent->name instead
of using just the dev->name to populate uc_pdata->name.

Signed-off-by: MD Danish Anwar <danishanwar@ti.com>
Reviewed-by: Roger Quadros <rogerq@kernel.org>
Reviewed-by: Andrew Davis <afd@ti.com>
drivers/remoteproc/rproc-uclass.c

index e64354dd52f1bf3b962dc5201be76b03dc67829d..3233ff80419b2f4f667b5ec92ab00bc57a181221 100644 (file)
@@ -158,9 +158,19 @@ static int rproc_pre_probe(struct udevice *dev)
                uc_pdata->driver_plat_data = pdata->driver_plat_data;
        }
 
-       /* Else try using device Name */
-       if (!uc_pdata->name)
-               uc_pdata->name = dev->name;
+       /* Else try using a combination of device Name and devices's parent's name */
+       if (!uc_pdata->name) {
+               /* 2 in the rproc_name_size indicates 1 for null and one for '-' */
+               int rproc_name_size = strlen(dev->name) + strlen(dev->parent->name) + 2;
+               char *buf;
+
+               buf = malloc(rproc_name_size);
+               if (!buf)
+                       return -ENOMEM;
+
+               snprintf(buf, rproc_name_size, "%s-%s", dev->name, dev->parent->name);
+               uc_pdata->name = buf;
+       }
        if (!uc_pdata->name) {
                debug("Unnamed device!");
                return -EINVAL;