diff mbox series

remoteproc: uclass: Modify uc_pdata->name to use combination of device name and device's parent name

Message ID 20240719085908.3564171-1-danishanwar@ti.com
State Changes Requested
Delegated to: Tom Rini
Headers show
Series remoteproc: uclass: Modify uc_pdata->name to use combination of device name and device's parent name | expand

Commit Message

MD Danish Anwar July 19, 2024, 8:59 a.m. UTC
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>
---
Cc: Andrew Davis <afd@ti.com>

Failure Example:
In k3-am64-main.dtsi, both pru0_0 [1] and pru1_0 [2] will have
dev->name as "pru@34000" although their parent name is different.

pru0_0 has dev->name as "pru@34000" and parent name as "icssg@30000000"
pru1_0 has dev->name as "pru@34000" and parent name as "icssg@30080000"

rproc_init() fails for pru1_0 as the the uc_pdata->name becomes same as the pru0_0.
More details on this issue can be found here [3]. It was suggested to use a
different combination if `dev->name` is not unique by Andrew Davis <afd@ti.com> [4]

Failure Logs:
	rproc_pre_probe: 'pru@34000': using fdt
	rproc_pre_probe: 'pru@34000': using fdt
	rproc_pre_probe: pru@34000 duplicate name 'pru@34000'
	_rproc_probe_dev: pru@34000: Failed to initialize - -22
	rproc_boot: rproc_init() failed: -22

To fix it, this commit uses combination of dev and dev's parent name.

After this commit,
pru0_0 uc->pdata->name = "pru@34000:icssg@30000000"
pru1_0 uc->pdata->name = "pru@34000:icssg@30080000"

Both the names are unique, thus rproc_init() succeeds.

[1] https://elixir.bootlin.com/u-boot/v2024.07-rc3/source/dts/upstream/src/arm64/ti/k3-am64-main.dtsi#L1276
[2] https://elixir.bootlin.com/u-boot/v2024.07-rc3/source/dts/upstream/src/arm64/ti/k3-am64-main.dtsi#L1417
[3] https://lore.kernel.org/all/5cda289f-1d14-41f6-84e3-ff1d1034be13@ti.com/
[4] https://lore.kernel.org/all/e48f5818-182c-47ab-b384-379659830d38@ti.com/

 drivers/remoteproc/rproc-uclass.c | 12 +++++++++---
 1 file changed, 9 insertions(+), 3 deletions(-)

Comments

Roger Quadros Aug. 5, 2024, 6:38 a.m. UTC | #1
On 19/07/2024 11:59, MD Danish Anwar wrote:
> 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>
> ---
> Cc: Andrew Davis <afd@ti.com>
> 
> Failure Example:
> In k3-am64-main.dtsi, both pru0_0 [1] and pru1_0 [2] will have
> dev->name as "pru@34000" although their parent name is different.
> 
> pru0_0 has dev->name as "pru@34000" and parent name as "icssg@30000000"
> pru1_0 has dev->name as "pru@34000" and parent name as "icssg@30080000"
> 
> rproc_init() fails for pru1_0 as the the uc_pdata->name becomes same as the pru0_0.
> More details on this issue can be found here [3]. It was suggested to use a
> different combination if `dev->name` is not unique by Andrew Davis <afd@ti.com> [4]
> 
> Failure Logs:
> 	rproc_pre_probe: 'pru@34000': using fdt
> 	rproc_pre_probe: 'pru@34000': using fdt
> 	rproc_pre_probe: pru@34000 duplicate name 'pru@34000'
> 	_rproc_probe_dev: pru@34000: Failed to initialize - -22
> 	rproc_boot: rproc_init() failed: -22
> 
> To fix it, this commit uses combination of dev and dev's parent name.
> 
> After this commit,
> pru0_0 uc->pdata->name = "pru@34000:icssg@30000000"
> pru1_0 uc->pdata->name = "pru@34000:icssg@30080000"
> 
> Both the names are unique, thus rproc_init() succeeds.
> 
> [1] https://elixir.bootlin.com/u-boot/v2024.07-rc3/source/dts/upstream/src/arm64/ti/k3-am64-main.dtsi#L1276
> [2] https://elixir.bootlin.com/u-boot/v2024.07-rc3/source/dts/upstream/src/arm64/ti/k3-am64-main.dtsi#L1417
> [3] https://lore.kernel.org/all/5cda289f-1d14-41f6-84e3-ff1d1034be13@ti.com/
> [4] https://lore.kernel.org/all/e48f5818-182c-47ab-b384-379659830d38@ti.com/
> 
>  drivers/remoteproc/rproc-uclass.c | 12 +++++++++---
>  1 file changed, 9 insertions(+), 3 deletions(-)
> 
> diff --git a/drivers/remoteproc/rproc-uclass.c b/drivers/remoteproc/rproc-uclass.c
> index 3ba2b40dca..e550292dda 100644
> --- a/drivers/remoteproc/rproc-uclass.c
> +++ b/drivers/remoteproc/rproc-uclass.c
> @@ -158,9 +158,15 @@ 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) {
> +		int rproc_name_size = 256;

Instead of hardcoding 256 why not use
		buf = malloc(strlen(dev->name) + strlen(dev->parent->name) + 2);	// 1 for null and one for '-'

> +		char *buf;
> +
> +		buf = malloc(rproc_name_size);

need to check/error out for malloc failure.

> +		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;
MD Danish Anwar Aug. 7, 2024, 8:41 a.m. UTC | #2
On 05/08/24 12:08 pm, Roger Quadros wrote:
> 
> 
> On 19/07/2024 11:59, MD Danish Anwar wrote:
>> 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>
>> ---
>> Cc: Andrew Davis <afd@ti.com>
>>
>> Failure Example:
>> In k3-am64-main.dtsi, both pru0_0 [1] and pru1_0 [2] will have
>> dev->name as "pru@34000" although their parent name is different.
>>
>> pru0_0 has dev->name as "pru@34000" and parent name as "icssg@30000000"
>> pru1_0 has dev->name as "pru@34000" and parent name as "icssg@30080000"
>>
>> rproc_init() fails for pru1_0 as the the uc_pdata->name becomes same as the pru0_0.
>> More details on this issue can be found here [3]. It was suggested to use a
>> different combination if `dev->name` is not unique by Andrew Davis <afd@ti.com> [4]
>>
>> Failure Logs:
>> 	rproc_pre_probe: 'pru@34000': using fdt
>> 	rproc_pre_probe: 'pru@34000': using fdt
>> 	rproc_pre_probe: pru@34000 duplicate name 'pru@34000'
>> 	_rproc_probe_dev: pru@34000: Failed to initialize - -22
>> 	rproc_boot: rproc_init() failed: -22
>>
>> To fix it, this commit uses combination of dev and dev's parent name.
>>
>> After this commit,
>> pru0_0 uc->pdata->name = "pru@34000:icssg@30000000"
>> pru1_0 uc->pdata->name = "pru@34000:icssg@30080000"
>>
>> Both the names are unique, thus rproc_init() succeeds.
>>
>> [1] https://elixir.bootlin.com/u-boot/v2024.07-rc3/source/dts/upstream/src/arm64/ti/k3-am64-main.dtsi#L1276
>> [2] https://elixir.bootlin.com/u-boot/v2024.07-rc3/source/dts/upstream/src/arm64/ti/k3-am64-main.dtsi#L1417
>> [3] https://lore.kernel.org/all/5cda289f-1d14-41f6-84e3-ff1d1034be13@ti.com/
>> [4] https://lore.kernel.org/all/e48f5818-182c-47ab-b384-379659830d38@ti.com/
>>
>>  drivers/remoteproc/rproc-uclass.c | 12 +++++++++---
>>  1 file changed, 9 insertions(+), 3 deletions(-)
>>
>> diff --git a/drivers/remoteproc/rproc-uclass.c b/drivers/remoteproc/rproc-uclass.c
>> index 3ba2b40dca..e550292dda 100644
>> --- a/drivers/remoteproc/rproc-uclass.c
>> +++ b/drivers/remoteproc/rproc-uclass.c
>> @@ -158,9 +158,15 @@ 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) {
>> +		int rproc_name_size = 256;
> 
> Instead of hardcoding 256 why not use
> 		buf = malloc(strlen(dev->name) + strlen(dev->parent->name) + 2);	// 1 for null and one for '-'
> 
>> +		char *buf;
>> +
>> +		buf = malloc(rproc_name_size);
> 
> need to check/error out for malloc failure.

Sure Roger, I will make these changes and update the patch. Thanks for
the review.

> 
>> +		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;
>
diff mbox series

Patch

diff --git a/drivers/remoteproc/rproc-uclass.c b/drivers/remoteproc/rproc-uclass.c
index 3ba2b40dca..e550292dda 100644
--- a/drivers/remoteproc/rproc-uclass.c
+++ b/drivers/remoteproc/rproc-uclass.c
@@ -158,9 +158,15 @@  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) {
+		int rproc_name_size = 256;
+		char *buf;
+
+		buf = malloc(rproc_name_size);
+		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;