mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-21 03:33:59 +08:00
3d21a46093
json-schema versions draft7 and earlier have a weird behavior in that any keywords combined with a '$ref' are ignored (silently). The correct form was to put a '$ref' under an 'allOf'. This behavior is now changed in the 2019-09 json-schema spec and '$ref' can be mixed with other keywords. The json-schema library doesn't yet support this, but the tooling now does a fixup for this and either way works. This has been a constant source of review comments, so let's change this treewide so everyone copies the simpler syntax. Scripted with ruamel.yaml with some manual fixups. Some minor whitespace changes from the script. Signed-off-by: Rob Herring <robh@kernel.org> Acked-by: Maxime Ripard <mripard@kernel.org> Acked-by: Lee Jones <lee.jones@linaro.org> Acked-By: Vinod Koul <vkoul@kernel.org> Acked-by: Mark Brown <broonie@kernel.org> Acked-by: Alexandre Belloni <alexandre.belloni@bootlin.com> Acked-by: Wolfram Sang <wsa@the-dreams.de> # for I2C Reviewed-by: Linus Walleij <linus.walleij@linaro.org> Acked-by: Jonathan Cameron <Jonathan.Cameron@huawei.com> #for-iio Reviewed-by: Stephen Boyd <sboyd@kernel.org> # clock Signed-off-by: Rob Herring <robh@kernel.org>
116 lines
3.0 KiB
YAML
116 lines
3.0 KiB
YAML
# SPDX-License-Identifier: GPL-2.0
|
|
%YAML 1.2
|
|
---
|
|
$id: http://devicetree.org/schemas/regulator/gpio-regulator.yaml#
|
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
|
|
|
title: GPIO controlled regulators
|
|
|
|
maintainers:
|
|
- Liam Girdwood <lgirdwood@gmail.com>
|
|
- Mark Brown <broonie@kernel.org>
|
|
|
|
description:
|
|
Any property defined as part of the core regulator binding, defined in
|
|
regulator.txt, can also be used.
|
|
|
|
allOf:
|
|
- $ref: "regulator.yaml#"
|
|
|
|
properties:
|
|
compatible:
|
|
const: regulator-gpio
|
|
|
|
regulator-name: true
|
|
|
|
enable-gpios:
|
|
description: GPIO to use to enable/disable the regulator.
|
|
Warning, the GPIO phandle flags are ignored and the GPIO polarity is
|
|
controlled solely by the presence of "enable-active-high" DT property.
|
|
This is due to compatibility with old DTs.
|
|
maxItems: 1
|
|
|
|
gpios:
|
|
description: Array of one or more GPIO pins used to select the regulator
|
|
voltage/current listed in "states".
|
|
minItems: 1
|
|
maxItems: 8 # Should be enough...
|
|
|
|
gpios-states:
|
|
description: |
|
|
On operating systems, that don't support reading back gpio values in
|
|
output mode (most notably linux), this array provides the state of GPIO
|
|
pins set when requesting them from the gpio controller. Systems, that are
|
|
capable of preserving state when requesting the lines, are free to ignore
|
|
this property.
|
|
0: LOW
|
|
1: HIGH
|
|
Default is LOW if nothing else is specified.
|
|
$ref: /schemas/types.yaml#/definitions/uint32-array
|
|
maxItems: 8
|
|
items:
|
|
enum: [0, 1]
|
|
default: 0
|
|
|
|
states:
|
|
description: Selection of available voltages/currents provided by this
|
|
regulator and matching GPIO configurations to achieve them. If there are
|
|
no states in the "states" array, use a fixed regulator instead.
|
|
$ref: /schemas/types.yaml#/definitions/uint32-matrix
|
|
maxItems: 8
|
|
items:
|
|
items:
|
|
- description: Voltage in microvolts
|
|
- description: GPIO group state value
|
|
|
|
startup-delay-us:
|
|
description: startup time in microseconds
|
|
|
|
enable-active-high:
|
|
description: Polarity of "enable-gpio" GPIO is active HIGH. Default is
|
|
active LOW.
|
|
type: boolean
|
|
|
|
gpio-open-drain:
|
|
description:
|
|
GPIO is open drain type. If this property is missing then default
|
|
assumption is false.
|
|
type: boolean
|
|
|
|
regulator-type:
|
|
description: Specifies what is being regulated.
|
|
$ref: /schemas/types.yaml#/definitions/string
|
|
enum:
|
|
- voltage
|
|
- current
|
|
default: voltage
|
|
|
|
required:
|
|
- compatible
|
|
- regulator-name
|
|
- gpios
|
|
- states
|
|
|
|
examples:
|
|
- |
|
|
gpio-regulator {
|
|
compatible = "regulator-gpio";
|
|
|
|
regulator-name = "mmci-gpio-supply";
|
|
regulator-min-microvolt = <1800000>;
|
|
regulator-max-microvolt = <2600000>;
|
|
regulator-boot-on;
|
|
|
|
enable-gpios = <&gpio0 23 0x4>;
|
|
gpios = <&gpio0 24 0x4
|
|
&gpio0 25 0x4>;
|
|
states = <1800000 0x3>,
|
|
<2200000 0x2>,
|
|
<2600000 0x1>,
|
|
<2900000 0x0>;
|
|
|
|
startup-delay-us = <100000>;
|
|
enable-active-high;
|
|
};
|
|
...
|