]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
iio: temperature: mlx90632 Relax the compatibility check
authorCrt Mori <cmo@melexis.com>
Thu, 23 May 2019 12:07:22 +0000 (14:07 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 25 Jun 2019 03:35:54 +0000 (11:35 +0800)
commit 389fc70b60f534d679aea9a3f05146040ce20d77 upstream.

Register EE_VERSION contains mixture of calibration information and DSP
version. So far, because calibrations were definite, the driver
compatibility depended on whole contents, but in the newer production
process the calibration part changes. Because of that, value in EE_VERSION
will be changed and to avoid that calibration value is same as DSP version
the MSB in calibration part was fixed to 1.
That means existing calibrations (medical and consumer) will now have
hex values (bits 8 to 15) of 83 and 84 respectively. Driver compatibility
should be based only on DSP version part of the EE_VERSION (bits 0 to 7)
register.

Signed-off-by: Crt Mori <cmo@melexis.com>
Cc: <Stable@vger.kernel.org>
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/iio/temperature/mlx90632.c

index 9851311aa3fdc95795f4bcd75adb12583ade858d..2d54d9cac61dc0d08c0619662484d10f46c2b4d4 100644 (file)
@@ -81,6 +81,8 @@
 /* Magic constants */
 #define MLX90632_ID_MEDICAL    0x0105 /* EEPROM DSPv5 Medical device id */
 #define MLX90632_ID_CONSUMER   0x0205 /* EEPROM DSPv5 Consumer device id */
+#define MLX90632_DSP_VERSION   5 /* DSP version */
+#define MLX90632_DSP_MASK      GENMASK(7, 0) /* DSP version in EE_VERSION */
 #define MLX90632_RESET_CMD     0x0006 /* Reset sensor (address or global) */
 #define MLX90632_REF_12                12LL /**< ResCtrlRef value of Ch 1 or Ch 2 */
 #define MLX90632_REF_3         12LL /**< ResCtrlRef value of Channel 3 */
@@ -666,10 +668,13 @@ static int mlx90632_probe(struct i2c_client *client,
        } else if (read == MLX90632_ID_CONSUMER) {
                dev_dbg(&client->dev,
                        "Detected Consumer EEPROM calibration %x\n", read);
+       } else if ((read & MLX90632_DSP_MASK) == MLX90632_DSP_VERSION) {
+               dev_dbg(&client->dev,
+                       "Detected Unknown EEPROM calibration %x\n", read);
        } else {
                dev_err(&client->dev,
-                       "EEPROM version mismatch %x (expected %x or %x)\n",
-                       read, MLX90632_ID_CONSUMER, MLX90632_ID_MEDICAL);
+                       "Wrong DSP version %x (expected %x)\n",
+                       read, MLX90632_DSP_VERSION);
                return -EPROTONOSUPPORT;
        }