From: Krzysztof Kozlowski <krzk@kernel.org>
To: "Edgar E. Iglesias" <edgar.iglesias@gmail.com>,
mturquette@baylibre.com, sboyd@kernel.org, robh@kernel.org,
krzk+dt@kernel.org, conor+dt@kernel.org, jank@cadence.com
Cc: edgar.iglesias@amd.com, linux-clk@vger.kernel.org,
devicetree@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH v1 1/2] dt-bindings: clk: fixed-mmio-clock: Add optional ready reg
Date: Mon, 26 May 2025 06:53:14 +0200 [thread overview]
Message-ID: <e7efac3d-8dbf-4370-8f36-ffa9351593c0@kernel.org> (raw)
In-Reply-To: <20250525190806.1204531-2-edgar.iglesias@gmail.com>
On 25/05/2025 21:08, Edgar E. Iglesias wrote:
> From: "Edgar E. Iglesias" <edgar.iglesias@amd.com>
>
> Add an optional ready register and properties describing bitfields
> that signal when the clock is ready. This can for example be useful
> to describe PLL lock bits.
>
> Signed-off-by: Edgar E. Iglesias <edgar.iglesias@amd.com>
> ---
> .../bindings/clock/fixed-mmio-clock.yaml | 38 ++++++++++++++++++-
> 1 file changed, 37 insertions(+), 1 deletion(-)
>
> diff --git a/Documentation/devicetree/bindings/clock/fixed-mmio-clock.yaml b/Documentation/devicetree/bindings/clock/fixed-mmio-clock.yaml
> index e22fc272d023..90033ba389e8 100644
> --- a/Documentation/devicetree/bindings/clock/fixed-mmio-clock.yaml
> +++ b/Documentation/devicetree/bindings/clock/fixed-mmio-clock.yaml
> @@ -10,6 +10,11 @@ description:
> This binding describes a fixed-rate clock for which the frequency can
> be read from a single 32-bit memory mapped I/O register.
>
> + An optional ready register can be specified in a second reg entry.
> + The ready register will be polled until it signals ready prior to reading
> + the fixed rate. This is useful for example to optionally wait for a PLL
> + to lock.
> +
> It was designed for test systems, like FPGA, not for complete,
> finished SoCs.
>
> @@ -21,7 +26,10 @@ properties:
> const: fixed-mmio-clock
>
> reg:
> - maxItems: 1
> + minItems: 1
> + items:
> + - description: Fixed rate register
> + - description: Optional clock ready register
>
I am not convinced we actually want this. If you have more complicated
clocks which need more than one register, then maybe this is too complex
for generic device and you should just make this part of clock controller.
Also I wonder how a clock, which is not controllable, cannot be gated,
can be ready or not. Issue is easily visible in your driver:
1. Probe the driver
2. Clock is not ready - you wait...
3. and wait and entire probe is waiting and busy-looping
4. Probed.
5. Unbind device
6. Rebind and again we check if clock is ready? Why? Nothing changed in
the hardware, clock was not disabled.
Although above is maybe better question for driver design, but it still
makes me wonder whether you are just putting driver complexity into DT.
> "#clock-cells":
> const: 0
> @@ -29,6 +37,25 @@ properties:
> clock-output-names:
> maxItems: 1
>
> + ready-timeout:
> + description:
> + Optional timeout in micro-seconds when polling for clock readiness.
> + 0 means no timeout.
Use a proper unit suffix.
https://github.com/devicetree-org/dt-schema/blob/main/dtschema/schemas/property-units.yaml
> + $ref: /schemas/types.yaml#/definitions/uint32
Drop
> + default: 0
> +
> + ready-mask:
> + description:
> + Optional mask to apply when reading the ready register.
> + $ref: /schemas/types.yaml#/definitions/uint32
> + default: 0xffffffff
> +
> + ready-value:
> + description:
> + When a ready register is specified in reg, poll the ready reg until
> + ready-reg & ready-mask == ready-value.
> + $ref: /schemas/types.yaml#/definitions/uint32
> +
> required:
> - compatible
> - reg
> @@ -44,4 +71,13 @@ examples:
> reg = <0xfd020004 0x4>;
> clock-output-names = "sysclk";
> };
> + - |
> + pclk: pclk@fd040000 {
clock@
And drop unused label
> + compatible = "fixed-mmio-clock";
> + #clock-cells = <0>;
> + reg = <0xfd040000 0x4 0xfd040004 0x4>;
> + ready-mask = <1>;
> + ready-value = <1>;
> + clock-output-names = "pclk";
> + };
> ...
Best regards,
Krzysztof
next prev parent reply other threads:[~2025-05-26 4:53 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-05-25 19:08 [PATCH v1 0/2] clk: fixed-mmio: Add optional ready registers Edgar E. Iglesias
2025-05-25 19:08 ` [PATCH v1 1/2] dt-bindings: clk: fixed-mmio-clock: Add optional ready reg Edgar E. Iglesias
2025-05-26 4:53 ` Krzysztof Kozlowski [this message]
2025-05-26 11:28 ` Edgar E. Iglesias
2025-05-25 19:08 ` [PATCH v1 2/2] clk: fixed-mmio: Add optional poll for clk readiness Edgar E. Iglesias
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=e7efac3d-8dbf-4370-8f36-ffa9351593c0@kernel.org \
--to=krzk@kernel.org \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=edgar.iglesias@amd.com \
--cc=edgar.iglesias@gmail.com \
--cc=jank@cadence.com \
--cc=krzk+dt@kernel.org \
--cc=linux-clk@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mturquette@baylibre.com \
--cc=robh@kernel.org \
--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