Re: [PATCH] dt-bindings: regulator: microchip,mcp16502: convert to YAML

From: Krzysztof Kozlowski
Date: Tue Jan 23 2024 - 10:55:32 EST


On 23/01/2024 16:45, Andrei Simion wrote:
> Convert devicetree binding mcp16502-regulator.txt to YAML format.
>
> Signed-off-by: Andrei Simion <andrei.simion@xxxxxxxxxxxxx>

Reverse subject prefixes. See: `git log --oneline -- DIRECTORY_OR_FILE`
on the directory your patch is touching.


> ---
> .../bindings/regulator/mcp16502-regulator.txt | 144 --------------
> .../regulator/microchip,mcp16502.yaml | 182 ++++++++++++++++++
> 2 files changed, 182 insertions(+), 144 deletions(-)
> delete mode 100644 Documentation/devicetree/bindings/regulator/mcp16502-regulator.txt
> create mode 100644 Documentation/devicetree/bindings/regulator/microchip,mcp16502.yaml
>
> diff --git a/Documentation/devicetree/bindings/regulator/mcp16502-regulator.txt b/Documentation/devicetree/bindings/regulator/mcp16502-regulator.txt
> deleted file mode 100644
> index 451cc4e86b01..000000000000
> --- a/Documentation/devicetree/bindings/regulator/mcp16502-regulator.txt
> +++ /dev/null
> @@ -1,144 +0,0 @@
> -MCP16502 PMIC
> -
> -Required properties:
> -- compatible: "microchip,mcp16502"
> -- reg: I2C slave address
> -- lpm-gpios: GPIO for LPM pin. Note that this GPIO *must* remain high during
> - suspend-to-ram, keeping the PMIC into HIBERNATE mode; this
> - property is optional;
> -- regulators: A node that houses a sub-node for each regulator within
> - the device. Each sub-node is identified using the node's
> - name. The content of each sub-node is defined by the
> - standard binding for regulators; see regulator.txt.
> -
> -Regulators of MCP16502 PMIC:
> -1) VDD_IO - Buck (1.2 - 3.7 V)
> -2) VDD_DDR - Buck (0.6 - 1.85 V)
> -3) VDD_CORE - Buck (0.6 - 1.85 V)
> -4) VDD_OTHER - BUCK (0.6 - 1.85 V)
> -5) LDO1 - LDO (1.2 - 3.7 V)
> -6) LDO2 - LDO (1.2 - 3.7 V)
> -
> -Regulator modes:
> -2 - FPWM: higher precision, higher consumption
> -4 - AutoPFM: lower precision, lower consumption
> -
> -Each regulator is defined using the standard binding for regulators.
> -
> -Example:
> -
> -mcp16502@5b {
> - compatible = "microchip,mcp16502";
> - reg = <0x5b>;
> - status = "okay";
> - lpm-gpios = <&pioBU 7 GPIO_ACTIVE_HIGH>;
> -
> - regulators {
> - VDD_IO {
> - regulator-name = "VDD_IO";
> - regulator-min-microvolt = <1200000>;
> - regulator-max-microvolt = <3700000>;
> - regulator-initial-mode = <2>;
> - regulator-allowed-modes = <2>, <4>;
> - regulator-always-on;
> -
> - regulator-state-standby {
> - regulator-on-in-suspend;
> - regulator-mode = <4>;
> - };
> -
> - regulator-state-mem {
> - regulator-off-in-suspend;
> - regulator-mode = <4>;
> - };
> - };
> -
> - VDD_DDR {
> - regulator-name = "VDD_DDR";
> - regulator-min-microvolt = <600000>;
> - regulator-max-microvolt = <1850000>;
> - regulator-initial-mode = <2>;
> - regulator-allowed-modes = <2>, <4>;
> - regulator-always-on;
> -
> - regulator-state-standby {
> - regulator-on-in-suspend;
> - regulator-mode = <4>;
> - };
> -
> - regulator-state-mem {
> - regulator-on-in-suspend;
> - regulator-mode = <4>;
> - };
> - };
> -
> - VDD_CORE {
> - regulator-name = "VDD_CORE";
> - regulator-min-microvolt = <600000>;
> - regulator-max-microvolt = <1850000>;
> - regulator-initial-mode = <2>;
> - regulator-allowed-modes = <2>, <4>;
> - regulator-always-on;
> -
> - regulator-state-standby {
> - regulator-on-in-suspend;
> - regulator-mode = <4>;
> - };
> -
> - regulator-state-mem {
> - regulator-off-in-suspend;
> - regulator-mode = <4>;
> - };
> - };
> -
> - VDD_OTHER {
> - regulator-name = "VDD_OTHER";
> - regulator-min-microvolt = <600000>;
> - regulator-max-microvolt = <1850000>;
> - regulator-initial-mode = <2>;
> - regulator-allowed-modes = <2>, <4>;
> - regulator-always-on;
> -
> - regulator-state-standby {
> - regulator-on-in-suspend;
> - regulator-mode = <4>;
> - };
> -
> - regulator-state-mem {
> - regulator-off-in-suspend;
> - regulator-mode = <4>;
> - };
> - };
> -
> - LDO1 {
> - regulator-name = "LDO1";
> - regulator-min-microvolt = <1200000>;
> - regulator-max-microvolt = <3700000>;
> - regulator-always-on;
> -
> - regulator-state-standby {
> - regulator-on-in-suspend;
> - };
> -
> - regulator-state-mem {
> - regulator-off-in-suspend;
> - };
> - };
> -
> - LDO2 {
> - regulator-name = "LDO2";
> - regulator-min-microvolt = <1200000>;
> - regulator-max-microvolt = <3700000>;
> - regulator-always-on;
> -
> - regulator-state-standby {
> - regulator-on-in-suspend;
> - };
> -
> - regulator-state-mem {
> - regulator-off-in-suspend;
> - };
> - };
> -
> - };
> -};
> diff --git a/Documentation/devicetree/bindings/regulator/microchip,mcp16502.yaml b/Documentation/devicetree/bindings/regulator/microchip,mcp16502.yaml
> new file mode 100644
> index 000000000000..13a6806b4604
> --- /dev/null
> +++ b/Documentation/devicetree/bindings/regulator/microchip,mcp16502.yaml
> @@ -0,0 +1,182 @@
> +# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
> +%YAML 1.2
> +---
> +$id: http://devicetree.org/schemas/regulator/microchip,mcp16502.yaml#
> +$schema: http://devicetree.org/meta-schemas/core.yaml#
> +
> +title: MCP16502 - High-Performance PMIC
> +
> +maintainers:
> + - Andrei Simion <andrei.simion@xxxxxxxxxxxxx>
> +
> +description: The MCP16502 is an optimally integrated PMIC compatible

Line break after "description:"

> + with Microchip's eMPUs(Embedded Microprocessor Units), requiring
> + Dynamic Voltage Scaling (DVS) with the use of High-Performance mode (HPM).
> +
> +properties:
> + compatible:
> + const: microchip,mcp16502
> +
> + lpm-gpios:
> + description: GPIO for LPM pin.
> + Note that this GPIO must remain high during
> + suspend-to-ram, keeping the PMIC into HIBERNATE mode;
> + maxItems: 1
> +
> + reg:
> + description: I2C slave address

Drop description, it's obvious.

> + maxItems: 1
> +
> + regulators:
> + type: object

additionalProperties: false

> + description: List of regulators and its properties.
> + A node that houses a sub-node for each regulator within
> + the device. Each sub-node is identified using the node's
> + name. The content of each sub-node is defined by the
> + standard binding for regulators;
> +
> + patternProperties:
> + "^(VDD_(IO|CORE|DDR|OTHER)|LDO[1-2])$":
> + type: object
> + $ref: regulator.yaml#
> +
> + properties:
> + regulator-name:
> + pattern: "^(VDD_(IO|CORE|DDR|OTHER)|LDO[1-2])$"

regulator-name should not be enforced. Does driver actually require it?

> +
> + regulator-allowed-modes:
> + description: Supported modes
> + 2 - FPWM higher precision, higher consumption
> + 4 - AutoPFM lower precision, lower consumption
> + items:
> + enum: [2, 4]

What about initial-mode?

> +
> + unevaluatedProperties: false

Please put this one just after $ref: regulator.yaml

> +
> +required:
> + - compatible
> + - reg
> + - regulators
> +
> +additionalProperties: false
> +
> +examples:
> + - |
> + i2c@600 {

Instead:

i2c {

> + reg = <0x600 0x100>;

Drop

> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + mcp16502@5b {

Node names should be generic. See also an explanation and list of
examples (not exhaustive) in DT specification:
https://devicetree-specification.readthedocs.io/en/latest/chapter2-devicetree-basics.html#generic-names-recommendation
E.g. pmic

> + compatible = "microchip,mcp16502";
> + reg = <0x5b>;
> +
> + regulators {
> + VDD_IO {

Use 4 spaces for example indentation.

> + regulator-name = "VDD_IO";
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-initial-mode = <2>;
> + regulator-allowed-modes = <2>, <4>;
> + regulator-always-on;
> +


Best regards,
Krzysztof