Documentation / devicetree / bindings / iio / light / vishay,veml6030.yaml


Based on kernel version 6.13. Page generated on 2025-01-21 08:20 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+
%YAML 1.2
---
$id: http://devicetree.org/schemas/iio/light/vishay,veml6030.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#

title: VEML3235, VEML6030, VEML6035 and VEML7700 Ambient Light Sensors (ALS)

maintainers:
  - Rishi Gupta <gupt21@gmail.com>

description: |
  Bindings for the ambient light sensors veml6030 and veml6035 from
  Vishay Semiconductors over an i2c interface.
 
  Irrespective of whether interrupt is used or not, application
  can get the ALS and White channel reading from IIO raw interface.
 
  If the interrupts are used, application will receive an IIO event
  whenever configured threshold is crossed.
 
  Specifications about the sensors can be found at:
    https://www.vishay.com/docs/80131/veml3235.pdf
    https://www.vishay.com/docs/84366/veml6030.pdf
    https://www.vishay.com/docs/84889/veml6035.pdf
    https://www.vishay.com/docs/84286/veml7700.pdf

properties:
  compatible:
    enum:
      - vishay,veml3235
      - vishay,veml6030
      - vishay,veml6035
      - vishay,veml7700

  reg:
    maxItems: 1

  interrupts:
    description:
      interrupt mapping for IRQ. Configure with IRQ_TYPE_LEVEL_LOW.
      Refer to interrupt-controller/interrupts.txt for generic
      interrupt client node bindings.
    maxItems: 1

  vdd-supply: true

required:
  - compatible
  - reg
  - vdd-supply

allOf:
  - if:
      properties:
        compatible:
          enum:
            - vishay,veml6030
    then:
      properties:
        reg:
          enum:
            - 0x10  # ADDR pin pulled down
            - 0x48  # ADDR pin pulled up

  - if:
      properties:
        compatible:
          enum:
            - vishay,veml6035
    then:
      properties:
        reg:
          enum:
            - 0x29

  - if:
      properties:
        compatible:
          enum:
            - vishay,veml3235
            - vishay,veml7700
    then:
      properties:
        reg:
          enum:
            - 0x10
        interrupts: false

additionalProperties: false

examples:
  - |
    #include <dt-bindings/interrupt-controller/irq.h>
 
    i2c {
        #address-cells = <1>;
        #size-cells = <0>;
 
        light-sensor@10 {
                compatible = "vishay,veml6030";
                reg = <0x10>;
                interrupts = <12 IRQ_TYPE_LEVEL_LOW>;
                vdd-supply = <&vdd>;
        };
    };
...