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