aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/iio
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/iio')
-rw-r--r--drivers/iio/adc/ad799x.c15
1 files changed, 6 insertions, 9 deletions
diff --git a/drivers/iio/adc/ad799x.c b/drivers/iio/adc/ad799x.c
index 16a8b14b1921..39b4cb48d738 100644
--- a/drivers/iio/adc/ad799x.c
+++ b/drivers/iio/adc/ad799x.c
@@ -717,7 +717,7 @@ static int ad799x_probe(struct i2c_client *client,
717 ret = iio_triggered_buffer_setup(indio_dev, NULL, 717 ret = iio_triggered_buffer_setup(indio_dev, NULL,
718 &ad799x_trigger_handler, NULL); 718 &ad799x_trigger_handler, NULL);
719 if (ret) 719 if (ret)
720 goto error_disable_reg; 720 goto error_disable_vref;
721 721
722 if (client->irq > 0) { 722 if (client->irq > 0) {
723 ret = devm_request_threaded_irq(&client->dev, 723 ret = devm_request_threaded_irq(&client->dev,
@@ -739,11 +739,10 @@ static int ad799x_probe(struct i2c_client *client,
739 739
740error_cleanup_ring: 740error_cleanup_ring:
741 iio_triggered_buffer_cleanup(indio_dev); 741 iio_triggered_buffer_cleanup(indio_dev);
742error_disable_vref:
743 regulator_disable(st->vref);
742error_disable_reg: 744error_disable_reg:
743 if (!IS_ERR(st->vref)) 745 regulator_disable(st->reg);
744 regulator_disable(st->vref);
745 if (!IS_ERR(st->reg))
746 regulator_disable(st->reg);
747 746
748 return ret; 747 return ret;
749} 748}
@@ -756,10 +755,8 @@ static int ad799x_remove(struct i2c_client *client)
756 iio_device_unregister(indio_dev); 755 iio_device_unregister(indio_dev);
757 756
758 iio_triggered_buffer_cleanup(indio_dev); 757 iio_triggered_buffer_cleanup(indio_dev);
759 if (!IS_ERR(st->vref)) 758 regulator_disable(st->vref);
760 regulator_disable(st->vref); 759 regulator_disable(st->reg);
761 if (!IS_ERR(st->reg))
762 regulator_disable(st->reg);
763 kfree(st->rx_buf); 760 kfree(st->rx_buf);
764 761
765 return 0; 762 return 0;