staging: iio: ad7746: Improve unlocking of a mutex in ad7746_start_calib()
* Add a jump target so that a call of the function "mutex_unlock" is stored only twice in this function implementation. * Replace two calls by goto statements. This issue was detected by using the Coccinelle software. Signed-off-by: Markus Elfring <elfring@users.sourceforge.net> Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
This commit is contained in:
parent
71e083aaf7
commit
aa6b707c14
|
@ -302,23 +302,24 @@ static inline ssize_t ad7746_start_calib(struct device *dev,
|
||||||
mutex_lock(&chip->lock);
|
mutex_lock(&chip->lock);
|
||||||
regval |= chip->config;
|
regval |= chip->config;
|
||||||
ret = i2c_smbus_write_byte_data(chip->client, AD7746_REG_CFG, regval);
|
ret = i2c_smbus_write_byte_data(chip->client, AD7746_REG_CFG, regval);
|
||||||
if (ret < 0) {
|
if (ret < 0)
|
||||||
mutex_unlock(&chip->lock);
|
goto unlock;
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
do {
|
do {
|
||||||
msleep(20);
|
msleep(20);
|
||||||
ret = i2c_smbus_read_byte_data(chip->client, AD7746_REG_CFG);
|
ret = i2c_smbus_read_byte_data(chip->client, AD7746_REG_CFG);
|
||||||
if (ret < 0) {
|
if (ret < 0)
|
||||||
mutex_unlock(&chip->lock);
|
goto unlock;
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
} while ((ret == regval) && timeout--);
|
} while ((ret == regval) && timeout--);
|
||||||
|
|
||||||
mutex_unlock(&chip->lock);
|
mutex_unlock(&chip->lock);
|
||||||
|
|
||||||
return len;
|
return len;
|
||||||
|
|
||||||
|
unlock:
|
||||||
|
mutex_unlock(&chip->lock);
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ssize_t ad7746_start_offset_calib(struct device *dev,
|
static ssize_t ad7746_start_offset_calib(struct device *dev,
|
||||||
|
|
Loading…
Reference in New Issue