linux_dsm_epyc7002/drivers/iio/imu/inv_mpu6050
Martin Kelly 5ec6486daa iio:imu: inv_mpu6050: support more interrupt types
Currently, we support only rising edge interrupts, and in fact we assume
that the interrupt we're given is rising edge (and things won't work if
it's not). However, the device supports rising edge, falling edge, level
low, and level high interrupts.

Empirically, on my system, switching to level interrupts has fixed a
problem I had with significant (~40%) interrupt loss with edge
interrupts. This issue is likely related to the SoC I'm using (Allwinner
H3), but being able to switch the interrupt type is still a very useful
workaround.

I tested this with each interrupt type and verified correct behavior in
a logic analyzer.

Add support for these interrupt types while also eliminating the error
case of the device tree and driver using different interrupt types.

Signed-off-by: Martin Kelly <mkelly@xevo.com>
Acked-by: Jean-Baptiste Maneyrol <jmaneyrol@invensense.com>
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
2018-04-21 16:24:30 +01:00
..
inv_mpu_acpi.c iio: imu: inv_mpu6050: Remove duplicate NULL check 2017-12-02 10:40:11 +00:00
inv_mpu_core.c iio:imu: inv_mpu6050: support more interrupt types 2018-04-21 16:24:30 +01:00
inv_mpu_i2c.c iio:imu: inv_mpu6050: support more interrupt types 2018-04-21 16:24:30 +01:00
inv_mpu_iio.h iio:imu: inv_mpu6050: support more interrupt types 2018-04-21 16:24:30 +01:00
inv_mpu_ring.c iio:imu: inv_mpu6050: support more interrupt types 2018-04-21 16:24:30 +01:00
inv_mpu_spi.c iio: imu: Add mpu9255 support to mpu6050 driver 2018-04-15 19:07:38 +01:00
inv_mpu_trigger.c iio:imu: inv_mpu6050: support more interrupt types 2018-04-21 16:24:30 +01:00
Kconfig iio:imu:mpu6050: icm20608 initial support 2016-07-03 12:39:57 +01:00
Makefile License cleanup: add SPDX GPL-2.0 license identifier to files with no license 2017-11-02 11:10:55 +01:00