iio: accel: kx022a: Support ICs with different G-ranges
authorMatti Vaittinen <mazziesaccount@gmail.com>
Thu, 28 Nov 2024 09:02:15 +0000 (11:02 +0200)
committerJonathan Cameron <Jonathan.Cameron@huawei.com>
Sat, 7 Dec 2024 17:49:11 +0000 (17:49 +0000)
The register interface of the ROHM KX134ACR-LBZ accelerometer is almost
identical to the KX132ACR-LBZ. Main difference between these
accelerometers is that the KX134ACR-LBZ supports G-ranges +/- 8, 16,
32 and 64G. All the other sensors supported by the kx022a driver can
measure +/- 2, 4, 8 and 16G.

Prepare supporting the KX134ACR-LBZ with different G-ranges by storing
a pointer to the scale tables in IC specific structure.

Signed-off-by: Matti Vaittinen <mazziesaccount@gmail.com>
Link: https://patch.msgid.link/fc667b1495adf4e3f29ecbb336495c1f18b47e61.1732783834.git.mazziesaccount@gmail.com
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
drivers/iio/accel/kionix-kx022a.c
drivers/iio/accel/kionix-kx022a.h

index 9cc6035b5f40846f0199fa6eede21a51bb3628d6..06859483cb132b2866050590375ebef3637a0275 100644 (file)
@@ -413,6 +413,8 @@ static int kx022a_read_avail(struct iio_dev *indio_dev,
                             const int **vals, int *type, int *length,
                             long mask)
 {
+       struct kx022a_data *data = iio_priv(indio_dev);
+
        switch (mask) {
        case IIO_CHAN_INFO_SAMP_FREQ:
                *vals = (const int *)kx022a_accel_samp_freq_table;
@@ -421,9 +423,8 @@ static int kx022a_read_avail(struct iio_dev *indio_dev,
                *type = IIO_VAL_INT_PLUS_MICRO;
                return IIO_AVAIL_LIST;
        case IIO_CHAN_INFO_SCALE:
-               *vals = (const int *)kx022a_scale_table;
-               *length = ARRAY_SIZE(kx022a_scale_table) *
-                         ARRAY_SIZE(kx022a_scale_table[0]);
+               *vals = (const int *)data->chip_info->scale_table;
+               *length = data->chip_info->scale_table_size;
                *type = IIO_VAL_INT_PLUS_NANO;
                return IIO_AVAIL_LIST;
        default:
@@ -439,14 +440,14 @@ static void kx022a_reg2freq(unsigned int val,  int *val1, int *val2)
        *val2 = kx022a_accel_samp_freq_table[val & KX022A_MASK_ODR][1];
 }
 
-static void kx022a_reg2scale(unsigned int val, unsigned int *val1,
-                            unsigned int *val2)
+static void kx022a_reg2scale(struct kx022a_data *data, unsigned int val,
+                            unsigned int *val1, unsigned int *val2)
 {
        val &= KX022A_MASK_GSEL;
        val >>= KX022A_GSEL_SHIFT;
 
-       *val1 = kx022a_scale_table[val][0];
-       *val2 = kx022a_scale_table[val][1];
+       *val1 = data->chip_info->scale_table[val][0];
+       *val2 = data->chip_info->scale_table[val][1];
 }
 
 static int __kx022a_turn_on_off(struct kx022a_data *data, bool on)
@@ -544,11 +545,11 @@ static int kx022a_write_raw(struct iio_dev *idev,
                kx022a_turn_on_unlock(data);
                break;
        case IIO_CHAN_INFO_SCALE:
-               n = ARRAY_SIZE(kx022a_scale_table);
+               n = data->chip_info->scale_table_size / 2;
 
                while (n-- > 0)
-                       if (val == kx022a_scale_table[n][0] &&
-                           val2 == kx022a_scale_table[n][1])
+                       if (val == data->chip_info->scale_table[n][0] &&
+                           val2 == data->chip_info->scale_table[n][1])
                                break;
                if (n < 0) {
                        ret = -EINVAL;
@@ -643,7 +644,7 @@ static int kx022a_read_raw(struct iio_dev *idev,
                if (ret < 0)
                        return ret;
 
-               kx022a_reg2scale(regval, val, val2);
+               kx022a_reg2scale(data, regval, val, val2);
 
                return IIO_VAL_INT_PLUS_NANO;
        }
@@ -1148,6 +1149,9 @@ const struct kx022a_chip_info kx022a_chip_info = {
        .regmap_config                  = &kx022a_regmap_config,
        .channels                       = kx022a_channels,
        .num_channels                   = ARRAY_SIZE(kx022a_channels),
+       .scale_table                    = kx022a_scale_table,
+       .scale_table_size               = ARRAY_SIZE(kx022a_scale_table) *
+                                         ARRAY_SIZE(kx022a_scale_table[0]),
        .fifo_length                    = KX022A_FIFO_LENGTH,
        .who                            = KX022A_REG_WHO,
        .id                             = KX022A_ID,
@@ -1173,6 +1177,9 @@ const struct kx022a_chip_info kx132_chip_info = {
        .regmap_config            = &kx132_regmap_config,
        .channels                 = kx132_channels,
        .num_channels             = ARRAY_SIZE(kx132_channels),
+       .scale_table                    = kx022a_scale_table,
+       .scale_table_size               = ARRAY_SIZE(kx022a_scale_table) *
+                                         ARRAY_SIZE(kx022a_scale_table[0]),
        .fifo_length              = KX132_FIFO_LENGTH,
        .who                      = KX132_REG_WHO,
        .id                       = KX132_ID,
@@ -1206,6 +1213,9 @@ const struct kx022a_chip_info kx132acr_chip_info = {
        .regmap_config                  = &kx022a_regmap_config,
        .channels                       = kx022a_channels,
        .num_channels                   = ARRAY_SIZE(kx022a_channels),
+       .scale_table                    = kx022a_scale_table,
+       .scale_table_size               = ARRAY_SIZE(kx022a_scale_table) *
+                                         ARRAY_SIZE(kx022a_scale_table[0]),
        .fifo_length                    = KX022A_FIFO_LENGTH,
        .who                            = KX022A_REG_WHO,
        .id                             = KX132ACR_LBZ_ID,
index 7060438ad88c8282a2cbe0ace41f7118f7f856dc..36e9d9de8c134e7d5479d6ca3cbf82b61417bc94 100644 (file)
@@ -161,6 +161,8 @@ struct kx022a_data;
 struct kx022a_chip_info {
        const char *name;
        const struct regmap_config *regmap_config;
+       const int (*scale_table)[2];
+       const int scale_table_size;
        const struct iio_chan_spec *channels;
        unsigned int num_channels;
        unsigned int fifo_length;