summaryrefslogtreecommitdiffstats
path: root/drivers/iio/proximity
diff options
context:
space:
mode:
authorJongpil Jung <jongpil19.jung@samsung.com>2022-01-22 13:34:44 -0800
committerJonathan Cameron <Jonathan.Cameron@huawei.com>2022-01-30 12:39:16 +0000
commit19d32860dc7826ef48ea3fb80d9f1b082c4a2cf8 (patch)
tree021285c97e555dcba2bdf6a2f8db1ba76422f5a2 /drivers/iio/proximity
parenta5e9b2ddbbc789f34be2333263232435d8edf57c (diff)
downloadlinux-19d32860dc7826ef48ea3fb80d9f1b082c4a2cf8.tar.bz2
iio: sx9360: fix iio event generation
To convert SX9360 status register ["REG_STAT"], into a channel index, we need to right shift by |stat_offset|, not left shift. Also the PROXSTAT bit (3) is for channel 1 (PHM, Phase Measured), not (PHR, Phase Reference, channel 0), so the offset is 2 instead of 3. Fixes: 1cdb4c47f7f5 ("iio:proximity:sx9360: Add sx9360 support") Signed-off-by: Jongpil Jung <jongpil19.jung@samsung.com> Signed-off-by: Gwendal Grignou <gwendal@chromium.org> Link: https://lore.kernel.org/r/20220122213444.745152-1-gwendal@chromium.org Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
Diffstat (limited to 'drivers/iio/proximity')
-rw-r--r--drivers/iio/proximity/sx9360.c2
-rw-r--r--drivers/iio/proximity/sx_common.c2
2 files changed, 2 insertions, 2 deletions
diff --git a/drivers/iio/proximity/sx9360.c b/drivers/iio/proximity/sx9360.c
index 6fd6561bb6f5..3ebb30c8a4f6 100644
--- a/drivers/iio/proximity/sx9360.c
+++ b/drivers/iio/proximity/sx9360.c
@@ -775,7 +775,7 @@ static const struct sx_common_chip_info sx9360_chip_info = {
.reg_reset = SX9360_REG_RESET,
.mask_enable_chan = SX9360_REG_GNRL_CTRL0_PHEN_MASK,
- .stat_offset = 3,
+ .stat_offset = 2,
.num_channels = SX9360_NUM_CHANNELS,
.num_default_regs = ARRAY_SIZE(sx9360_default_regs),
diff --git a/drivers/iio/proximity/sx_common.c b/drivers/iio/proximity/sx_common.c
index ac8fd5920481..a7c07316a0a9 100644
--- a/drivers/iio/proximity/sx_common.c
+++ b/drivers/iio/proximity/sx_common.c
@@ -87,7 +87,7 @@ static void sx_common_push_events(struct iio_dev *indio_dev)
return;
}
- val <<= data->chip_info->stat_offset;
+ val >>= data->chip_info->stat_offset;
/*
* Only iterate over channels with changes on proximity status that have