Commit ebf30bed authored by Jonathan Cameron's avatar Jonathan Cameron

staging: iio: cdc: ad7746: Use explicit be24 handling.

Chance from fiddly local implementation of be24 to cpu endian conversion
by reading into a 3 byte buffer and using get_unaligned_be24()
Signed-off-by: default avatarJonathan Cameron <Jonathan.Cameron@huawei.com>
Reviewed-by: default avatarAndy Shevchenko <andy.shevchenko@gmail.com>
Link: https://lore.kernel.org/r/20220626122938.582107-4-jic23@kernel.org
parent 1efc4103
...@@ -15,6 +15,8 @@ ...@@ -15,6 +15,8 @@
#include <linux/stat.h> #include <linux/stat.h>
#include <linux/sysfs.h> #include <linux/sysfs.h>
#include <asm/unaligned.h>
#include <linux/iio/iio.h> #include <linux/iio/iio.h>
#include <linux/iio/sysfs.h> #include <linux/iio/sysfs.h>
...@@ -95,10 +97,7 @@ struct ad7746_chip_info { ...@@ -95,10 +97,7 @@ struct ad7746_chip_info {
u8 capdac[2][2]; u8 capdac[2][2];
s8 capdac_set; s8 capdac_set;
union { u8 data[3] ____cacheline_aligned;
__be32 d32;
u8 d8[4];
} data ____cacheline_aligned;
}; };
enum ad7746_chan { enum ad7746_chan {
...@@ -546,13 +545,14 @@ static int ad7746_read_raw(struct iio_dev *indio_dev, ...@@ -546,13 +545,14 @@ static int ad7746_read_raw(struct iio_dev *indio_dev,
/* Now read the actual register */ /* Now read the actual register */
ret = i2c_smbus_read_i2c_block_data(chip->client, ret = i2c_smbus_read_i2c_block_data(chip->client,
chan->address >> 8, 3, chan->address >> 8,
&chip->data.d8[1]); sizeof(chip->data),
chip->data);
if (ret < 0) if (ret < 0)
goto out; goto out;
*val = (be32_to_cpu(chip->data.d32) & 0xFFFFFF) - 0x800000; *val = get_unaligned_be24(chip->data) - 0x800000;
switch (chan->type) { switch (chan->type) {
case IIO_TEMP: case IIO_TEMP:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment