Commit a917af2a authored by Daniel Campello's avatar Daniel Campello Committed by Jonathan Cameron

iio: sx9310: Simplify error return handling

Checks for non-zero return values to signal error conditions.
Signed-off-by: default avatarDaniel Campello <campello@chromium.org>
Reviewed-by: default avatarAndy Shevchenko <andy.shevchenko@gmail.com>
Reviewed-by: default avatarStephen Boyd <swboyd@chromium.org>
Signed-off-by: default avatarJonathan Cameron <Jonathan.Cameron@huawei.com>
parent 124cbc33
...@@ -347,7 +347,7 @@ static int sx9310_read_prox_data(struct sx9310_data *data, ...@@ -347,7 +347,7 @@ static int sx9310_read_prox_data(struct sx9310_data *data,
int ret; int ret;
ret = regmap_write(data->regmap, SX9310_REG_SENSOR_SEL, chan->channel); ret = regmap_write(data->regmap, SX9310_REG_SENSOR_SEL, chan->channel);
if (ret < 0) if (ret)
return ret; return ret;
return regmap_bulk_read(data->regmap, chan->address, val, sizeof(*val)); return regmap_bulk_read(data->regmap, chan->address, val, sizeof(*val));
...@@ -363,7 +363,7 @@ static int sx9310_wait_for_sample(struct sx9310_data *data) ...@@ -363,7 +363,7 @@ static int sx9310_wait_for_sample(struct sx9310_data *data)
unsigned int val; unsigned int val;
ret = regmap_read(data->regmap, SX9310_REG_PROX_CTRL0, &val); ret = regmap_read(data->regmap, SX9310_REG_PROX_CTRL0, &val);
if (ret < 0) if (ret)
return ret; return ret;
val = FIELD_GET(SX9310_REG_PROX_CTRL0_SCANPERIOD_MASK, val); val = FIELD_GET(SX9310_REG_PROX_CTRL0_SCANPERIOD_MASK, val);
...@@ -376,17 +376,17 @@ static int sx9310_wait_for_sample(struct sx9310_data *data) ...@@ -376,17 +376,17 @@ static int sx9310_wait_for_sample(struct sx9310_data *data)
static int sx9310_read_proximity(struct sx9310_data *data, static int sx9310_read_proximity(struct sx9310_data *data,
const struct iio_chan_spec *chan, int *val) const struct iio_chan_spec *chan, int *val)
{ {
int ret = 0; int ret;
__be16 rawval; __be16 rawval;
mutex_lock(&data->mutex); mutex_lock(&data->mutex);
ret = sx9310_get_read_channel(data, chan->channel); ret = sx9310_get_read_channel(data, chan->channel);
if (ret < 0) if (ret)
goto out; goto out;
ret = sx9310_enable_irq(data, SX9310_CONVDONE_IRQ); ret = sx9310_enable_irq(data, SX9310_CONVDONE_IRQ);
if (ret < 0) if (ret)
goto out_put_channel; goto out_put_channel;
mutex_unlock(&data->mutex); mutex_unlock(&data->mutex);
...@@ -400,22 +400,22 @@ static int sx9310_read_proximity(struct sx9310_data *data, ...@@ -400,22 +400,22 @@ static int sx9310_read_proximity(struct sx9310_data *data,
mutex_lock(&data->mutex); mutex_lock(&data->mutex);
if (ret < 0) if (ret)
goto out_disable_irq; goto out_disable_irq;
ret = sx9310_read_prox_data(data, chan, &rawval); ret = sx9310_read_prox_data(data, chan, &rawval);
if (ret < 0) if (ret)
goto out_disable_irq; goto out_disable_irq;
*val = sign_extend32(be16_to_cpu(rawval), *val = sign_extend32(be16_to_cpu(rawval),
(chan->address == SX9310_REG_DIFF_MSB ? 11 : 15)); (chan->address == SX9310_REG_DIFF_MSB ? 11 : 15));
ret = sx9310_disable_irq(data, SX9310_CONVDONE_IRQ); ret = sx9310_disable_irq(data, SX9310_CONVDONE_IRQ);
if (ret < 0) if (ret)
goto out_put_channel; goto out_put_channel;
ret = sx9310_put_read_channel(data, chan->channel); ret = sx9310_put_read_channel(data, chan->channel);
if (ret < 0) if (ret)
goto out; goto out;
mutex_unlock(&data->mutex); mutex_unlock(&data->mutex);
...@@ -437,7 +437,7 @@ static int sx9310_read_samp_freq(struct sx9310_data *data, int *val, int *val2) ...@@ -437,7 +437,7 @@ static int sx9310_read_samp_freq(struct sx9310_data *data, int *val, int *val2)
unsigned int regval; unsigned int regval;
int ret = regmap_read(data->regmap, SX9310_REG_PROX_CTRL0, &regval); int ret = regmap_read(data->regmap, SX9310_REG_PROX_CTRL0, &regval);
if (ret < 0) if (ret)
return ret; return ret;
regval = FIELD_GET(SX9310_REG_PROX_CTRL0_SCANPERIOD_MASK, regval); regval = FIELD_GET(SX9310_REG_PROX_CTRL0_SCANPERIOD_MASK, regval);
...@@ -539,7 +539,7 @@ static void sx9310_push_events(struct iio_dev *indio_dev) ...@@ -539,7 +539,7 @@ static void sx9310_push_events(struct iio_dev *indio_dev)
/* Read proximity state on all channels */ /* Read proximity state on all channels */
ret = regmap_read(data->regmap, SX9310_REG_STAT0, &val); ret = regmap_read(data->regmap, SX9310_REG_STAT0, &val);
if (ret < 0) { if (ret) {
dev_err(&data->client->dev, "i2c transfer error in irq\n"); dev_err(&data->client->dev, "i2c transfer error in irq\n");
return; return;
} }
...@@ -573,7 +573,7 @@ static irqreturn_t sx9310_irq_thread_handler(int irq, void *private) ...@@ -573,7 +573,7 @@ static irqreturn_t sx9310_irq_thread_handler(int irq, void *private)
mutex_lock(&data->mutex); mutex_lock(&data->mutex);
ret = regmap_read(data->regmap, SX9310_REG_IRQ_SRC, &val); ret = regmap_read(data->regmap, SX9310_REG_IRQ_SRC, &val);
if (ret < 0) { if (ret) {
dev_err(&data->client->dev, "i2c transfer error in irq\n"); dev_err(&data->client->dev, "i2c transfer error in irq\n");
goto out; goto out;
} }
...@@ -616,20 +616,20 @@ static int sx9310_write_event_config(struct iio_dev *indio_dev, ...@@ -616,20 +616,20 @@ static int sx9310_write_event_config(struct iio_dev *indio_dev,
mutex_lock(&data->mutex); mutex_lock(&data->mutex);
if (state) { if (state) {
ret = sx9310_get_event_channel(data, chan->channel); ret = sx9310_get_event_channel(data, chan->channel);
if (ret < 0) if (ret)
goto out_unlock; goto out_unlock;
if (!(data->chan_event & ~BIT(chan->channel))) { if (!(data->chan_event & ~BIT(chan->channel))) {
ret = sx9310_enable_irq(data, eventirq); ret = sx9310_enable_irq(data, eventirq);
if (ret < 0) if (ret)
sx9310_put_event_channel(data, chan->channel); sx9310_put_event_channel(data, chan->channel);
} }
} else { } else {
ret = sx9310_put_event_channel(data, chan->channel); ret = sx9310_put_event_channel(data, chan->channel);
if (ret < 0) if (ret)
goto out_unlock; goto out_unlock;
if (!data->chan_event) { if (!data->chan_event) {
ret = sx9310_disable_irq(data, eventirq); ret = sx9310_disable_irq(data, eventirq);
if (ret < 0) if (ret)
sx9310_get_event_channel(data, chan->channel); sx9310_get_event_channel(data, chan->channel);
} }
} }
...@@ -668,7 +668,7 @@ static int sx9310_set_trigger_state(struct iio_trigger *trig, bool state) ...@@ -668,7 +668,7 @@ static int sx9310_set_trigger_state(struct iio_trigger *trig, bool state)
ret = sx9310_enable_irq(data, SX9310_CONVDONE_IRQ); ret = sx9310_enable_irq(data, SX9310_CONVDONE_IRQ);
else if (!data->chan_read) else if (!data->chan_read)
ret = sx9310_disable_irq(data, SX9310_CONVDONE_IRQ); ret = sx9310_disable_irq(data, SX9310_CONVDONE_IRQ);
if (ret < 0) if (ret)
goto out; goto out;
data->trigger_enabled = state; data->trigger_enabled = state;
...@@ -697,7 +697,7 @@ static irqreturn_t sx9310_trigger_handler(int irq, void *private) ...@@ -697,7 +697,7 @@ static irqreturn_t sx9310_trigger_handler(int irq, void *private)
indio_dev->masklength) { indio_dev->masklength) {
ret = sx9310_read_prox_data(data, &indio_dev->channels[bit], ret = sx9310_read_prox_data(data, &indio_dev->channels[bit],
&val); &val);
if (ret < 0) if (ret)
goto out; goto out;
data->buffer.channels[i++] = val; data->buffer.channels[i++] = val;
...@@ -802,13 +802,13 @@ static int sx9310_init_compensation(struct iio_dev *indio_dev) ...@@ -802,13 +802,13 @@ static int sx9310_init_compensation(struct iio_dev *indio_dev)
unsigned int ctrl0; unsigned int ctrl0;
ret = regmap_read(data->regmap, SX9310_REG_PROX_CTRL0, &ctrl0); ret = regmap_read(data->regmap, SX9310_REG_PROX_CTRL0, &ctrl0);
if (ret < 0) if (ret)
return ret; return ret;
/* run the compensation phase on all channels */ /* run the compensation phase on all channels */
ret = regmap_write(data->regmap, SX9310_REG_PROX_CTRL0, ret = regmap_write(data->regmap, SX9310_REG_PROX_CTRL0,
ctrl0 | SX9310_REG_PROX_CTRL0_SENSOREN_MASK); ctrl0 | SX9310_REG_PROX_CTRL0_SENSOREN_MASK);
if (ret < 0) if (ret)
return ret; return ret;
ret = regmap_read_poll_timeout(data->regmap, SX9310_REG_STAT1, val, ret = regmap_read_poll_timeout(data->regmap, SX9310_REG_STAT1, val,
...@@ -834,21 +834,21 @@ static int sx9310_init_device(struct iio_dev *indio_dev) ...@@ -834,21 +834,21 @@ static int sx9310_init_device(struct iio_dev *indio_dev)
unsigned int i, val; unsigned int i, val;
ret = regmap_write(data->regmap, SX9310_REG_RESET, SX9310_SOFT_RESET); ret = regmap_write(data->regmap, SX9310_REG_RESET, SX9310_SOFT_RESET);
if (ret < 0) if (ret)
return ret; return ret;
usleep_range(1000, 2000); /* power-up time is ~1ms. */ usleep_range(1000, 2000); /* power-up time is ~1ms. */
/* Clear reset interrupt state by reading SX9310_REG_IRQ_SRC. */ /* Clear reset interrupt state by reading SX9310_REG_IRQ_SRC. */
ret = regmap_read(data->regmap, SX9310_REG_IRQ_SRC, &val); ret = regmap_read(data->regmap, SX9310_REG_IRQ_SRC, &val);
if (ret < 0) if (ret)
return ret; return ret;
/* Program some sane defaults. */ /* Program some sane defaults. */
for (i = 0; i < ARRAY_SIZE(sx9310_default_regs); i++) { for (i = 0; i < ARRAY_SIZE(sx9310_default_regs); i++) {
initval = &sx9310_default_regs[i]; initval = &sx9310_default_regs[i];
ret = regmap_write(data->regmap, initval->reg, initval->def); ret = regmap_write(data->regmap, initval->reg, initval->def);
if (ret < 0) if (ret)
return ret; return ret;
} }
...@@ -902,14 +902,14 @@ static int sx9310_probe(struct i2c_client *client) ...@@ -902,14 +902,14 @@ static int sx9310_probe(struct i2c_client *client)
return PTR_ERR(data->regmap); return PTR_ERR(data->regmap);
ret = regmap_read(data->regmap, SX9310_REG_WHOAMI, &data->whoami); ret = regmap_read(data->regmap, SX9310_REG_WHOAMI, &data->whoami);
if (ret < 0) { if (ret) {
dev_err(&client->dev, "error in reading WHOAMI register: %d", dev_err(&client->dev, "error in reading WHOAMI register: %d",
ret); ret);
return ret; return ret;
} }
ret = sx9310_set_indio_dev_name(&client->dev, indio_dev, data->whoami); ret = sx9310_set_indio_dev_name(&client->dev, indio_dev, data->whoami);
if (ret < 0) if (ret)
return ret; return ret;
ACPI_COMPANION_SET(&indio_dev->dev, ACPI_COMPANION(&client->dev)); ACPI_COMPANION_SET(&indio_dev->dev, ACPI_COMPANION(&client->dev));
...@@ -920,7 +920,7 @@ static int sx9310_probe(struct i2c_client *client) ...@@ -920,7 +920,7 @@ static int sx9310_probe(struct i2c_client *client)
i2c_set_clientdata(client, indio_dev); i2c_set_clientdata(client, indio_dev);
ret = sx9310_init_device(indio_dev); ret = sx9310_init_device(indio_dev);
if (ret < 0) if (ret)
return ret; return ret;
if (client->irq) { if (client->irq) {
...@@ -929,7 +929,7 @@ static int sx9310_probe(struct i2c_client *client) ...@@ -929,7 +929,7 @@ static int sx9310_probe(struct i2c_client *client)
sx9310_irq_thread_handler, sx9310_irq_thread_handler,
IRQF_TRIGGER_LOW | IRQF_ONESHOT, IRQF_TRIGGER_LOW | IRQF_ONESHOT,
"sx9310_event", indio_dev); "sx9310_event", indio_dev);
if (ret < 0) if (ret)
return ret; return ret;
data->trig = data->trig =
...@@ -951,7 +951,7 @@ static int sx9310_probe(struct i2c_client *client) ...@@ -951,7 +951,7 @@ static int sx9310_probe(struct i2c_client *client)
iio_pollfunc_store_time, iio_pollfunc_store_time,
sx9310_trigger_handler, sx9310_trigger_handler,
&sx9310_buffer_setup_ops); &sx9310_buffer_setup_ops);
if (ret < 0) if (ret)
return ret; return ret;
return devm_iio_device_register(&client->dev, indio_dev); return devm_iio_device_register(&client->dev, indio_dev);
......
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