1# SPDX-License-Identifier: GPL-2.0 2%YAML 1.2 3--- 4$id: http://devicetree.org/schemas/regulator/gpio-regulator.yaml# 5$schema: http://devicetree.org/meta-schemas/core.yaml# 6 7title: GPIO controlled regulators 8 9maintainers: 10 - Liam Girdwood <lgirdwood@gmail.com> 11 - Mark Brown <broonie@kernel.org> 12 13description: 14 Any property defined as part of the core regulator binding, defined in 15 regulator.txt, can also be used. 16 17allOf: 18 - $ref: regulator.yaml# 19 20properties: 21 compatible: 22 const: regulator-gpio 23 24 regulator-name: true 25 26 enable-gpios: 27 description: GPIO to use to enable/disable the regulator. 28 Warning, the GPIO phandle flags are ignored and the GPIO polarity is 29 controlled solely by the presence of "enable-active-high" DT property. 30 This is due to compatibility with old DTs. 31 maxItems: 1 32 33 gpios: 34 description: Array of one or more GPIO pins used to select the regulator 35 voltage/current listed in "states". 36 minItems: 1 37 maxItems: 8 # Should be enough... 38 39 gpios-states: 40 description: | 41 On operating systems, that don't support reading back gpio values in 42 output mode (most notably linux), this array provides the state of GPIO 43 pins set when requesting them from the gpio controller. Systems, that are 44 capable of preserving state when requesting the lines, are free to ignore 45 this property. 46 0: LOW 47 1: HIGH 48 Default is LOW if nothing else is specified. 49 $ref: /schemas/types.yaml#/definitions/uint32-array 50 minItems: 1 51 maxItems: 8 52 items: 53 enum: [0, 1] 54 default: 0 55 56 states: 57 description: Selection of available voltages/currents provided by this 58 regulator and matching GPIO configurations to achieve them. If there are 59 no states in the "states" array, use a fixed regulator instead. 60 $ref: /schemas/types.yaml#/definitions/uint32-matrix 61 minItems: 2 62 maxItems: 256 63 items: 64 items: 65 - description: Voltage in microvolts 66 - description: GPIO group state value 67 68 startup-delay-us: 69 description: startup time in microseconds 70 71 enable-active-high: 72 description: Polarity of "enable-gpio" GPIO is active HIGH. Default is 73 active LOW. 74 type: boolean 75 76 gpio-open-drain: 77 description: 78 GPIO is open drain type. If this property is missing then default 79 assumption is false. 80 type: boolean 81 82 regulator-type: 83 description: Specifies what is being regulated. 84 $ref: /schemas/types.yaml#/definitions/string 85 enum: 86 - voltage 87 - current 88 default: voltage 89 90 vin-supply: 91 description: Input supply phandle. 92 93required: 94 - compatible 95 - regulator-name 96 - gpios 97 - states 98 99unevaluatedProperties: false 100 101examples: 102 - | 103 gpio-regulator { 104 compatible = "regulator-gpio"; 105 106 regulator-name = "mmci-gpio-supply"; 107 regulator-min-microvolt = <1800000>; 108 regulator-max-microvolt = <2600000>; 109 regulator-boot-on; 110 111 enable-gpios = <&gpio0 23 0x4>; 112 gpios = <&gpio0 24 0x4 113 &gpio0 25 0x4>; 114 states = <1800000 0x3>, 115 <2200000 0x2>, 116 <2600000 0x1>, 117 <2900000 0x0>; 118 119 startup-delay-us = <100000>; 120 enable-active-high; 121 }; 122... 123