Documentation / devicetree / bindings / regulator / maxim,max20086.yaml


Based on kernel version 6.8. Page generated on 2024-03-11 21:26 EST.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
%YAML 1.2
---
$id: http://devicetree.org/schemas/regulator/maxim,max20086.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#

title: Maxim Integrated MAX20086-MAX20089 Camera Power Protector

maintainers:
  - Laurent Pinchart <laurent.pinchart@ideasonboard.com>

description: |
  The MAX20086-MAX20089 are dual/quad camera power protectors, designed to
  deliver power over coax for radar and camera modules. They support
  software-configurable output switching and monitoring. The output voltage and
  current limit are fixed by the hardware design.

properties:
  compatible:
    enum:
      - maxim,max20086
      - maxim,max20087
      - maxim,max20088
      - maxim,max20089

  reg:
    maxItems: 1

  enable-gpios:
    maxItems: 1
    description: GPIO connected to the EN pin, active high

  in-supply:
    description: Input supply for the camera outputs (IN pin, 3.0V to 15.0V)

  vdd-supply:
    description: Input supply for the device (VDD pin, 3.0V to 5.5V)

  regulators:
    type: object

    patternProperties:
      "^OUT[1-4]$":
        type: object
        $ref: regulator.yaml#
        unevaluatedProperties: false

    additionalProperties: false

required:
  - compatible
  - reg
  - in-supply
  - vdd-supply
  - regulators

allOf:
  - if:
      properties:
        compatible:
          contains:
            enum:
              - maxim,max20088
              - maxim,max20089
    then:
      properties:
        regulators:
          properties:
            OUT3: false
            OUT4: false

additionalProperties: false

examples:
  - |
    #include <dt-bindings/gpio/gpio.h>
 
    i2c {
        #address-cells = <1>;
        #size-cells = <0>;
 
        regulator@28 {
            compatible = "maxim,max20087";
            reg = <0x28>;
 
            in-supply = <&reg_12v0>;
            vdd-supply = <&reg_3v3>;
 
            enable-gpios = <&gpio 108 GPIO_ACTIVE_HIGH>;
 
            regulators {
                OUT1 {
                    regulator-name = "VOUT1";
                };
                OUT2 {
                    regulator-name = "VOUT2";
                };
                OUT3 {
                    regulator-name = "VOUT3";
                };
                OUT4 {
                    regulator-name = "VOUT4";
                };
            };
        };
    };
...