diff options
author | Martin Kelly <mkelly@xevo.com> | 2018-04-20 09:54:00 -0700 |
---|---|---|
committer | Jonathan Cameron <Jonathan.Cameron@huawei.com> | 2018-04-21 16:24:30 +0100 |
commit | 5ec6486daa98ba4bb18542116db7d867986c0ebe (patch) | |
tree | a5edf818833df832edec52a40de58f05c80c7b18 /drivers/iio/imu/kmx61.c | |
parent | 17623d9a2310213648e7b563b44eb680d49e0524 (diff) |
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>
Diffstat (limited to 'drivers/iio/imu/kmx61.c')
0 files changed, 0 insertions, 0 deletions