[PATCH 07/14] dt-bindings: pinctrl: stm32: support IO synchronization parameters
Linus Walleij
linus.walleij at linaro.org
Thu Oct 24 15:38:08 PDT 2024
Hi Antonio/Fabien,
thanks for your patch!
On Tue, Oct 22, 2024 at 5:59 PM Antonio Borneo
<antonio.borneo at foss.st.com> wrote:
> From: Fabien Dessenne <fabien.dessenne at foss.st.com>
>
> Support the following IO synchronization parameters:
> - Delay (in ns)
> - Delay path (input / output)
> - Clock edge (single / double edge)
> - Clock inversion
> - Retiming
>
> Signed-off-by: Fabien Dessenne <fabien.dessenne at foss.st.com>
> Signed-off-by: Antonio Borneo <antonio.borneo at foss.st.com>
(...)
I want to check if we already have some of these properties
and if we don't, if they could and should be made generic,
i.e. will we see more of them, also from other vendors?
> + st,io-delay-path:
> + description: |
> + IO synchronization delay path location
> + 0: Delay switched into the output path
> + 1: Delay switched into the input path
> + $ref: /schemas/types.yaml#/definitions/uint32
> + enum: [0, 1]
This looks related to the st,io-delay below so please keep those
properties together.
Is this path identification really needed in practice, isn't it
implicit from other pin config properties if the pin is used as
input or output, and in that case where the delay applies?
Do you really have - in practice - pins that change between
input and output and need different delays at runtime (i.e. not
at startup)?
Otherwise I would say that just checking if the line is in input
or output from other properties should be enough to configure
this? input-enable, output-enable to name the obvious.
> + st,io-clk-edge:
> + description: |
> + IO synchronization clock edge
> + 0: Data single-edge (changing on rising or falling clock edge)
> + 1: Data double-edge (changing on both clock edges)
> + $ref: /schemas/types.yaml#/definitions/uint32
> + enum: [0, 1]
This looks like it should be made into a generic property,
it seems to be about how the logic is used rather than something
electronic but arguable fits in pin config.
Isn't this usually called DDR (double data rate) in tech speak?
What about a generic property "double-data-rate"?
> + st,io-clk-type:
> + description: |
> + IO synchronization clock inversion
> + 0: IO clocks not inverted. Data retimed to rising clock edge
> + 1: IO clocks inverted. Data retimed to falling clock edge
> + $ref: /schemas/types.yaml#/definitions/uint32
> + enum: [0, 1]
Doesn't this require st,io-retime to be specified at the same time?
Then we should add some YAML magic (if we can) to make sure
that happens.
> + st,io-retime:
> + description: |
> + IO synchronization data retime
> + 0: Data not synchronized or retimed on clock edges
> + 1: Data retimed to either rising or falling clock edge
> + $ref: /schemas/types.yaml#/definitions/uint32
> + enum: [0, 1]
Can't these two be merged into one (generic) property:
io-retime
enum [0, 1, 2]
0=none
1=rising retime
2=falling retime
Retiming seems like a very generic concept so I think it should
be made into a generic property.
> + st,io-delay:
> + description: |
> + IO synchronization delay applied to the input or output path
> + 0: No delay
> + 1: Delay 0.30 ns
> + 2: Delay 0.50 ns
> + 3: Delay 0.75 ns
> + 4: Delay 1.00 ns
> + 5: Delay 1.25 ns
> + 6: Delay 1.50 ns
> + 7: Delay 1.75 ns
> + 8: Delay 2.00 ns
> + 9: Delay 2.25 ns
> + 10: Delay 2.50 ns
> + 11: Delay 2.75 ns
> + 12: Delay 3.00 ns
> + 13: Delay 3.25 ns
> + $ref: /schemas/types.yaml#/definitions/uint32
> + minimum: 0
> + maximum: 13
This looks very similar to the existing "skew-delay" property:
skew-delay:
$ref: /schemas/types.yaml#/definitions/uint32
description:
this affects the expected clock skew on input pins
and the delay before latching a value to an output
pin. Typically indicates how many double-inverters are
used to delay the signal.
can't we just use that?
Feel free to edit the text for it in
Documentation/devicetree/bindings/pinctrl/pincfg-node.yaml
if that is too clock-specific.
Yours,
Linus Walleij
More information about the linux-arm-kernel
mailing list