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:
Markus Elfring 2017-11-03 09:26:28 +01:00 committed by Jonathan Cameron
parent 71e083aaf7
commit aa6b707c14
1 changed files with 9 additions and 8 deletions

View File

@ -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,