linux-arm-kernel.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
* [PATCH V2] firmware: arm_scmi: bus: bypass set fwnode for scmi cpufreq
@ 2024-07-29  7:03 Peng Fan (OSS)
  2024-08-13  0:26 ` Peng Fan
  2024-08-13  8:57 ` Dhruva Gole
  0 siblings, 2 replies; 16+ messages in thread
From: Peng Fan (OSS) @ 2024-07-29  7:03 UTC (permalink / raw)
  To: sudeep.holla, cristian.marussi, saravanak
  Cc: linux-arm-kernel, linux-kernel, arm-scmi, Peng Fan

From: Peng Fan <peng.fan@nxp.com>

Two drivers scmi_cpufreq.c and scmi_perf_domain.c both use
SCMI_PROTCOL_PERF protocol, but with different name, so two scmi devices
will be created. But the fwnode->dev could only point to one device.

If scmi cpufreq device created earlier, the fwnode->dev will point to
the scmi cpufreq device. Then the fw_devlink will link performance
domain user device(consumer) to the scmi cpufreq device(supplier).
But actually the performance domain user device, such as GPU, should use
the scmi perf device as supplier. Also if 'cpufreq.off=1' in bootargs,
the GPU driver will defer probe always, because of the scmi cpufreq
device not ready.

Because for cpufreq, no need use fw_devlink. So bypass setting fwnode
for scmi cpufreq device.

Fixes: 96da4a99ce50 ("firmware: arm_scmi: Set fwnode for the scmi_device")
Signed-off-by: Peng Fan <peng.fan@nxp.com>
---

V2:
 Use A!=B to replace !(A == B)
 Add fixes tag
 This might be a workaround, but since this is a fix, it is simple for
 backporting.

V1:
 https://lore.kernel.org/all/20240717093515.327647-1-peng.fan@oss.nxp.com/

 drivers/firmware/arm_scmi/bus.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/drivers/firmware/arm_scmi/bus.c b/drivers/firmware/arm_scmi/bus.c
index 96b2e5f9a8ef..be91a82e0cda 100644
--- a/drivers/firmware/arm_scmi/bus.c
+++ b/drivers/firmware/arm_scmi/bus.c
@@ -395,7 +395,8 @@ __scmi_device_create(struct device_node *np, struct device *parent,
 	scmi_dev->id = id;
 	scmi_dev->protocol_id = protocol;
 	scmi_dev->dev.parent = parent;
-	device_set_node(&scmi_dev->dev, of_fwnode_handle(np));
+	if ((protocol != SCMI_PROTOCOL_PERF) || strcmp(name, "cpufreq"))
+		device_set_node(&scmi_dev->dev, of_fwnode_handle(np));
 	scmi_dev->dev.bus = &scmi_bus_type;
 	scmi_dev->dev.release = scmi_device_release;
 	dev_set_name(&scmi_dev->dev, "scmi_dev.%d", id);
-- 
2.37.1



^ permalink raw reply related	[flat|nested] 16+ messages in thread

end of thread, other threads:[~2024-09-02 12:23 UTC | newest]

Thread overview: 16+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-07-29  7:03 [PATCH V2] firmware: arm_scmi: bus: bypass set fwnode for scmi cpufreq Peng Fan (OSS)
2024-08-13  0:26 ` Peng Fan
2024-08-13  8:57 ` Dhruva Gole
2024-08-13 10:25   ` Peng Fan
2024-08-13 13:38     ` Cristian Marussi
2024-08-13 13:52       ` Peng Fan
2024-08-13 15:09         ` Cristian Marussi
2024-08-13 15:17           ` Peng Fan
2024-08-14  3:35             ` Peng Fan
2024-08-14  6:51               ` Saravana Kannan
2024-08-14  7:04                 ` Peng Fan
2024-08-14  7:17                   ` Saravana Kannan
2024-08-14 12:08                     ` Peng Fan
2024-09-02 12:22                       ` Peng Fan
2024-08-14 11:27                 ` Cristian Marussi
2024-08-13 12:47   ` Cristian Marussi

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).