|
@@ -547,7 +547,7 @@ static int bmc150_accel_get_axis(struct bmc150_accel_data *data,
|
|
{
|
|
{
|
|
int ret;
|
|
int ret;
|
|
int axis = chan->scan_index;
|
|
int axis = chan->scan_index;
|
|
- unsigned int raw_val;
|
|
|
|
|
|
+ __le16 raw_val;
|
|
|
|
|
|
mutex_lock(&data->mutex);
|
|
mutex_lock(&data->mutex);
|
|
ret = bmc150_accel_set_power_state(data, true);
|
|
ret = bmc150_accel_set_power_state(data, true);
|
|
@@ -557,14 +557,14 @@ static int bmc150_accel_get_axis(struct bmc150_accel_data *data,
|
|
}
|
|
}
|
|
|
|
|
|
ret = regmap_bulk_read(data->regmap, BMC150_ACCEL_AXIS_TO_REG(axis),
|
|
ret = regmap_bulk_read(data->regmap, BMC150_ACCEL_AXIS_TO_REG(axis),
|
|
- &raw_val, 2);
|
|
|
|
|
|
+ &raw_val, sizeof(raw_val));
|
|
if (ret < 0) {
|
|
if (ret < 0) {
|
|
dev_err(data->dev, "Error reading axis %d\n", axis);
|
|
dev_err(data->dev, "Error reading axis %d\n", axis);
|
|
bmc150_accel_set_power_state(data, false);
|
|
bmc150_accel_set_power_state(data, false);
|
|
mutex_unlock(&data->mutex);
|
|
mutex_unlock(&data->mutex);
|
|
return ret;
|
|
return ret;
|
|
}
|
|
}
|
|
- *val = sign_extend32(raw_val >> chan->scan_type.shift,
|
|
|
|
|
|
+ *val = sign_extend32(le16_to_cpu(raw_val) >> chan->scan_type.shift,
|
|
chan->scan_type.realbits - 1);
|
|
chan->scan_type.realbits - 1);
|
|
ret = bmc150_accel_set_power_state(data, false);
|
|
ret = bmc150_accel_set_power_state(data, false);
|
|
mutex_unlock(&data->mutex);
|
|
mutex_unlock(&data->mutex);
|
|
@@ -988,6 +988,7 @@ static const struct iio_event_spec bmc150_accel_event = {
|
|
.realbits = (bits), \
|
|
.realbits = (bits), \
|
|
.storagebits = 16, \
|
|
.storagebits = 16, \
|
|
.shift = 16 - (bits), \
|
|
.shift = 16 - (bits), \
|
|
|
|
+ .endianness = IIO_LE, \
|
|
}, \
|
|
}, \
|
|
.event_spec = &bmc150_accel_event, \
|
|
.event_spec = &bmc150_accel_event, \
|
|
.num_event_specs = 1 \
|
|
.num_event_specs = 1 \
|