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@xxxxxxxxxxxxx>
---
.../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