Re: [PATCH] clk: qcom: gcc-msm8994: Remove NoC clocks
From: Konrad Dybcio
Date: Thu Dec 30 2021 - 09:27:00 EST
On 30.12.2021 15:06, Dmitry Baryshkov wrote:
> On Thu, 30 Dec 2021 at 05:31, Konrad Dybcio
> <konrad.dybcio@xxxxxxxxxxxxxx> wrote:
>> Just like in commit 05cf3ec00d460b50088d421fb878a0f83f57e262
>> ("clk: qcom: gcc-msm8996: Drop (again) gcc_aggre1_pnoc_ahb_clk")
>> adding NoC clocks turned out to be a huge mistake, as they cause a lot of
>> issues at little benefit (basically only letting Linux know about their
>> children's frequencies), especially when mishandled or misconfigured.
> I'm not against this patch, but it manifests another question to me:
> should the NoC driver set these frequencies (as demanded), or are they
> set by the hardware/RPM/etc and so are read-only to us?
The downstream driver [1] only seems to vote for 19.2 MHz on
p(c)noc_keepalive_a_clk and 40MHz on mmssnoc_ahb_a_clk and
not really care much about them otherwise in the (msm_)clk framework.
Interestingly, the voting-at-probe also seems to be true for 8916 [2],
and even more so for 8974 [3] which votes for CXO too, and I don't
think we handle it upstream.. Is it unnecessary, or did things always
work by miracle? Should we perhaps set it with assigned-clocks under
rpmcc in DT?
Otherwise, they seem to be handled by msm_bus's voter clocks, so in
our case that'll be interconnect's job. I had an old WIP driver somewhere,
but it had issues with some (well, many) paths.. I'll rebase it and try debugging
that.
Decoding ancient msm-3.10 code is not for the faint of heart, but I don't think
8994 or 8974 (which are similar in many ways) ever got a newer kernel release..
[..]
Konrad
[1] https://github.com/sonyxperiadev/kernel/blob/aosp/LA.BR.1.3.3_rb2.14/drivers/clk/qcom/clock-rpm-8994.c#L292
[2] https://github.com/sonyxperiadev/kernel/blob/aosp/LA.BR.1.3.3_rb2.14/drivers/clk/qcom/clock-rpm-8916.c#L168
[3] https://github.com/sonyxperiadev/kernel/blob/aosp/LA.BR.1.3.3_rb2.14/arch/arm/mach-msm/clock-rpm-8974.c