From: Jeffrey Hugo <jhugo@codeaurora.org>
To: Stephen Boyd <sboyd@kernel.org>,
Bjorn Andersson <bjorn.andersson@linaro.org>
Cc: Andy Gross <andy.gross@linaro.org>,
MSM <linux-arm-msm@vger.kernel.org>,
Georgi Djakov <georgi.djakov@linaro.org>,
Linux ARM <linux-arm-kernel@lists.infradead.org>,
Marc Gonzalez <marc.w.gonzalez@free.fr>
Subject: Re: [PATCH v2 1/3] arm64: dts: qcom: msm8998: correct xo clock name
Date: Wed, 5 Dec 2018 14:20:07 -0700 [thread overview]
Message-ID: <14cad8f0-7388-16a0-b1ba-4cd5a469a17e@codeaurora.org> (raw)
In-Reply-To: <154404384283.88331.2522037578224950651@swboyd.mtv.corp.google.com>
On 12/5/2018 2:04 PM, Stephen Boyd wrote:
> Quoting Jeffrey Hugo (2018-12-05 09:03:54)
>> On 12/5/2018 9:48 AM, Bjorn Andersson wrote:
>>> On Wed 05 Dec 08:38 PST 2018, Jeffrey Hugo wrote:
>>>
>>>> On 12/5/2018 9:12 AM, Marc Gonzalez wrote:
>>>>> On 15/11/2018 21:44, Jeffrey Hugo wrote:
>>>>>
>>>>>> The root parent clock of most msm8998 clock is the "xo" clock. The DT node
>>>>>> is incorrectly named "xo_board", which prevents Linux from correctly
>>>>>> parsing the clock tree, resulting in most clocks being unparented and
>>>>>> unable to be manipulated. The end result is that we can't turn on clocks
>>>>>> for peripherals like SD, so init usually fails.
>>>>>>
>>>>>> Fixes: 4807c71cc688 (arm64: dts: Add msm8998 SoC and MTP board support)
>>>>>> Reviewed-by: Bjorn Andersson <bjorn.andersson@linaro.org>
>>>>>> Signed-off-by: Jeffrey Hugo <jhugo@codeaurora.org>
>>>>>> ---
>>>>>> arch/arm64/boot/dts/qcom/msm8998.dtsi | 2 +-
>>>>>> 1 file changed, 1 insertion(+), 1 deletion(-)
>>>>>>
>>>>>> diff --git a/arch/arm64/boot/dts/qcom/msm8998.dtsi b/arch/arm64/boot/dts/qcom/msm8998.dtsi
>>>>>> index 78227cc..a948d4b 100644
>>>>>> --- a/arch/arm64/boot/dts/qcom/msm8998.dtsi
>>>>>> +++ b/arch/arm64/boot/dts/qcom/msm8998.dtsi
>>>>>> @@ -53,7 +53,7 @@
>>>>>> };
>>>>>> clocks {
>>>>>> - xo_board {
>>>>>> + xo {
>>>>>> compatible = "fixed-clock";
>>>>>> #clock-cells = <0>;
>>>>>> clock-frequency = <19200000>;
>>>>>>
>>>>>
>>>>> Isn't there going to be a problem for msm8998 in drivers/clk/qcom/clk-smd-rpm.c
>>>>> which uses "xo_board" for parent_names?
>>>>
>>>> Looks like you are right. This doesn't seem to be the correct way to
>>>> address the issue then. I'll have to dig in and take another look.
>>>>
>>>
>>> The appropriate solution is to describe references between clock drivers
>>> explicitly in DeviceTree and by that not rely on a global namespace.
>>> That will also sort out any initialization ordering issues that we might
>>> have.
>>>
>>> But this task has not yet made it off the todo lists where it lives...
>>
>> Ok, that sounds great, but doesn't seem like it helps anyone today.
>>
>> Looks like 8916 and 8974 explicitly register an xo clock off the
>> xo_board clock in the respective gcc drivers. 8996 does not, but I
>> don't know how functional 8996 really is on mainline. 845 seems to
>> register the bi_tcxo clock (the 845 version of xo) in the rpmh driver,
>> off of xo_board.
>>
>> Since both Marc and I are trying to get 8998 to work, it seems like one
>> of those two solutions would be workable, short term.
>>
>> How do you suggest we proceed?
>>
>
> I don't quite understand the patch in general. The xo_board clk should
> always exist in DT and the fixed factor clk in GCC is there until the
> rpm clk driver can control the XO clk state vote for the kernel.
Sorry, this wasn't apparent. It doesn't seem like this "requirement" is
captured anywhere.
As far as the SD clocks are concerned, they are defined in GCC, and
eventually have a root parent called "xo". "xo" isn't defined anywhere,
so the SD clocks can't really be used, and the hardware doesn't come up.
This patch "fixed" that, but I missed the link to the rpm driver that
Marc pointed out.
>
> If anything, change the DT node to be named xo-board instead of xo_board
> because that matches DT naming schemes and then add a clock-output-names
> = "xo_board" property to it so that we keep the underscore.
I see this now, and I agree with it, but then SD goes back to a broken
state because there is "xo" clock for GCC. Its not quite clear to me
how to make GCC (and thus SD) happy again with this change reverted/fixed.
Bjorn mentioned offline he is going to take a look, but he has a few
other things on his plate first.
--
Jeffrey Hugo
Qualcomm Datacenter Technologies as an affiliate of Qualcomm
Technologies, Inc.
Qualcomm Technologies, Inc. is a member of the
Code Aurora Forum, a Linux Foundation Collaborative Project.
next prev parent reply other threads:[~2018-12-05 21:20 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-11-15 20:44 [PATCH v2 0/3] Enable SD card slot on msm8998 MTP Jeffrey Hugo
2018-11-15 20:44 ` [PATCH v2 1/3] arm64: dts: qcom: msm8998: correct xo clock name Jeffrey Hugo
2018-12-05 16:12 ` Marc Gonzalez
2018-12-05 16:38 ` Jeffrey Hugo
2018-12-05 16:48 ` Bjorn Andersson
2018-12-05 17:03 ` Jeffrey Hugo
2018-12-05 21:04 ` Stephen Boyd
2018-12-05 21:20 ` Jeffrey Hugo [this message]
2018-12-05 21:42 ` Stephen Boyd
2018-12-05 23:04 ` Jeffrey Hugo
2018-12-06 18:34 ` Stephen Boyd
2018-12-07 9:03 ` Marc Gonzalez
2018-12-07 14:58 ` Jeffrey Hugo
2018-12-07 18:23 ` Andy Gross
2018-11-15 20:44 ` [PATCH v2 2/3] arm64: dts: qcom: msm8998: Add SDCC2 Jeffrey Hugo
2018-11-15 20:44 ` [PATCH v2 3/3] arm64: dts: qcom: msm8998-mtp: Add external SD Jeffrey Hugo
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=14cad8f0-7388-16a0-b1ba-4cd5a469a17e@codeaurora.org \
--to=jhugo@codeaurora.org \
--cc=andy.gross@linaro.org \
--cc=bjorn.andersson@linaro.org \
--cc=georgi.djakov@linaro.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-arm-msm@vger.kernel.org \
--cc=marc.w.gonzalez@free.fr \
--cc=sboyd@kernel.org \
/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