mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-16 18:16:41 +07:00
Staging: iio: dereferencing uninitialized variable
In the error handling, it dereferences "st" before it has been initialized. I also just tidied it up a bit to remove some extra conditions. Signed-off-by: Dan Carpenter <error27@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
7959a7c477
commit
f88af7e7d3
@ -1255,12 +1255,15 @@ static int __devinit max1363_probe(struct i2c_client *client,
|
||||
struct regulator *reg;
|
||||
|
||||
reg = regulator_get(&client->dev, "vcc");
|
||||
if (!IS_ERR(reg)) {
|
||||
ret = regulator_enable(reg);
|
||||
if (ret)
|
||||
goto error_put_reg;
|
||||
if (IS_ERR(reg)) {
|
||||
ret = PTR_ERR(reg);
|
||||
goto error_out;
|
||||
}
|
||||
|
||||
ret = regulator_enable(reg);
|
||||
if (ret)
|
||||
goto error_put_reg;
|
||||
|
||||
indio_dev = iio_allocate_device(sizeof(struct max1363_state));
|
||||
if (indio_dev == NULL) {
|
||||
ret = -ENOMEM;
|
||||
@ -1323,6 +1326,7 @@ static int __devinit max1363_probe(struct i2c_client *client,
|
||||
}
|
||||
|
||||
return 0;
|
||||
|
||||
error_uninit_ring:
|
||||
iio_ring_buffer_unregister(indio_dev->ring);
|
||||
error_cleanup_ring:
|
||||
@ -1335,12 +1339,10 @@ static int __devinit max1363_probe(struct i2c_client *client,
|
||||
else
|
||||
iio_device_unregister(indio_dev);
|
||||
error_disable_reg:
|
||||
if (!IS_ERR(st->reg))
|
||||
regulator_disable(st->reg);
|
||||
regulator_disable(reg);
|
||||
error_put_reg:
|
||||
if (!IS_ERR(st->reg))
|
||||
regulator_put(st->reg);
|
||||
|
||||
regulator_put(reg);
|
||||
error_out:
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user