iio:common:st_sensors: add st_sensors_get_settings_index() helper function
authorDenis Ciocca <denis.ciocca@st.com>
Thu, 18 Jul 2019 22:53:43 +0000 (15:53 -0700)
committerJonathan Cameron <Jonathan.Cameron@huawei.com>
Sat, 27 Jul 2019 21:52:04 +0000 (22:52 +0100)
Extract from st_sensors_check_device_support() function the code that
is used to get the specific settings for a device. This will be used
as generic extractor by each ST driver.

Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
drivers/iio/common/st_sensors/st_sensors_core.c
include/linux/iio/common/st_sensors.h

index 8b22dc24148219fd4d7e0afdeb27afa8eeeb4db4..3610ca9eaa876ad17eb5c992fee085fbd9c5babc 100644 (file)
@@ -633,28 +633,47 @@ static int st_sensors_init_interface_mode(struct iio_dev *indio_dev,
        return 0;
 }
 
+/*
+ * st_sensors_get_settings_index() - get index of the sensor settings for a
+ *                                  specific device from list of settings
+ * @name: device name buffer reference.
+ * @list: sensor settings list.
+ * @list_length: length of sensor settings list.
+ *
+ * Return: non negative number on success (valid index),
+ *        negative error code otherwise.
+ */
+int st_sensors_get_settings_index(const char *name,
+                                 const struct st_sensor_settings *list,
+                                 const int list_length)
+{
+       int i, n;
+
+       for (i = 0; i < list_length; i++) {
+               for (n = 0; n < ST_SENSORS_MAX_4WAI; n++) {
+                       if (strcmp(name, list[i].sensors_supported[n]) == 0)
+                               return i;
+               }
+       }
+
+       return -ENODEV;
+}
+EXPORT_SYMBOL(st_sensors_get_settings_index);
+
 int st_sensors_check_device_support(struct iio_dev *indio_dev,
                        int num_sensors_list,
                        const struct st_sensor_settings *sensor_settings)
 {
-       int i, n, err = 0;
-       u8 wai;
        struct st_sensor_data *sdata = iio_priv(indio_dev);
+       int i, err;
+       u8 wai;
 
-       for (i = 0; i < num_sensors_list; i++) {
-               for (n = 0; n < ST_SENSORS_MAX_4WAI; n++) {
-                       if (strcmp(indio_dev->name,
-                               sensor_settings[i].sensors_supported[n]) == 0) {
-                               break;
-                       }
-               }
-               if (n < ST_SENSORS_MAX_4WAI)
-                       break;
-       }
-       if (i == num_sensors_list) {
+       i = st_sensors_get_settings_index(indio_dev->name,
+                                         sensor_settings, num_sensors_list);
+       if (i < 0) {
                dev_err(&indio_dev->dev, "device name %s not recognized.\n",
-                                                       indio_dev->name);
-               return -ENODEV;
+                       indio_dev->name);
+               return i;
        }
 
        err = st_sensors_init_interface_mode(indio_dev, &sensor_settings[i]);
index 2948ac99e2dacc992fd4f0cde3cd04a2cc66ce04..17fbf3e9b01329f0fea9ee2c7bdd3958c6fab095 100644 (file)
@@ -334,6 +334,10 @@ int st_sensors_set_fullscale_by_gain(struct iio_dev *indio_dev, int scale);
 int st_sensors_read_info_raw(struct iio_dev *indio_dev,
                                struct iio_chan_spec const *ch, int *val);
 
+int st_sensors_get_settings_index(const char *name,
+                                 const struct st_sensor_settings *list,
+                                 const int list_length);
+
 int st_sensors_check_device_support(struct iio_dev *indio_dev,
        int num_sensors_list, const struct st_sensor_settings *sensor_settings);