From: Dhruva Gole <d-gole@ti.com>
To: "Peng Fan (OSS)" <peng.fan@oss.nxp.com>
Cc: <sudeep.holla@arm.com>, <cristian.marussi@arm.com>,
<saravanak@google.com>, <linux-arm-kernel@lists.infradead.org>,
<linux-kernel@vger.kernel.org>, <arm-scmi@vger.kernel.org>,
Peng Fan <peng.fan@nxp.com>
Subject: Re: [PATCH V2] firmware: arm_scmi: bus: bypass set fwnode for scmi cpufreq
Date: Tue, 13 Aug 2024 14:27:03 +0530 [thread overview]
Message-ID: <20240813085703.zz6ltcxmrrbdgt77@lcpd911> (raw)
In-Reply-To: <20240729070325.2065286-1-peng.fan@oss.nxp.com>
On Jul 29, 2024 at 15:03:25 +0800, Peng Fan (OSS) wrote:
> 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
The commit message itself seems very specific to some platform to me.
What about platforms that don't atall have a GPU? Why would they care
about this?
> 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.
More than a workaround, it feels like a HACK to me.
>
> 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));
I kind of disagree with the idea here to be specific about the
PROTOCOL_PERF or cpufreq. This is a generic arm scmi bus driver right?
Why bring in specific code into a bus driver? We will never fix the
actual root cause of the issue this way.
--
Best regards,
Dhruva Gole <d-gole@ti.com>
next prev parent reply other threads:[~2024-08-13 8:58 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
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 [this message]
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
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20240813085703.zz6ltcxmrrbdgt77@lcpd911 \
--to=d-gole@ti.com \
--cc=arm-scmi@vger.kernel.org \
--cc=cristian.marussi@arm.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=peng.fan@nxp.com \
--cc=peng.fan@oss.nxp.com \
--cc=saravanak@google.com \
--cc=sudeep.holla@arm.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox