aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/iio/pressure
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/iio/pressure')
-rw-r--r--drivers/iio/pressure/st_pressure_core.c1
-rw-r--r--drivers/iio/pressure/st_pressure_i2c.c15
-rw-r--r--drivers/iio/pressure/st_pressure_spi.c15
3 files changed, 8 insertions, 23 deletions
diff --git a/drivers/iio/pressure/st_pressure_core.c b/drivers/iio/pressure/st_pressure_core.c
index 43b3a55e1130..ceebd3c27892 100644
--- a/drivers/iio/pressure/st_pressure_core.c
+++ b/drivers/iio/pressure/st_pressure_core.c
@@ -275,7 +275,6 @@ void st_press_common_remove(struct iio_dev *indio_dev)
275 st_sensors_deallocate_trigger(indio_dev); 275 st_sensors_deallocate_trigger(indio_dev);
276 st_press_deallocate_ring(indio_dev); 276 st_press_deallocate_ring(indio_dev);
277 } 277 }
278 iio_device_free(indio_dev);
279} 278}
280EXPORT_SYMBOL(st_press_common_remove); 279EXPORT_SYMBOL(st_press_common_remove);
281 280
diff --git a/drivers/iio/pressure/st_pressure_i2c.c b/drivers/iio/pressure/st_pressure_i2c.c
index 306599307a96..08aac5e6251d 100644
--- a/drivers/iio/pressure/st_pressure_i2c.c
+++ b/drivers/iio/pressure/st_pressure_i2c.c
@@ -25,11 +25,9 @@ static int st_press_i2c_probe(struct i2c_client *client,
25 struct st_sensor_data *pdata; 25 struct st_sensor_data *pdata;
26 int err; 26 int err;
27 27
28 indio_dev = iio_device_alloc(sizeof(*pdata)); 28 indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*pdata));
29 if (indio_dev == NULL) { 29 if (!indio_dev)
30 err = -ENOMEM; 30 return -ENOMEM;
31 goto iio_device_alloc_error;
32 }
33 31
34 pdata = iio_priv(indio_dev); 32 pdata = iio_priv(indio_dev);
35 pdata->dev = &client->dev; 33 pdata->dev = &client->dev;
@@ -38,14 +36,9 @@ static int st_press_i2c_probe(struct i2c_client *client,
38 36
39 err = st_press_common_probe(indio_dev, client->dev.platform_data); 37 err = st_press_common_probe(indio_dev, client->dev.platform_data);
40 if (err < 0) 38 if (err < 0)
41 goto st_press_common_probe_error; 39 return err;
42 40
43 return 0; 41 return 0;
44
45st_press_common_probe_error:
46 iio_device_free(indio_dev);
47iio_device_alloc_error:
48 return err;
49} 42}
50 43
51static int st_press_i2c_remove(struct i2c_client *client) 44static int st_press_i2c_remove(struct i2c_client *client)
diff --git a/drivers/iio/pressure/st_pressure_spi.c b/drivers/iio/pressure/st_pressure_spi.c
index b2aded6d2108..399a29b6017b 100644
--- a/drivers/iio/pressure/st_pressure_spi.c
+++ b/drivers/iio/pressure/st_pressure_spi.c
@@ -24,11 +24,9 @@ static int st_press_spi_probe(struct spi_device *spi)
24 struct st_sensor_data *pdata; 24 struct st_sensor_data *pdata;
25 int err; 25 int err;
26 26
27 indio_dev = iio_device_alloc(sizeof(*pdata)); 27 indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*pdata));
28 if (indio_dev == NULL) { 28 if (indio_dev == NULL)
29 err = -ENOMEM; 29 return -ENOMEM;
30 goto iio_device_alloc_error;
31 }
32 30
33 pdata = iio_priv(indio_dev); 31 pdata = iio_priv(indio_dev);
34 pdata->dev = &spi->dev; 32 pdata->dev = &spi->dev;
@@ -37,14 +35,9 @@ static int st_press_spi_probe(struct spi_device *spi)
37 35
38 err = st_press_common_probe(indio_dev, spi->dev.platform_data); 36 err = st_press_common_probe(indio_dev, spi->dev.platform_data);
39 if (err < 0) 37 if (err < 0)
40 goto st_press_common_probe_error; 38 return err;
41 39
42 return 0; 40 return 0;
43
44st_press_common_probe_error:
45 iio_device_free(indio_dev);
46iio_device_alloc_error:
47 return err;
48} 41}
49 42
50static int st_press_spi_remove(struct spi_device *spi) 43static int st_press_spi_remove(struct spi_device *spi)