Commit 4e34025b authored by Dmitry Torokhov's avatar Dmitry Torokhov

Input: ad7879 - return plain error code from ad7879_probe()

With the switch to devm, there is no need for ad7879_probe() to return the
touchscreen structure, we can use plain error code. This also fixes issue
introduced with devm concersion, where we returned 0 on success (which
worked OK since IS_ERR(0) would not trigger, but was not correct
regardless).

Fixes: 381f688eee3d ("Input: ad7879 - use more devm interfaces")
Acked-by: default avatarMichael Hennerich <michael.hennerich@analog.com>
Signed-off-by: default avatarDmitry Torokhov <dmitry.torokhov@gmail.com>
parent af160c54
...@@ -27,7 +27,6 @@ static const struct regmap_config ad7879_i2c_regmap_config = { ...@@ -27,7 +27,6 @@ static const struct regmap_config ad7879_i2c_regmap_config = {
static int ad7879_i2c_probe(struct i2c_client *client, static int ad7879_i2c_probe(struct i2c_client *client,
const struct i2c_device_id *id) const struct i2c_device_id *id)
{ {
struct ad7879 *ts;
struct regmap *regmap; struct regmap *regmap;
if (!i2c_check_functionality(client->adapter, if (!i2c_check_functionality(client->adapter,
...@@ -40,12 +39,8 @@ static int ad7879_i2c_probe(struct i2c_client *client, ...@@ -40,12 +39,8 @@ static int ad7879_i2c_probe(struct i2c_client *client,
if (IS_ERR(regmap)) if (IS_ERR(regmap))
return PTR_ERR(regmap); return PTR_ERR(regmap);
ts = ad7879_probe(&client->dev, regmap, client->irq, return ad7879_probe(&client->dev, regmap, client->irq,
BUS_I2C, AD7879_DEVID); BUS_I2C, AD7879_DEVID);
if (IS_ERR(ts))
return PTR_ERR(ts);
return 0;
} }
static const struct i2c_device_id ad7879_id[] = { static const struct i2c_device_id ad7879_id[] = {
......
...@@ -32,7 +32,6 @@ static const struct regmap_config ad7879_spi_regmap_config = { ...@@ -32,7 +32,6 @@ static const struct regmap_config ad7879_spi_regmap_config = {
static int ad7879_spi_probe(struct spi_device *spi) static int ad7879_spi_probe(struct spi_device *spi)
{ {
struct ad7879 *ts;
struct regmap *regmap; struct regmap *regmap;
/* don't exceed max specified SPI CLK frequency */ /* don't exceed max specified SPI CLK frequency */
...@@ -45,11 +44,7 @@ static int ad7879_spi_probe(struct spi_device *spi) ...@@ -45,11 +44,7 @@ static int ad7879_spi_probe(struct spi_device *spi)
if (IS_ERR(regmap)) if (IS_ERR(regmap))
return PTR_ERR(regmap); return PTR_ERR(regmap);
ts = ad7879_probe(&spi->dev, regmap, spi->irq, BUS_SPI, AD7879_DEVID); return ad7879_probe(&spi->dev, regmap, spi->irq, BUS_SPI, AD7879_DEVID);
if (IS_ERR(ts))
return PTR_ERR(ts);
return 0;
} }
#ifdef CONFIG_OF #ifdef CONFIG_OF
......
...@@ -531,7 +531,7 @@ static void ad7879_cleanup_sysfs(void *_ts) ...@@ -531,7 +531,7 @@ static void ad7879_cleanup_sysfs(void *_ts)
sysfs_remove_group(&ts->dev->kobj, &ad7879_attr_group); sysfs_remove_group(&ts->dev->kobj, &ad7879_attr_group);
} }
struct ad7879 *ad7879_probe(struct device *dev, struct regmap *regmap, int ad7879_probe(struct device *dev, struct regmap *regmap,
int irq, u16 bustype, u8 devid) int irq, u16 bustype, u8 devid)
{ {
struct ad7879_platform_data *pdata = dev_get_platdata(dev); struct ad7879_platform_data *pdata = dev_get_platdata(dev);
...@@ -542,12 +542,12 @@ struct ad7879 *ad7879_probe(struct device *dev, struct regmap *regmap, ...@@ -542,12 +542,12 @@ struct ad7879 *ad7879_probe(struct device *dev, struct regmap *regmap,
if (irq <= 0) { if (irq <= 0) {
dev_err(dev, "No IRQ specified\n"); dev_err(dev, "No IRQ specified\n");
return ERR_PTR(-EINVAL); return -EINVAL;
} }
ts = devm_kzalloc(dev, sizeof(*ts), GFP_KERNEL); ts = devm_kzalloc(dev, sizeof(*ts), GFP_KERNEL);
if (!ts) if (!ts)
return ERR_PTR(-ENOMEM); return -ENOMEM;
if (pdata) { if (pdata) {
/* Platform data use swapped axis (backward compatibility) */ /* Platform data use swapped axis (backward compatibility) */
...@@ -564,13 +564,13 @@ struct ad7879 *ad7879_probe(struct device *dev, struct regmap *regmap, ...@@ -564,13 +564,13 @@ struct ad7879 *ad7879_probe(struct device *dev, struct regmap *regmap,
ad7879_parse_dt(dev, ts); ad7879_parse_dt(dev, ts);
} else { } else {
dev_err(dev, "No platform data\n"); dev_err(dev, "No platform data\n");
return ERR_PTR(-EINVAL); return -EINVAL;
} }
input_dev = devm_input_allocate_device(dev); input_dev = devm_input_allocate_device(dev);
if (!input_dev) { if (!input_dev) {
dev_err(dev, "Failed to allocate input device\n"); dev_err(dev, "Failed to allocate input device\n");
return ERR_PTR(-ENOMEM); return -ENOMEM;
} }
ts->dev = dev; ts->dev = dev;
...@@ -618,14 +618,14 @@ struct ad7879 *ad7879_probe(struct device *dev, struct regmap *regmap, ...@@ -618,14 +618,14 @@ struct ad7879 *ad7879_probe(struct device *dev, struct regmap *regmap,
touchscreen_parse_properties(input_dev, false, NULL); touchscreen_parse_properties(input_dev, false, NULL);
if (!input_abs_get_max(input_dev, ABS_PRESSURE)) { if (!input_abs_get_max(input_dev, ABS_PRESSURE)) {
dev_err(dev, "Touchscreen pressure is not specified\n"); dev_err(dev, "Touchscreen pressure is not specified\n");
return ERR_PTR(-EINVAL); return -EINVAL;
} }
} }
err = ad7879_write(ts, AD7879_REG_CTRL2, AD7879_RESET); err = ad7879_write(ts, AD7879_REG_CTRL2, AD7879_RESET);
if (err < 0) { if (err < 0) {
dev_err(dev, "Failed to write %s\n", input_dev->name); dev_err(dev, "Failed to write %s\n", input_dev->name);
return ERR_PTR(err); return err;
} }
revid = ad7879_read(ts, AD7879_REG_REVID); revid = ad7879_read(ts, AD7879_REG_REVID);
...@@ -634,7 +634,7 @@ struct ad7879 *ad7879_probe(struct device *dev, struct regmap *regmap, ...@@ -634,7 +634,7 @@ struct ad7879 *ad7879_probe(struct device *dev, struct regmap *regmap,
if (input_dev->id.product != devid) { if (input_dev->id.product != devid) {
dev_err(dev, "Failed to probe %s (%x vs %x)\n", dev_err(dev, "Failed to probe %s (%x vs %x)\n",
input_dev->name, devid, revid); input_dev->name, devid, revid);
return ERR_PTR(-ENODEV); return -ENODEV;
} }
ts->cmd_crtl3 = AD7879_YPLUS_BIT | ts->cmd_crtl3 = AD7879_YPLUS_BIT |
...@@ -659,26 +659,26 @@ struct ad7879 *ad7879_probe(struct device *dev, struct regmap *regmap, ...@@ -659,26 +659,26 @@ struct ad7879 *ad7879_probe(struct device *dev, struct regmap *regmap,
dev_name(dev), ts); dev_name(dev), ts);
if (err) { if (err) {
dev_err(dev, "Failed to request IRQ: %d\n", err); dev_err(dev, "Failed to request IRQ: %d\n", err);
return ERR_PTR(err); return err;
} }
__ad7879_disable(ts); __ad7879_disable(ts);
err = sysfs_create_group(&dev->kobj, &ad7879_attr_group); err = sysfs_create_group(&dev->kobj, &ad7879_attr_group);
if (err) if (err)
return ERR_PTR(err); return err;
err = devm_add_action_or_reset(dev, ad7879_cleanup_sysfs, ts); err = devm_add_action_or_reset(dev, ad7879_cleanup_sysfs, ts);
if (err) if (err)
return ERR_PTR(err); return err;
err = ad7879_gpio_add(ts, pdata); err = ad7879_gpio_add(ts, pdata);
if (err) if (err)
return ERR_PTR(err); return err;
err = input_register_device(input_dev); err = input_register_device(input_dev);
if (err) if (err)
return ERR_PTR(err); return err;
dev_set_drvdata(dev, ts); dev_set_drvdata(dev, ts);
......
...@@ -11,13 +11,12 @@ ...@@ -11,13 +11,12 @@
#include <linux/types.h> #include <linux/types.h>
struct ad7879;
struct device; struct device;
struct regmap; struct regmap;
extern const struct dev_pm_ops ad7879_pm_ops; extern const struct dev_pm_ops ad7879_pm_ops;
struct ad7879 *ad7879_probe(struct device *dev, struct regmap *regmap, int ad7879_probe(struct device *dev, struct regmap *regmap,
int irq, u16 bustype, u8 devid); int irq, u16 bustype, u8 devid);
#endif #endif
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