Skip to content

Commit 78ad686

Browse files
NXP-CarlosSongjic23
authored andcommitted
iio: imu: fxos8700: fix incorrect ODR mode readback
The absence of a correct offset leads an incorrect ODR mode readback after use a hexadecimal number to mark the value from FXOS8700_CTRL_REG1. Get ODR mode by field mask and FIELD_GET clearly and conveniently. And attach other additional fix for keeping the original code logic and a good readability. Fixes: 84e5ddd ("iio: imu: Add support for the FXOS8700 IMU") Signed-off-by: Carlos Song <[email protected]> Link: https://lore.kernel.org/r/[email protected] Cc: <[email protected]> Signed-off-by: Jonathan Cameron <[email protected]>
1 parent ee3c5b6 commit 78ad686

File tree

1 file changed

+6
-6
lines changed

1 file changed

+6
-6
lines changed

drivers/iio/imu/fxos8700_core.c

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,7 @@
1010
#include <linux/regmap.h>
1111
#include <linux/acpi.h>
1212
#include <linux/bitops.h>
13+
#include <linux/bitfield.h>
1314

1415
#include <linux/iio/iio.h>
1516
#include <linux/iio/sysfs.h>
@@ -144,9 +145,9 @@
144145
#define FXOS8700_NVM_DATA_BNK0 0xa7
145146

146147
/* Bit definitions for FXOS8700_CTRL_REG1 */
147-
#define FXOS8700_CTRL_ODR_MSK 0x38
148148
#define FXOS8700_CTRL_ODR_MAX 0x00
149149
#define FXOS8700_CTRL_ODR_MIN GENMASK(4, 3)
150+
#define FXOS8700_CTRL_ODR_MSK GENMASK(5, 3)
150151

151152
/* Bit definitions for FXOS8700_M_CTRL_REG1 */
152153
#define FXOS8700_HMS_MASK GENMASK(1, 0)
@@ -508,10 +509,9 @@ static int fxos8700_set_odr(struct fxos8700_data *data, enum fxos8700_sensor t,
508509
if (i >= odr_num)
509510
return -EINVAL;
510511

511-
return regmap_update_bits(data->regmap,
512-
FXOS8700_CTRL_REG1,
513-
FXOS8700_CTRL_ODR_MSK + FXOS8700_ACTIVE,
514-
fxos8700_odr[i].bits << 3 | active_mode);
512+
val &= ~FXOS8700_CTRL_ODR_MSK;
513+
val |= FIELD_PREP(FXOS8700_CTRL_ODR_MSK, fxos8700_odr[i].bits) | FXOS8700_ACTIVE;
514+
return regmap_write(data->regmap, FXOS8700_CTRL_REG1, val);
515515
}
516516

517517
static int fxos8700_get_odr(struct fxos8700_data *data, enum fxos8700_sensor t,
@@ -524,7 +524,7 @@ static int fxos8700_get_odr(struct fxos8700_data *data, enum fxos8700_sensor t,
524524
if (ret)
525525
return ret;
526526

527-
val &= FXOS8700_CTRL_ODR_MSK;
527+
val = FIELD_GET(FXOS8700_CTRL_ODR_MSK, val);
528528

529529
for (i = 0; i < odr_num; i++)
530530
if (val == fxos8700_odr[i].bits)

0 commit comments

Comments
 (0)