[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <12093e84-49b0-d36d-cfde-08ab8af3801c@linaro.org>
Date: Tue, 17 May 2022 16:47:39 +0200
From: Krzysztof Kozlowski <krzysztof.kozlowski@...aro.org>
To: Robert Marko <robimarko@...il.com>, agross@...nel.org,
bjorn.andersson@...aro.org, lgirdwood@...il.com,
broonie@...nel.org, robh+dt@...nel.org,
krzysztof.kozlowski+dt@...aro.org, linux-arm-msm@...r.kernel.org,
linux-kernel@...r.kernel.org, devicetree@...r.kernel.org
Subject: Re: [PATCH v2 1/6] dt-bindings: regulator: qcom,spmi-regulator:
Convert to dtschema
On 17/05/2022 13:59, Robert Marko wrote:
> Convert the bindings of Qualcomm SPMI regulators to DT schema.
>
> Signed-off-by: Robert Marko <robimarko@...il.com>
> ---
> I am aware that syscon alone is not really acceptable, its converted
> directly from the old text bindings.
>
> There is also the issue of some MSM8994, MSM8996 and APQ8096 devices using
> '#address-cells', '#size-cells', some even defining reg property for
> regulators.
>
> Any advice on how to solve these issues is appreciated.
>
> Changes in v2:
Changelog goes after ---
> * Remove the forgotten text bindings
> * Move allOf after patternProperties
> * Use my private email as the maintainer email
> ---
> .../regulator/qcom,spmi-regulator.txt | 347 ------------------
> .../regulator/qcom,spmi-regulator.yaml | 176 +++++++++
> 2 files changed, 176 insertions(+), 347 deletions(-)
> delete mode 100644 Documentation/devicetree/bindings/regulator/qcom,spmi-regulator.txt
> create mode 100644 Documentation/devicetree/bindings/regulator/qcom,spmi-regulator.yaml
>
> diff --git a/Documentation/devicetree/bindings/regulator/qcom,spmi-regulator.txt b/Documentation/devicetree/bindings/regulator/qcom,spmi-regulator.txt
> deleted file mode 100644
> index c2a39b121b1b..000000000000
> --- a/Documentation/devicetree/bindings/regulator/qcom,spmi-regulator.txt
> +++ /dev/null
> @@ -1,347 +0,0 @@
> -Qualcomm SPMI Regulators
> -
> -- compatible:
> - Usage: required
> - Value type: <string>
> - Definition: must be one of:
> - "qcom,pm8004-regulators"
> - "qcom,pm8005-regulators"
> - "qcom,pm8226-regulators"
> - "qcom,pm8841-regulators"
> - "qcom,pm8916-regulators"
> - "qcom,pm8941-regulators"
> - "qcom,pm8950-regulators"
> - "qcom,pm8994-regulators"
> - "qcom,pmi8994-regulators"
> - "qcom,pm660-regulators"
> - "qcom,pm660l-regulators"
> - "qcom,pms405-regulators"
> -
> -- interrupts:
> - Usage: optional
> - Value type: <prop-encoded-array>
> - Definition: List of OCP interrupts.
> -
> -- interrupt-names:
> - Usage: required if 'interrupts' property present
> - Value type: <string-array>
> - Definition: List of strings defining the names of the
> - interrupts in the 'interrupts' property 1-to-1.
> - Supported values are "ocp-<regulator_name>", where
> - <regulator_name> corresponds to a voltage switch
> - type regulator.
> -
> -- vdd_s1-supply:
> -- vdd_s2-supply:
> -- vdd_s3-supply:
> -- vdd_s4-supply:
> -- vdd_s5-supply:
> -- vdd_s6-supply:
> -- vdd_s7-supply:
> -- vdd_s8-supply:
> - Usage: optional (pm8841 only)
> - Value type: <phandle>
> - Definition: Reference to regulator supplying the input pin, as
> - described in the data sheet.
> -
> -- vdd_s1-supply:
> -- vdd_s2-supply:
> -- vdd_s3-supply:
> -- vdd_s4-supply:
> -- vdd_l1_l3-supply:
> -- vdd_l2-supply:
> -- vdd_l4_l5_l6-supply:
> -- vdd_l7-supply:
> -- vdd_l8_l11_l14_l15_l16-supply:
> -- vdd_l9_l10_l12_l13_l17_l18-supply:
> - Usage: optional (pm8916 only)
> - Value type: <phandle>
> - Definition: Reference to regulator supplying the input pin, as
> - described in the data sheet.
> -
> -- vdd_s1-supply:
> -- vdd_s2-supply:
> -- vdd_s3-supply:
> -- vdd_l1_l3-supply:
> -- vdd_l2_lvs_1_2_3-supply:
> -- vdd_l4_l11-supply:
> -- vdd_l5_l7-supply:
> -- vdd_l6_l12_l14_l15-supply:
> -- vdd_l8_l16_l18_19-supply:
> -- vdd_l9_l10_l17_l22-supply:
> -- vdd_l13_l20_l23_l24-supply:
> -- vdd_l21-supply:
> -- vin_5vs-supply:
> - Usage: optional (pm8941 only)
> - Value type: <phandle>
> - Definition: Reference to regulator supplying the input pin, as
> - described in the data sheet.
> -
> -- vdd_s1-supply:
> -- vdd_s2-supply:
> -- vdd_s3-supply:
> -- vdd_s4-supply:
> -- vdd_s4-supply:
> -- vdd_s5-supply:
> -- vdd_s6-supply:
> -- vdd_l1_l19-supply:
> -- vdd_l2_l23-supply:
> -- vdd_l3-supply:
> -- vdd_l4_l5_l6_l7_l16-supply:
> -- vdd_l8_l11_l12_l17_l22-supply:
> -- vdd_l9_l10_l13_l14_l15_l18-supply:
> -- vdd_l20-supply:
> -- vdd_l21-supply:
> - Usage: optional (pm8950 only)
> - Value type: <phandle>
> - Definition: reference to regulator supplying the input pin, as
> - described in the data sheet
> -
> -- vdd_s1-supply:
> -- vdd_s2-supply:
> -- vdd_s3-supply:
> -- vdd_s4-supply:
> -- vdd_s5-supply:
> -- vdd_s6-supply:
> -- vdd_s7-supply:
> -- vdd_s8-supply:
> -- vdd_s9-supply:
> -- vdd_s10-supply:
> -- vdd_s11-supply:
> -- vdd_s12-supply:
> -- vdd_l1-supply:
> -- vdd_l2_l26_l28-supply:
> -- vdd_l3_l11-supply:
> -- vdd_l4_l27_l31-supply:
> -- vdd_l5_l7-supply:
> -- vdd_l6_l12_l32-supply:
> -- vdd_l8_l16_l30-supply:
> -- vdd_l9_l10_l18_l22-supply:
> -- vdd_l13_l19_l23_l24-supply:
> -- vdd_l14_l15-supply:
> -- vdd_l17_l29-supply:
> -- vdd_l20_l21-supply:
> -- vdd_l25-supply:
> -- vdd_lvs_1_2-supply:
> - Usage: optional (pm8994 only)
> - Value type: <phandle>
> - Definition: Reference to regulator supplying the input pin, as
> - described in the data sheet.
> -
> -- vdd_s1-supply:
> -- vdd_s2-supply:
> -- vdd_s3-supply:
> -- vdd_l1-supply:
> - Usage: optional (pmi8994 only)
> - Value type: <phandle>
> - Definition: Reference to regulator supplying the input pin, as
> - described in the data sheet.
> -
> -- vdd_l1_l6_l7-supply:
> -- vdd_l2_l3-supply:
> -- vdd_l5-supply:
> -- vdd_l8_l9_l10_l11_l12_l13_l14-supply:
> -- vdd_l15_l16_l17_l18_l19-supply:
> -- vdd_s1-supply:
> -- vdd_s2-supply:
> -- vdd_s3-supply:
> -- vdd_s5-supply:
> -- vdd_s6-supply:
> - Usage: optional (pm660 only)
> - Value type: <phandle>
> - Definition: Reference to regulator supplying the input pin, as
> - described in the data sheet.
> -
> -- vdd_l1_l9_l10-supply:
> -- vdd_l2-supply:
> -- vdd_l3_l5_l7_l8-supply:
> -- vdd_l4_l6-supply:
> -- vdd_s1-supply:
> -- vdd_s2-supply:
> -- vdd_s3-supply:
> -- vdd_s4-supply:
> -- vdd_s5-supply:
> - Usage: optional (pm660l only)
> - Value type: <phandle>
> - Definition: Reference to regulator supplying the input pin, as
> - described in the data sheet.
> -
> -- vdd_l1_l2-supply:
> -- vdd_l3_l8-supply:
> -- vdd_l4-supply:
> -- vdd_l5_l6-supply:
> -- vdd_l10_l11_l12_l13-supply:
> -- vdd_l7-supply:
> -- vdd_l9-supply:
> -- vdd_s1-supply:
> -- vdd_s2-supply:
> -- vdd_s3-supply:
> -- vdd_s4-supply:
> -- vdd_s5-supply
> - Usage: optional (pms405 only)
> - Value type: <phandle>
> - Definition: Reference to regulator supplying the input pin, as
> - described in the data sheet.
> -
> -- qcom,saw-reg:
> - Usage: optional
> - Value type: <phandle>
> - Description: Reference to syscon node defining the SAW registers.
> -
> -
> -The regulator node houses sub-nodes for each regulator within the device. Each
> -sub-node is identified using the node's name, with valid values listed for each
> -of the PMICs below.
> -
> -pm8004:
> - s2, s5
> -
> -pm8005:
> - s1, s2, s3, s4
> -
> -pm8841:
> - s1, s2, s3, s4, s5, s6, s7, s8
> -
> -pm8916:
> - s1, s2, s3, s4, l1, l2, l3, l4, l5, l6, l7, l8, l9, l10, l11, l12, l13,
> - l14, l15, l16, l17, l18
> -
> -pm8941:
> - s1, s2, s3, s4, l1, l2, l3, l4, l5, l6, l7, l8, l9, l10, l11, l12, l13,
> - l14, l15, l16, l17, l18, l19, l20, l21, l22, l23, l24, lvs1, lvs2, lvs3,
> - 5vs1, 5vs2
> -
> -pm8994:
> - s1, s2, s3, s4, s5, s6, s7, s8, s9, s10, s11, s12, l1, l2, l3, l4, l5,
> - l6, l7, l8, l9, l10, l11, l12, l13, l14, l15, l16, l17, l18, l19, l20,
> - l21, l22, l23, l24, l25, l26, l27, l28, l29, l30, l31, l32, lvs1, lvs2
> -
> -pmi8994:
> - s1, s2, s3, l1
> -
> -The content of each sub-node is defined by the standard binding for regulators -
> -see regulator.txt - with additional custom properties described below:
> -
> -- regulator-initial-mode:
> - Usage: optional
> - Value type: <u32>
> - Description: 2 = Set initial mode to auto mode (automatically select
> - between HPM and LPM); not available on boost type
> - regulators.
> -
> - 1 = Set initial mode to high power mode (HPM), also referred
> - to as NPM. HPM consumes more ground current than LPM, but
> - it can source significantly higher load current. HPM is not
> - available on boost type regulators. For voltage switch type
> - regulators, HPM implies that over current protection and
> - soft start are active all the time.
> -
> - 0 = Set initial mode to low power mode (LPM).
> -
> -- qcom,ocp-max-retries:
> - Usage: optional
> - Value type: <u32>
> - Description: Maximum number of times to try toggling a voltage switch
> - off and back on as a result of consecutive over current
> - events.
> -
> -- qcom,ocp-retry-delay:
> - Usage: optional
> - Value type: <u32>
> - Description: Time to delay in milliseconds between each voltage switch
> - toggle after an over current event takes place.
> -
> -- qcom,pin-ctrl-enable:
> - Usage: optional
> - Value type: <u32>
> - Description: Bit mask specifying which hardware pins should be used to
> - enable the regulator, if any; supported bits are:
> - 0 = ignore all hardware enable signals
> - BIT(0) = follow HW0_EN signal
> - BIT(1) = follow HW1_EN signal
> - BIT(2) = follow HW2_EN signal
> - BIT(3) = follow HW3_EN signal
> -
> -- qcom,pin-ctrl-hpm:
> - Usage: optional
> - Value type: <u32>
> - Description: Bit mask specifying which hardware pins should be used to
> - force the regulator into high power mode, if any;
> - supported bits are:
> - 0 = ignore all hardware enable signals
> - BIT(0) = follow HW0_EN signal
> - BIT(1) = follow HW1_EN signal
> - BIT(2) = follow HW2_EN signal
> - BIT(3) = follow HW3_EN signal
> - BIT(4) = follow PMIC awake state
> -
> -- qcom,vs-soft-start-strength:
> - Usage: optional
> - Value type: <u32>
> - Description: This property sets the soft start strength for voltage
> - switch type regulators; supported values are:
> - 0 = 0.05 uA
> - 1 = 0.25 uA
> - 2 = 0.55 uA
> - 3 = 0.75 uA
> -
> -- qcom,saw-slave:
> - Usage: optional
> - Value type: <boo>
> - Description: SAW controlled gang slave. Will not be configured.
> -
> -- qcom,saw-leader:
> - Usage: optional
> - Value type: <boo>
> - Description: SAW controlled gang leader. Will be configured as
> - SAW regulator.
> -
> -Example:
> -
> - regulators {
> - compatible = "qcom,pm8941-regulators";
> - vdd_l1_l3-supply = <&s1>;
> -
> - s1: s1 {
> - regulator-min-microvolt = <1300000>;
> - regulator-max-microvolt = <1400000>;
> - };
> -
> - ...
> -
> - l1: l1 {
> - regulator-min-microvolt = <1225000>;
> - regulator-max-microvolt = <1300000>;
> - };
> -
> - ....
> - };
> -
> -Example 2:
> -
> - saw3: syscon@...0000 {
> - compatible = "syscon";
> - reg = <0x9A10000 0x1000>;
> - };
> -
> - ...
> -
> - spm-regulators {
> - compatible = "qcom,pm8994-regulators";
> - qcom,saw-reg = <&saw3>;
> - s8 {
> - qcom,saw-slave;
> - };
> - s9 {
> - qcom,saw-slave;
> - };
> - s10 {
> - qcom,saw-slave;
> - };
> - pm8994_s11_saw: s11 {
> - qcom,saw-leader;
> - regulator-always-on;
> - regulator-min-microvolt = <900000>;
> - regulator-max-microvolt = <1140000>;
> - };
> - };
> diff --git a/Documentation/devicetree/bindings/regulator/qcom,spmi-regulator.yaml b/Documentation/devicetree/bindings/regulator/qcom,spmi-regulator.yaml
> new file mode 100644
> index 000000000000..5c747c832529
> --- /dev/null
> +++ b/Documentation/devicetree/bindings/regulator/qcom,spmi-regulator.yaml
> @@ -0,0 +1,176 @@
> +# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
> +%YAML 1.2
> +---
> +$id: http://devicetree.org/schemas/regulator/qcom,spmi-regulator.yaml#
> +$schema: http://devicetree.org/meta-schemas/core.yaml#
> +
> +title: Qualcomm SPMI Regulators
> +
> +maintainers:
> + - Robert Marko <robimarko@...il.com>
> +
> +properties:
> + compatible:
> + enum:
> + - qcom,pm660-regulators
> + - qcom,pm660l-regulators
> + - qcom,pm8004-regulators
> + - qcom,pm8005-regulators
> + - qcom,pm8226-regulators
> + - qcom,pm8841-regulators
> + - qcom,pm8916-regulators
> + - qcom,pm8941-regulators
> + - qcom,pm8950-regulators
> + - qcom,pm8994-regulators
> + - qcom,pmi8994-regulators
> + - qcom,pms405-regulators
> +
You miss here interrupts+names.
> + qcom,saw-reg:
> + description: Reference to syscon node defining the SAW registers
> + $ref: "/schemas/types.yaml#/definitions/phandle"
No quotes around this.
> +
> +patternProperties:
> + ".*-supply$":
We should not allow any supply, but rather a strictly defined pattern.
What I actually prefer is to see something like this:
https://lore.kernel.org/all/20220426105501.73200-3-krzysztof.kozlowski@linaro.org/
but that's not a requirement. Some specific pattern is enough.
> + description: Input supply phandle(s) for this node
> + $ref: "/schemas/types.yaml#/definitions/phandle"
> +
> + "^((s|l|lvs|5vs)[0-9]*)$":
s1111 should not be a valid regulator. :)
Neither s000000.
Best regards,
Krzysztof
Powered by blists - more mailing lists