mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
synced 2025-09-03 17:51:23 +00:00

Add interrupt-names INT1 and INT2 for the two interrupt lines of the sensor. When one of the two interrupt lines is connected, the interrupt as its interrupt-name, need to be declared in the devicetree. The driver then configures the sensor to indicate its events on either INT1 or INT2. If no interrupt is configured, then no interrupt-name should be configured, and vice versa. In this case the sensor runs in FIFO BYPASS mode. This allows sensor measurements, but none of the sensor events. Signed-off-by: Lothar Rubusch <l.rubusch@gmail.com> Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> Link: https://patch.msgid.link/20241225181338.69672-4-l.rubusch@gmail.com Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
93 lines
2.1 KiB
YAML
93 lines
2.1 KiB
YAML
# SPDX-License-Identifier: GPL-2.0
|
|
%YAML 1.2
|
|
---
|
|
$id: http://devicetree.org/schemas/iio/accel/adi,adxl345.yaml#
|
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
|
|
|
title: Analog Devices ADXL345/ADXL375 3-Axis Digital Accelerometers
|
|
|
|
maintainers:
|
|
- Michael Hennerich <michael.hennerich@analog.com>
|
|
|
|
description: |
|
|
Analog Devices ADXL345/ADXL375 3-Axis Digital Accelerometers that supports
|
|
both I2C & SPI interfaces.
|
|
https://www.analog.com/en/products/mems/accelerometers/adxl345.html
|
|
https://www.analog.com/en/products/sensors-mems/accelerometers/adxl375.html
|
|
|
|
properties:
|
|
compatible:
|
|
oneOf:
|
|
- items:
|
|
- const: adi,adxl346
|
|
- const: adi,adxl345
|
|
- enum:
|
|
- adi,adxl345
|
|
- adi,adxl375
|
|
|
|
reg:
|
|
maxItems: 1
|
|
|
|
spi-cpha: true
|
|
|
|
spi-cpol: true
|
|
|
|
spi-3wire: true
|
|
|
|
interrupts:
|
|
maxItems: 1
|
|
|
|
interrupt-names:
|
|
items:
|
|
- enum: [INT1, INT2]
|
|
|
|
dependencies:
|
|
interrupts: [ interrupt-names ]
|
|
interrupt-names: [ interrupts ]
|
|
|
|
required:
|
|
- compatible
|
|
- reg
|
|
|
|
allOf:
|
|
- $ref: /schemas/spi/spi-peripheral-props.yaml#
|
|
|
|
unevaluatedProperties: false
|
|
|
|
examples:
|
|
- |
|
|
#include <dt-bindings/gpio/gpio.h>
|
|
#include <dt-bindings/interrupt-controller/irq.h>
|
|
i2c {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
/* Example for a I2C device node */
|
|
accelerometer@2a {
|
|
compatible = "adi,adxl345";
|
|
reg = <0x2a>;
|
|
interrupt-parent = <&gpio0>;
|
|
interrupts = <0 IRQ_TYPE_LEVEL_HIGH>;
|
|
interrupt-names = "INT1";
|
|
};
|
|
};
|
|
- |
|
|
#include <dt-bindings/gpio/gpio.h>
|
|
#include <dt-bindings/interrupt-controller/irq.h>
|
|
spi {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
/* Example for a SPI device node */
|
|
accelerometer@0 {
|
|
compatible = "adi,adxl345";
|
|
reg = <0>;
|
|
spi-max-frequency = <5000000>;
|
|
spi-cpol;
|
|
spi-cpha;
|
|
interrupt-parent = <&gpio0>;
|
|
interrupts = <0 IRQ_TYPE_LEVEL_HIGH>;
|
|
interrupt-names = "INT2";
|
|
};
|
|
};
|