diff mbox series

[11/38] dt-bindings: power: supply: sbs-manager: Convert to DT schema format

Message ID 20210312154357.1561730-12-sebastian.reichel@collabora.com
State Superseded
Headers show
Series Convert power-supply DT bindings to YAML | expand

Commit Message

Sebastian Reichel March 12, 2021, 3:43 p.m. UTC
Convert the binding to DT schema format.

Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
---
 .../bindings/power/supply/sbs,sbs-manager.txt |  66 -----------
 .../power/supply/sbs,sbs-manager.yaml         | 111 ++++++++++++++++++
 2 files changed, 111 insertions(+), 66 deletions(-)
 delete mode 100644 Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.txt
 create mode 100644 Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.yaml

Comments

Rob Herring March 15, 2021, 6:27 p.m. UTC | #1
On Fri, Mar 12, 2021 at 8:45 AM Sebastian Reichel
<sebastian.reichel@collabora.com> wrote:
>

> Convert the binding to DT schema format.

>

> Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>

> ---

>  .../bindings/power/supply/sbs,sbs-manager.txt |  66 -----------

>  .../power/supply/sbs,sbs-manager.yaml         | 111 ++++++++++++++++++

>  2 files changed, 111 insertions(+), 66 deletions(-)

>  delete mode 100644 Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.txt

>  create mode 100644 Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.yaml

>



> diff --git a/Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.yaml b/Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.yaml

> new file mode 100644

> index 000000000000..592c476d83e6

> --- /dev/null

> +++ b/Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.yaml

> @@ -0,0 +1,111 @@

> +# SPDX-License-Identifier: GPL-2.0

> +%YAML 1.2

> +---

> +$id: http://devicetree.org/schemas/power/supply/sbs,sbs-manager.yaml#

> +$schema: http://devicetree.org/meta-schemas/core.yaml#

> +

> +title: SBS compliant manger

> +

> +maintainers:

> +  - Sebastian Reichel <sre@kernel.org>

> +

> +allOf:

> +  - $ref: power-supply.yaml#

> +

> +properties:

> +  compatible:

> +    oneOf:

> +      - items:

> +          - enum:

> +              - lltc,ltc1760

> +          - enum:

> +              - sbs,sbs-manager

> +      - items:

> +          - const: sbs,sbs-manager

> +

> +  reg:

> +    const: 0xa

> +

> +  "#address-cells":

> +    const: 1

> +

> +  "#size-cells":

> +    const: 0

> +

> +  gpio-controller: true

> +

> +  "#gpio-cells":

> +    const: 2

> +

> +required:

> +  - compatible

> +  - reg

> +

> +additionalProperties: false

> +

> +dependencies:

> +  '#gpio-cells': [gpio-controller]

> +  gpio-controller: ['#gpio-cells']


The core schema should capture these dependencies.

> +

> +patternProperties:

> +  "^i2c@[1-4]$":

> +    type: object

> +

> +    allOf:

> +      - $ref: /schemas/i2c/i2c-controller.yaml#

> +

> +examples:

> +  - |

> +    #include <dt-bindings/interrupt-controller/irq.h>

> +    #include <dt-bindings/gpio/gpio.h>

> +

> +    i2c {

> +      #address-cells = <1>;

> +      #size-cells = <0>;

> +

> +      batman: battery-manager@a {

> +        compatible = "lltc,ltc1760", "sbs,sbs-manager";

> +        reg = <0x0a>;

> +        #address-cells = <1>;

> +        #size-cells = <0>;

> +

> +        gpio-controller;

> +        #gpio-cells = <2>;

> +

> +        i2c@1 {

> +          #address-cells = <1>;

> +          #size-cells = <0>;

> +          reg = <1>;

> +

> +          battery@b {

> +            compatible = "ti,bq20z65", "sbs,sbs-battery";

> +            reg = <0x0b>;

> +            sbs,battery-detect-gpios = <&batman 1 1>;

> +          };

> +        };

> +

> +        i2c@2 {

> +          #address-cells = <1>;

> +          #size-cells = <0>;

> +          reg = <2>;

> +

> +          battery@b {

> +            compatible = "ti,bq20z65", "sbs,sbs-battery";

> +            reg = <0x0b>;

> +            sbs,battery-detect-gpios = <&batman 2 1>;

> +          };

> +        };

> +

> +        i2c@3 {

> +          #address-cells = <1>;

> +          #size-cells = <0>;

> +          reg = <3>;

> +

> +          battery@b {

> +            compatible = "ti,bq20z65", "sbs,sbs-battery";

> +            reg = <0x0b>;

> +            sbs,battery-detect-gpios = <&batman 3 1>;

> +          };

> +        };

> +      };

> +    };

> --

> 2.30.1

>
diff mbox series

Patch

diff --git a/Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.txt b/Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.txt
deleted file mode 100644
index 4b2195571a49..000000000000
--- a/Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.txt
+++ /dev/null
@@ -1,66 +0,0 @@ 
-Binding for sbs-manager
-
-Required properties:
-- compatible: "<vendor>,<part-number>", "sbs,sbs-charger" as fallback. The part
-  number compatible string might be used in order to take care of vendor
-  specific registers.
-- reg: integer, i2c address of the device. Should be <0xa>.
-Optional properties:
-- gpio-controller: Marks the port as GPIO controller.
-  See "gpio-specifier" in .../devicetree/bindings/gpio/gpio.txt.
-- #gpio-cells: Should be <2>. The first cell is the pin number, the second cell
-  is used to specify optional parameters:
-  See "gpio-specifier" in .../devicetree/bindings/gpio/gpio.txt.
-
-From OS view the device is basically an i2c-mux used to communicate with up to
-four smart battery devices at address 0xb. The driver actually implements this
-behaviour. So standard i2c-mux nodes can be used to register up to four slave
-batteries. Channels will be numerated starting from 1 to 4.
-
-Example:
-
-batman@a {
-    compatible = "lltc,ltc1760", "sbs,sbs-manager";
-    reg = <0x0a>;
-    #address-cells = <1>;
-    #size-cells = <0>;
-
-    gpio-controller;
-    #gpio-cells = <2>;
-
-    i2c@1 {
-        #address-cells = <1>;
-        #size-cells = <0>;
-        reg = <1>;
-
-        battery@b {
-            compatible = "ti,bq2060", "sbs,sbs-battery";
-            reg = <0x0b>;
-            sbs,battery-detect-gpios = <&batman 1 1>;
-        };
-    };
-
-    i2c@2 {
-        #address-cells = <1>;
-        #size-cells = <0>;
-        reg = <2>;
-
-        battery@b {
-            compatible = "ti,bq2060", "sbs,sbs-battery";
-            reg = <0x0b>;
-            sbs,battery-detect-gpios = <&batman 2 1>;
-        };
-    };
-
-    i2c@3 {
-        #address-cells = <1>;
-        #size-cells = <0>;
-        reg = <3>;
-
-        battery@b {
-            compatible = "ti,bq2060", "sbs,sbs-battery";
-            reg = <0x0b>;
-            sbs,battery-detect-gpios = <&batman 3 1>;
-        };
-    };
-};
diff --git a/Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.yaml b/Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.yaml
new file mode 100644
index 000000000000..592c476d83e6
--- /dev/null
+++ b/Documentation/devicetree/bindings/power/supply/sbs,sbs-manager.yaml
@@ -0,0 +1,111 @@ 
+# SPDX-License-Identifier: GPL-2.0
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/power/supply/sbs,sbs-manager.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: SBS compliant manger
+
+maintainers:
+  - Sebastian Reichel <sre@kernel.org>
+
+allOf:
+  - $ref: power-supply.yaml#
+
+properties:
+  compatible:
+    oneOf:
+      - items:
+          - enum:
+              - lltc,ltc1760
+          - enum:
+              - sbs,sbs-manager
+      - items:
+          - const: sbs,sbs-manager
+
+  reg:
+    const: 0xa
+
+  "#address-cells":
+    const: 1
+
+  "#size-cells":
+    const: 0
+
+  gpio-controller: true
+
+  "#gpio-cells":
+    const: 2
+
+required:
+  - compatible
+  - reg
+
+additionalProperties: false
+
+dependencies:
+  '#gpio-cells': [gpio-controller]
+  gpio-controller: ['#gpio-cells']
+
+patternProperties:
+  "^i2c@[1-4]$":
+    type: object
+
+    allOf:
+      - $ref: /schemas/i2c/i2c-controller.yaml#
+
+examples:
+  - |
+    #include <dt-bindings/interrupt-controller/irq.h>
+    #include <dt-bindings/gpio/gpio.h>
+
+    i2c {
+      #address-cells = <1>;
+      #size-cells = <0>;
+
+      batman: battery-manager@a {
+        compatible = "lltc,ltc1760", "sbs,sbs-manager";
+        reg = <0x0a>;
+        #address-cells = <1>;
+        #size-cells = <0>;
+
+        gpio-controller;
+        #gpio-cells = <2>;
+
+        i2c@1 {
+          #address-cells = <1>;
+          #size-cells = <0>;
+          reg = <1>;
+
+          battery@b {
+            compatible = "ti,bq20z65", "sbs,sbs-battery";
+            reg = <0x0b>;
+            sbs,battery-detect-gpios = <&batman 1 1>;
+          };
+        };
+
+        i2c@2 {
+          #address-cells = <1>;
+          #size-cells = <0>;
+          reg = <2>;
+
+          battery@b {
+            compatible = "ti,bq20z65", "sbs,sbs-battery";
+            reg = <0x0b>;
+            sbs,battery-detect-gpios = <&batman 2 1>;
+          };
+        };
+
+        i2c@3 {
+          #address-cells = <1>;
+          #size-cells = <0>;
+          reg = <3>;
+
+          battery@b {
+            compatible = "ti,bq20z65", "sbs,sbs-battery";
+            reg = <0x0b>;
+            sbs,battery-detect-gpios = <&batman 3 1>;
+          };
+        };
+      };
+    };