|
Takashi Iwai |
9e1dde |
From fde272e78e004a45c7e4976876277d7e6a5a0ede Mon Sep 17 00:00:00 2001
|
|
Takashi Iwai |
9e1dde |
From: Kister Genesis Jimenez <kister.jimenez@analog.com>
|
|
Takashi Iwai |
9e1dde |
Date: Mon, 15 Nov 2021 11:41:47 +0100
|
|
Takashi Iwai |
9e1dde |
Subject: [PATCH] iio: gyro: adxrs290: fix data signedness
|
|
Takashi Iwai |
9e1dde |
Mime-version: 1.0
|
|
Takashi Iwai |
9e1dde |
Content-type: text/plain; charset=UTF-8
|
|
Takashi Iwai |
9e1dde |
Content-transfer-encoding: 8bit
|
|
Takashi Iwai |
9e1dde |
Git-commit: fde272e78e004a45c7e4976876277d7e6a5a0ede
|
|
Takashi Iwai |
9e1dde |
Patch-mainline: v5.16-rc5
|
|
Takashi Iwai |
9e1dde |
References: git-fixes
|
|
Takashi Iwai |
9e1dde |
|
|
Takashi Iwai |
9e1dde |
Properly sign-extend the rate and temperature data.
|
|
Takashi Iwai |
9e1dde |
|
|
Takashi Iwai |
9e1dde |
Fixes: 2c8920fff1457 ("iio: gyro: Add driver support for ADXRS290")
|
|
Takashi Iwai |
9e1dde |
Signed-off-by: Kister Genesis Jimenez <kister.jimenez@analog.com>
|
|
Takashi Iwai |
9e1dde |
Signed-off-by: Nuno Sá <nuno.sa@analog.com>
|
|
Takashi Iwai |
9e1dde |
Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com>
|
|
Takashi Iwai |
9e1dde |
Link: https://lore.kernel.org/r/20211115104147.18669-1-nuno.sa@analog.com
|
|
Takashi Iwai |
9e1dde |
Cc: <Stable@vger.kernel.org>
|
|
Takashi Iwai |
9e1dde |
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
|
|
Takashi Iwai |
9e1dde |
Acked-by: Takashi Iwai <tiwai@suse.de>
|
|
Takashi Iwai |
9e1dde |
|
|
Takashi Iwai |
9e1dde |
---
|
|
Takashi Iwai |
9e1dde |
drivers/iio/gyro/adxrs290.c | 5 +++--
|
|
Takashi Iwai |
9e1dde |
1 file changed, 3 insertions(+), 2 deletions(-)
|
|
Takashi Iwai |
9e1dde |
|
|
Takashi Iwai |
9e1dde |
diff --git a/drivers/iio/gyro/adxrs290.c b/drivers/iio/gyro/adxrs290.c
|
|
Takashi Iwai |
9e1dde |
index 3e0734ddafe3..600e9725da78 100644
|
|
Takashi Iwai |
9e1dde |
--- a/drivers/iio/gyro/adxrs290.c
|
|
Takashi Iwai |
9e1dde |
+++ b/drivers/iio/gyro/adxrs290.c
|
|
Takashi Iwai |
9e1dde |
@@ -7,6 +7,7 @@
|
|
Takashi Iwai |
9e1dde |
*/
|
|
Takashi Iwai |
9e1dde |
|
|
Takashi Iwai |
9e1dde |
#include <linux/bitfield.h>
|
|
Takashi Iwai |
9e1dde |
+#include <linux/bitops.h>
|
|
Takashi Iwai |
9e1dde |
#include <linux/delay.h>
|
|
Takashi Iwai |
9e1dde |
#include <linux/device.h>
|
|
Takashi Iwai |
9e1dde |
#include <linux/kernel.h>
|
|
Takashi Iwai |
9e1dde |
@@ -124,7 +125,7 @@ static int adxrs290_get_rate_data(struct iio_dev *indio_dev, const u8 cmd, int *
|
|
Takashi Iwai |
9e1dde |
goto err_unlock;
|
|
Takashi Iwai |
9e1dde |
}
|
|
Takashi Iwai |
9e1dde |
|
|
Takashi Iwai |
9e1dde |
- *val = temp;
|
|
Takashi Iwai |
9e1dde |
+ *val = sign_extend32(temp, 15);
|
|
Takashi Iwai |
9e1dde |
|
|
Takashi Iwai |
9e1dde |
err_unlock:
|
|
Takashi Iwai |
9e1dde |
mutex_unlock(&st->lock);
|
|
Takashi Iwai |
9e1dde |
@@ -146,7 +147,7 @@ static int adxrs290_get_temp_data(struct iio_dev *indio_dev, int *val)
|
|
Takashi Iwai |
9e1dde |
}
|
|
Takashi Iwai |
9e1dde |
|
|
Takashi Iwai |
9e1dde |
/* extract lower 12 bits temperature reading */
|
|
Takashi Iwai |
9e1dde |
- *val = temp & 0x0FFF;
|
|
Takashi Iwai |
9e1dde |
+ *val = sign_extend32(temp, 11);
|
|
Takashi Iwai |
9e1dde |
|
|
Takashi Iwai |
9e1dde |
err_unlock:
|
|
Takashi Iwai |
9e1dde |
mutex_unlock(&st->lock);
|
|
Takashi Iwai |
9e1dde |
--
|
|
Takashi Iwai |
9e1dde |
2.31.1
|
|
Takashi Iwai |
9e1dde |
|