[v2,1/2] dt-bindings: soc: qcom: Add bindings for Qualcomm Ramp Controller

Message ID 20221104142204.156333-2-angelogioacchino.delregno@collabora.com
State New
Headers
Series Qualcomm Ramp Controller and MSM8976 config |

Commit Message

AngeloGioacchino Del Regno Nov. 4, 2022, 2:22 p.m. UTC
  Document bindings for the Qualcomm Ramp Controller, found on various
legacy Qualcomm SoCs.

Signed-off-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
---
 .../qcom/qcom,msm8976-ramp-controller.yaml    | 37 +++++++++++++++++++
 1 file changed, 37 insertions(+)
 create mode 100644 Documentation/devicetree/bindings/soc/qcom/qcom,msm8976-ramp-controller.yaml
  

Comments

Krzysztof Kozlowski Nov. 4, 2022, 2:32 p.m. UTC | #1
On 04/11/2022 10:22, AngeloGioacchino Del Regno wrote:
> Document bindings for the Qualcomm Ramp Controller, found on various
> legacy Qualcomm SoCs.

Subject: drop second "bindings" word. One in prefix (dt-bindings) is enough.

> 
> Signed-off-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
> ---

With above:

Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>


Best regards,
Krzysztof
  
Rob Herring Nov. 4, 2022, 5:54 p.m. UTC | #2
On Fri, 04 Nov 2022 15:22:03 +0100, AngeloGioacchino Del Regno wrote:
> Document bindings for the Qualcomm Ramp Controller, found on various
> legacy Qualcomm SoCs.
> 
> Signed-off-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
> ---
>  .../qcom/qcom,msm8976-ramp-controller.yaml    | 37 +++++++++++++++++++
>  1 file changed, 37 insertions(+)
>  create mode 100644 Documentation/devicetree/bindings/soc/qcom/qcom,msm8976-ramp-controller.yaml
> 

My bot found errors running 'make DT_CHECKER_FLAGS=-m dt_binding_check'
on your patch (DT_CHECKER_FLAGS is new in v5.13):

yamllint warnings/errors:

dtschema/dtc warnings/errors:
/builds/robherring/dt-review-ci/linux/Documentation/devicetree/bindings/soc/qcom/qcom,msm8976-ramp-controller.example.dtb: power-controller@b014000: '#power-domain-cells' is a required property
	From schema: /builds/robherring/dt-review-ci/linux/Documentation/devicetree/bindings/power/power-domain.yaml

doc reference errors (make refcheckdocs):

See https://patchwork.ozlabs.org/patch/

This check can fail if there are any dependencies. The base for a patch
series is generally the most recent rc1.

If you already ran 'make dt_binding_check' and didn't see the above
error(s), then make sure 'yamllint' is installed and dt-schema is up to
date:

pip3 install dtschema --upgrade

Please check and re-submit.
  
AngeloGioacchino Del Regno Nov. 11, 2022, 10:05 a.m. UTC | #3
Il 04/11/22 18:54, Rob Herring ha scritto:
> 
> On Fri, 04 Nov 2022 15:22:03 +0100, AngeloGioacchino Del Regno wrote:
>> Document bindings for the Qualcomm Ramp Controller, found on various
>> legacy Qualcomm SoCs.
>>
>> Signed-off-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
>> ---
>>   .../qcom/qcom,msm8976-ramp-controller.yaml    | 37 +++++++++++++++++++
>>   1 file changed, 37 insertions(+)
>>   create mode 100644 Documentation/devicetree/bindings/soc/qcom/qcom,msm8976-ramp-controller.yaml
>>
> 
> My bot found errors running 'make DT_CHECKER_FLAGS=-m dt_binding_check'
> on your patch (DT_CHECKER_FLAGS is new in v5.13):
> 
> yamllint warnings/errors:
> 
> dtschema/dtc warnings/errors:
> /builds/robherring/dt-review-ci/linux/Documentation/devicetree/bindings/soc/qcom/qcom,msm8976-ramp-controller.example.dtb: power-controller@b014000: '#power-domain-cells' is a required property
> 	From schema: /builds/robherring/dt-review-ci/linux/Documentation/devicetree/bindings/power/power-domain.yaml
> 
> doc reference errors (make refcheckdocs):
> 
> See https://patchwork.ozlabs.org/patch/
> 
> This check can fail if there are any dependencies. The base for a patch
> series is generally the most recent rc1.
> 
> If you already ran 'make dt_binding_check' and didn't see the above
> error(s), then make sure 'yamllint' is installed and dt-schema is up to
> date:
> 
> pip3 install dtschema --upgrade
> 
> Please check and re-submit.
> 

I'm unsure about what I should do about this one.
This is a power-controller, but does *not* need any #power-domain-cells, as it is
standalone and doesn't require being attached to anything.

Any hints?

Thanks,
Angelo
  
Krzysztof Kozlowski Nov. 15, 2022, 1:36 p.m. UTC | #4
On 11/11/2022 11:05, AngeloGioacchino Del Regno wrote:
> Il 04/11/22 18:54, Rob Herring ha scritto:
>>
>> On Fri, 04 Nov 2022 15:22:03 +0100, AngeloGioacchino Del Regno wrote:
>>> Document bindings for the Qualcomm Ramp Controller, found on various
>>> legacy Qualcomm SoCs.
>>>
>>> Signed-off-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
>>> ---
>>>   .../qcom/qcom,msm8976-ramp-controller.yaml    | 37 +++++++++++++++++++
>>>   1 file changed, 37 insertions(+)
>>>   create mode 100644 Documentation/devicetree/bindings/soc/qcom/qcom,msm8976-ramp-controller.yaml
>>>
>>
>> My bot found errors running 'make DT_CHECKER_FLAGS=-m dt_binding_check'
>> on your patch (DT_CHECKER_FLAGS is new in v5.13):
>>
>> yamllint warnings/errors:
>>
>> dtschema/dtc warnings/errors:
>> /builds/robherring/dt-review-ci/linux/Documentation/devicetree/bindings/soc/qcom/qcom,msm8976-ramp-controller.example.dtb: power-controller@b014000: '#power-domain-cells' is a required property
>> 	From schema: /builds/robherring/dt-review-ci/linux/Documentation/devicetree/bindings/power/power-domain.yaml
>>
>> doc reference errors (make refcheckdocs):
>>
>> See https://patchwork.ozlabs.org/patch/
>>
>> This check can fail if there are any dependencies. The base for a patch
>> series is generally the most recent rc1.
>>
>> If you already ran 'make dt_binding_check' and didn't see the above
>> error(s), then make sure 'yamllint' is installed and dt-schema is up to
>> date:
>>
>> pip3 install dtschema --upgrade
>>
>> Please check and re-submit.
>>
> 
> I'm unsure about what I should do about this one.
> This is a power-controller, but does *not* need any #power-domain-cells, as it is
> standalone and doesn't require being attached to anything.

power-domain-cells are for power domain providers, not consumers. The
generic binding expect that nodes called power-controller are exactly
like that.

Solutions could be:
1. Rename the node to something else. I cannot deduct the type of the
device based on description. What is "sequence ID" and how is it even
closely related to power control?

2. Narrow the node name in power-domain.yaml which would require changes
in multiple DTS and bindings.

3. Do not require power-domain-cells for power-controllers, only for
power-domains.

Best regards,
Krzysztof
  
AngeloGioacchino Del Regno Nov. 15, 2022, 2:44 p.m. UTC | #5
Il 15/11/22 14:36, Krzysztof Kozlowski ha scritto:
> On 11/11/2022 11:05, AngeloGioacchino Del Regno wrote:
>> Il 04/11/22 18:54, Rob Herring ha scritto:
>>>
>>> On Fri, 04 Nov 2022 15:22:03 +0100, AngeloGioacchino Del Regno wrote:
>>>> Document bindings for the Qualcomm Ramp Controller, found on various
>>>> legacy Qualcomm SoCs.
>>>>
>>>> Signed-off-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
>>>> ---
>>>>    .../qcom/qcom,msm8976-ramp-controller.yaml    | 37 +++++++++++++++++++
>>>>    1 file changed, 37 insertions(+)
>>>>    create mode 100644 Documentation/devicetree/bindings/soc/qcom/qcom,msm8976-ramp-controller.yaml
>>>>
>>>
>>> My bot found errors running 'make DT_CHECKER_FLAGS=-m dt_binding_check'
>>> on your patch (DT_CHECKER_FLAGS is new in v5.13):
>>>
>>> yamllint warnings/errors:
>>>
>>> dtschema/dtc warnings/errors:
>>> /builds/robherring/dt-review-ci/linux/Documentation/devicetree/bindings/soc/qcom/qcom,msm8976-ramp-controller.example.dtb: power-controller@b014000: '#power-domain-cells' is a required property
>>> 	From schema: /builds/robherring/dt-review-ci/linux/Documentation/devicetree/bindings/power/power-domain.yaml
>>>
>>> doc reference errors (make refcheckdocs):
>>>
>>> See https://patchwork.ozlabs.org/patch/
>>>
>>> This check can fail if there are any dependencies. The base for a patch
>>> series is generally the most recent rc1.
>>>
>>> If you already ran 'make dt_binding_check' and didn't see the above
>>> error(s), then make sure 'yamllint' is installed and dt-schema is up to
>>> date:
>>>
>>> pip3 install dtschema --upgrade
>>>
>>> Please check and re-submit.
>>>
>>
>> I'm unsure about what I should do about this one.
>> This is a power-controller, but does *not* need any #power-domain-cells, as it is
>> standalone and doesn't require being attached to anything.
> 
> power-domain-cells are for power domain providers, not consumers. The
> generic binding expect that nodes called power-controller are exactly
> like that.
> 
> Solutions could be:
> 1. Rename the node to something else. I cannot deduct the type of the
> device based on description. What is "sequence ID" and how is it even
> closely related to power control?

This uC is mainly controlling DCVS, automagically plays with voltages for
each ramp up/down step and from what I understand also decides to shut down
or bring up *power* to "certain clocks" before ungating (CPU related, mainly
big cluster).
This also interacts with LMH - setting the LMH part makes it possible to
later use CPR (otherwise CPR errors out internally and won't start, as it
requires this controller, SAW and LMH to be set up in order to work).

What I've seen is that without it I can't bring up the big cluster at all,
not even at minimum frequency, as the HF2PLL (a clock source for that cluster)
will not power up.
All it takes is to initialize these params and start the controller, then
everything goes as it should.

If you're wondering why my explanation may not be particularly satisfying,
that's because downstream contains practically no information about this
one, apart from a bunch of lines of code and because this controller is
just a big black box.

> 
> 2. Narrow the node name in power-domain.yaml which would require changes
> in multiple DTS and bindings.
> 
> 3. Do not require power-domain-cells for power-controllers, only for
> power-domains.
> 

Solutions 2 and 3... well, I don't think that this would be really feasible
as I envision this being the one and only driver that will ever require
that kind of thing.
Also, this programming was later moved to bootloaders and the only SoCs that
will ever require this are MSM8956/76, MSM8953 and.. I think MSM8952 as well,
but nothing more.

Even if I can imagine the answer, I'm still tempted to ask: can we eventually
just name it ramp-controller@xxxx or qcom-rc@xxxx or something "special" like
that to overcome to this binding issue?

Regards,
Angelo
  
Krzysztof Kozlowski Nov. 15, 2022, 3:16 p.m. UTC | #6
On 15/11/2022 15:44, AngeloGioacchino Del Regno wrote:

>>>> Please check and re-submit.
>>>>
>>>
>>> I'm unsure about what I should do about this one.
>>> This is a power-controller, but does *not* need any #power-domain-cells, as it is
>>> standalone and doesn't require being attached to anything.
>>
>> power-domain-cells are for power domain providers, not consumers. The
>> generic binding expect that nodes called power-controller are exactly
>> like that.
>>
>> Solutions could be:
>> 1. Rename the node to something else. I cannot deduct the type of the
>> device based on description. What is "sequence ID" and how is it even
>> closely related to power control?
> 
> This uC is mainly controlling DCVS, automagically plays with voltages for
> each ramp up/down step and from what I understand also decides to shut down
> or bring up *power* to "certain clocks" before ungating (CPU related, mainly
> big cluster).
> This also interacts with LMH - setting the LMH part makes it possible to
> later use CPR (otherwise CPR errors out internally and won't start, as it
> requires this controller, SAW and LMH to be set up in order to work).
> 
> What I've seen is that without it I can't bring up the big cluster at all,
> not even at minimum frequency, as the HF2PLL (a clock source for that cluster)
> will not power up.
> All it takes is to initialize these params and start the controller, then
> everything goes as it should.
> 
> If you're wondering why my explanation may not be particularly satisfying,
> that's because downstream contains practically no information about this
> one, apart from a bunch of lines of code and because this controller is
> just a big black box.
> 
>>
>> 2. Narrow the node name in power-domain.yaml which would require changes
>> in multiple DTS and bindings.
>>
>> 3. Do not require power-domain-cells for power-controllers, only for
>> power-domains.
>>
> 
> Solutions 2 and 3... well, I don't think that this would be really feasible
> as I envision this being the one and only driver that will ever require
> that kind of thing.
> Also, this programming was later moved to bootloaders and the only SoCs that
> will ever require this are MSM8956/76, MSM8953 and.. I think MSM8952 as well,
> but nothing more.
> 
> Even if I can imagine the answer, I'm still tempted to ask: can we eventually
> just name it ramp-controller@xxxx or qcom-rc@xxxx or something "special" like
> that to overcome to this binding issue?

So maybe "cpu-power-controller"? This should already help for this warning.

Best regards,
Krzysztof
  
AngeloGioacchino Del Regno Nov. 15, 2022, 3:34 p.m. UTC | #7
Il 15/11/22 16:16, Krzysztof Kozlowski ha scritto:
> On 15/11/2022 15:44, AngeloGioacchino Del Regno wrote:
> 
>>>>> Please check and re-submit.
>>>>>
>>>>
>>>> I'm unsure about what I should do about this one.
>>>> This is a power-controller, but does *not* need any #power-domain-cells, as it is
>>>> standalone and doesn't require being attached to anything.
>>>
>>> power-domain-cells are for power domain providers, not consumers. The
>>> generic binding expect that nodes called power-controller are exactly
>>> like that.
>>>
>>> Solutions could be:
>>> 1. Rename the node to something else. I cannot deduct the type of the
>>> device based on description. What is "sequence ID" and how is it even
>>> closely related to power control?
>>
>> This uC is mainly controlling DCVS, automagically plays with voltages for
>> each ramp up/down step and from what I understand also decides to shut down
>> or bring up *power* to "certain clocks" before ungating (CPU related, mainly
>> big cluster).
>> This also interacts with LMH - setting the LMH part makes it possible to
>> later use CPR (otherwise CPR errors out internally and won't start, as it
>> requires this controller, SAW and LMH to be set up in order to work).
>>
>> What I've seen is that without it I can't bring up the big cluster at all,
>> not even at minimum frequency, as the HF2PLL (a clock source for that cluster)
>> will not power up.
>> All it takes is to initialize these params and start the controller, then
>> everything goes as it should.
>>
>> If you're wondering why my explanation may not be particularly satisfying,
>> that's because downstream contains practically no information about this
>> one, apart from a bunch of lines of code and because this controller is
>> just a big black box.
>>
>>>
>>> 2. Narrow the node name in power-domain.yaml which would require changes
>>> in multiple DTS and bindings.
>>>
>>> 3. Do not require power-domain-cells for power-controllers, only for
>>> power-domains.
>>>
>>
>> Solutions 2 and 3... well, I don't think that this would be really feasible
>> as I envision this being the one and only driver that will ever require
>> that kind of thing.
>> Also, this programming was later moved to bootloaders and the only SoCs that
>> will ever require this are MSM8956/76, MSM8953 and.. I think MSM8952 as well,
>> but nothing more.
>>
>> Even if I can imagine the answer, I'm still tempted to ask: can we eventually
>> just name it ramp-controller@xxxx or qcom-rc@xxxx or something "special" like
>> that to overcome to this binding issue?
> 
> So maybe "cpu-power-controller"? This should already help for this warning.
> 

Agreed. Thanks for the advice!

Sending a v3 asap!
  

Patch

diff --git a/Documentation/devicetree/bindings/soc/qcom/qcom,msm8976-ramp-controller.yaml b/Documentation/devicetree/bindings/soc/qcom/qcom,msm8976-ramp-controller.yaml
new file mode 100644
index 000000000000..67f0bdf7d2da
--- /dev/null
+++ b/Documentation/devicetree/bindings/soc/qcom/qcom,msm8976-ramp-controller.yaml
@@ -0,0 +1,37 @@ 
+# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/soc/qcom/qcom,msm8976-ramp-controller.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Qualcomm Ramp Controller
+
+maintainers:
+  - AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
+
+description:
+  The Ramp Controller is used to program the sequence ID for pulse
+  swallowing, enable sequences and link Sequence IDs (SIDs) for the
+  CPU cores on some Qualcomm SoCs.
+
+properties:
+  compatible:
+    enum:
+      - qcom,msm8976-ramp-controller
+
+  reg:
+    maxItems: 1
+
+required:
+  - compatible
+  - reg
+
+additionalProperties: false
+
+examples:
+  - |
+    power-controller@b014000 {
+        compatible = "qcom,msm8976-ramp-controller";
+        reg = <0x0b014000 0x68>;
+    };
+