Commit 7af9648f authored by Sachin Kamat's avatar Sachin Kamat Committed by Jonathan Cameron

staging: iio: adt7316: Use devm_* APIs

devm_* APIs are device managed and make code simpler.
Signed-off-by: default avatarSachin Kamat <sachin.kamat@linaro.org>
Signed-off-by: default avatarJonathan Cameron <jic23@kernel.org>
parent 7d456e4e
...@@ -2106,11 +2106,9 @@ int adt7316_probe(struct device *dev, struct adt7316_bus *bus, ...@@ -2106,11 +2106,9 @@ int adt7316_probe(struct device *dev, struct adt7316_bus *bus,
unsigned short *adt7316_platform_data = dev->platform_data; unsigned short *adt7316_platform_data = dev->platform_data;
int ret = 0; int ret = 0;
indio_dev = iio_device_alloc(sizeof(*chip)); indio_dev = devm_iio_device_alloc(dev, sizeof(*chip));
if (indio_dev == NULL) { if (!indio_dev)
ret = -ENOMEM; return -ENOMEM;
goto error_ret;
}
chip = iio_priv(indio_dev); chip = iio_priv(indio_dev);
/* this is only used for device removal purposes */ /* this is only used for device removal purposes */
dev_set_drvdata(dev, indio_dev); dev_set_drvdata(dev, indio_dev);
...@@ -2146,58 +2144,44 @@ int adt7316_probe(struct device *dev, struct adt7316_bus *bus, ...@@ -2146,58 +2144,44 @@ int adt7316_probe(struct device *dev, struct adt7316_bus *bus,
if (adt7316_platform_data[0]) if (adt7316_platform_data[0])
chip->bus.irq_flags = adt7316_platform_data[0]; chip->bus.irq_flags = adt7316_platform_data[0];
ret = request_threaded_irq(chip->bus.irq, ret = devm_request_threaded_irq(dev, chip->bus.irq,
NULL, NULL,
&adt7316_event_handler, &adt7316_event_handler,
chip->bus.irq_flags | IRQF_ONESHOT, chip->bus.irq_flags |
indio_dev->name, IRQF_ONESHOT,
indio_dev); indio_dev->name,
indio_dev);
if (ret) if (ret)
goto error_free_dev; return ret;
if (chip->bus.irq_flags & IRQF_TRIGGER_HIGH) if (chip->bus.irq_flags & IRQF_TRIGGER_HIGH)
chip->config1 |= ADT7316_INT_POLARITY; chip->config1 |= ADT7316_INT_POLARITY;
} }
ret = chip->bus.write(chip->bus.client, ADT7316_CONFIG1, chip->config1); ret = chip->bus.write(chip->bus.client, ADT7316_CONFIG1, chip->config1);
if (ret) { if (ret)
ret = -EIO; return -EIO;
goto error_unreg_irq;
}
ret = chip->bus.write(chip->bus.client, ADT7316_CONFIG3, chip->config3); ret = chip->bus.write(chip->bus.client, ADT7316_CONFIG3, chip->config3);
if (ret) { if (ret)
ret = -EIO; return -EIO;
goto error_unreg_irq;
}
ret = iio_device_register(indio_dev); ret = iio_device_register(indio_dev);
if (ret) if (ret)
goto error_unreg_irq; return ret;
dev_info(dev, "%s temperature sensor, ADC and DAC registered.\n", dev_info(dev, "%s temperature sensor, ADC and DAC registered.\n",
indio_dev->name); indio_dev->name);
return 0; return 0;
error_unreg_irq:
free_irq(chip->bus.irq, indio_dev);
error_free_dev:
iio_device_free(indio_dev);
error_ret:
return ret;
} }
EXPORT_SYMBOL(adt7316_probe); EXPORT_SYMBOL(adt7316_probe);
int adt7316_remove(struct device *dev) int adt7316_remove(struct device *dev)
{ {
struct iio_dev *indio_dev = dev_get_drvdata(dev); struct iio_dev *indio_dev = dev_get_drvdata(dev);
struct adt7316_chip_info *chip = iio_priv(indio_dev);
iio_device_unregister(indio_dev); iio_device_unregister(indio_dev);
if (chip->bus.irq)
free_irq(chip->bus.irq, indio_dev);
iio_device_free(indio_dev);
return 0; return 0;
} }
......
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