| # SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) |
| %YAML 1.2 |
| --- |
| $id: http://devicetree.org/schemas/regulator/dlg,da9121.yaml# |
| $schema: http://devicetree.org/meta-schemas/core.yaml# |
| |
| title: Dialog Semiconductor DA9121 voltage regulator |
| |
| maintainers: |
| - Adam Ward <Adam.Ward.opensource@diasemi.com> |
| |
| description: | |
| Dialog Semiconductor DA9121 Single-channel 10A double-phase buck converter |
| Dialog Semiconductor DA9122 Double-channel 5A single-phase buck converter |
| Dialog Semiconductor DA9220 Double-channel 3A single-phase buck converter |
| Dialog Semiconductor DA9217 Single-channel 6A double-phase buck converter |
| Dialog Semiconductor DA9130 Single-channel 10A double-phase buck converter |
| Dialog Semiconductor DA9131 Double-channel 5A single-phase buck converter |
| Dialog Semiconductor DA9132 Double-channel 3A single-phase buck converter |
| Dialog Semiconductor DA9141 Single-channel 40A quad-phase buck converter |
| Dialog Semiconductor DA9142 Single-channel 20A double-phase buck converter |
| |
| Device parameter ranges |
| |
| The current limits can be set to at/near double the rated current per channel |
| to allow for transient peaks. |
| Current limit changes when the output is enabled are not supported, as a |
| precaution against undefined behaviour. |
| |
| |----------------------------------------------| |
| | | range & reset default value | |
| | Device |------------------------------| |
| | | microvolt | microamp | |
| |----------------------------------------------| |
| | DA9121/DA9130 | Min: 300000 | Min: 7000000 | |
| | | Max: 1900000 | Max: 20000000 | |
| |----------------------------------------------| |
| | DA9121/DA9131 | Min: 300000 | Min: 3500000 | |
| | | Max: 1900000 | Max: 10000000 | |
| |----------------------------------------------| |
| | DA9121/DA9131 | Min: 300000 | Min: 3500000 | |
| | | Max: 1900000 | Max: 6000000 | |
| |----------------------------------------------| |
| | DA9217 | Min: 300000 | Min: 7000000 | |
| | | Max: 1900000 | Max: 12000000 | |
| |----------------------------------------------| |
| | DA9141 | Min: 300000 | Min: 26000000 | |
| | | Max: 1300000 | Max: 78000000 | |
| |----------------------------------------------| |
| | DA9142 | Min: 300000 | Min: 13000000 | |
| | | Max: 1300000 | Max: 39000000 | |
| |----------------------------------------------| |
| |
| properties: |
| $nodename: |
| pattern: "pmic@[0-9a-f]{1,2}" |
| compatible: |
| enum: |
| - dlg,da9121 |
| - dlg,da9122 |
| - dlg,da9220 |
| - dlg,da9217 |
| - dlg,da9130 |
| - dlg,da9131 |
| - dlg,da9132 |
| - dlg,da9141 |
| - dlg,da9142 |
| |
| reg: |
| maxItems: 1 |
| description: Specifies the I2C slave address. |
| |
| interrupts: |
| maxItems: 1 |
| description: IRQ line information. |
| |
| dlg,irq-polling-delay-passive-ms: |
| minimum: 1000 |
| maximum: 10000 |
| description: | |
| Specify the polling period, measured in milliseconds, between interrupt status |
| update checks. Range 1000-10000 ms. |
| |
| regulators: |
| type: object |
| additionalProperties: false |
| description: | |
| List of regulators provided by the device |
| |
| patternProperties: |
| "^buck([1-2])$": |
| type: object |
| $ref: regulator.yaml# |
| description: | |
| Properties for a single BUCK regulator |
| |
| properties: |
| regulator-initial-mode: |
| enum: [ 0, 1, 2, 3 ] |
| description: Defined in include/dt-bindings/regulator/dlg,da9121-regulator.h |
| |
| enable-gpios: |
| maxItems: 1 |
| description: Specify a valid GPIO for platform control of the regulator |
| |
| dlg,ripple-cancel: |
| $ref: /schemas/types.yaml#/definitions/uint32 |
| enum: [ 0, 1, 2, 3 ] |
| description: | |
| Defined in include/dt-bindings/regulator/dlg,da9121-regulator.h |
| Only present on multi-channel devices (DA9122, DA9220, DA9131, DA9132) |
| |
| unevaluatedProperties: false |
| |
| required: |
| - compatible |
| - reg |
| - regulators |
| |
| allOf: |
| - if: |
| properties: |
| compatible: |
| not: |
| contains: |
| enum: |
| - dlg,da9122 |
| - dlg,da9131 |
| - dlg,da9132 |
| - dlg,da9220 |
| then: |
| properties: |
| regulators: |
| properties: |
| buck2: false |
| |
| additionalProperties: false |
| |
| examples: |
| - | |
| #include <dt-bindings/gpio/gpio.h> |
| #include <dt-bindings/interrupt-controller/irq.h> |
| #include <dt-bindings/regulator/dlg,da9121-regulator.h> |
| i2c { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| pmic@68 { |
| compatible = "dlg,da9121"; |
| reg = <0x68>; |
| |
| interrupt-parent = <&gpio6>; |
| interrupts = <11 IRQ_TYPE_LEVEL_LOW>; |
| |
| dlg,irq-polling-delay-passive-ms = <2000>; |
| |
| regulators { |
| DA9121_BUCK1: buck1 { |
| regulator-name = "BUCK1"; |
| regulator-min-microvolt = <300000>; |
| regulator-max-microvolt = <1900000>; |
| regulator-min-microamp = <7000000>; |
| regulator-max-microamp = <20000000>; |
| regulator-boot-on; |
| regulator-initial-mode = <DA9121_BUCK_MODE_AUTO>; |
| enable-gpios = <&gpio 1 GPIO_ACTIVE_HIGH>; |
| }; |
| }; |
| }; |
| }; |
| |
| - | |
| #include <dt-bindings/gpio/gpio.h> |
| #include <dt-bindings/interrupt-controller/irq.h> |
| #include <dt-bindings/regulator/dlg,da9121-regulator.h> |
| i2c { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| pmic@68 { |
| compatible = "dlg,da9122"; |
| reg = <0x68>; |
| |
| interrupt-parent = <&gpio6>; |
| interrupts = <11 IRQ_TYPE_LEVEL_LOW>; |
| |
| dlg,irq-polling-delay-passive-ms = <2000>; |
| |
| regulators { |
| DA9122_BUCK1: buck1 { |
| regulator-name = "BUCK1"; |
| regulator-min-microvolt = <300000>; |
| regulator-max-microvolt = <1900000>; |
| regulator-min-microamp = <3500000>; |
| regulator-max-microamp = <10000000>; |
| regulator-boot-on; |
| regulator-initial-mode = <DA9121_BUCK_MODE_AUTO>; |
| enable-gpios = <&gpio6 1 GPIO_ACTIVE_HIGH>; |
| dlg,ripple-cancel = <DA9121_BUCK_RIPPLE_CANCEL_NONE>; |
| }; |
| DA9122_BUCK2: buck2 { |
| regulator-name = "BUCK2"; |
| regulator-min-microvolt = <300000>; |
| regulator-max-microvolt = <1900000>; |
| regulator-min-microamp = <3500000>; |
| regulator-max-microamp = <10000000>; |
| regulator-boot-on; |
| regulator-initial-mode = <DA9121_BUCK_MODE_AUTO>; |
| enable-gpios = <&gpio6 2 GPIO_ACTIVE_HIGH>; |
| dlg,ripple-cancel = <DA9121_BUCK_RIPPLE_CANCEL_NONE>; |
| }; |
| }; |
| }; |
| }; |
| ... |