Commit d18a6ef5 authored by Dan Carpenter's avatar Dan Carpenter Committed by Mauro Carvalho Chehab

media: dib0700: fix locking in dib0700_i2c_xfer_new()

This patch mostly adds unlocks to error paths.  But one additional small
change is that I made the first "break;" a "goto unlock;" which means
that now we return failure instead of success on that path.
Signed-off-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
parent dbe885a5
...@@ -215,13 +215,14 @@ static int dib0700_i2c_xfer_new(struct i2c_adapter *adap, struct i2c_msg *msg, ...@@ -215,13 +215,14 @@ static int dib0700_i2c_xfer_new(struct i2c_adapter *adap, struct i2c_msg *msg,
USB_CTRL_GET_TIMEOUT); USB_CTRL_GET_TIMEOUT);
if (result < 0) { if (result < 0) {
deb_info("i2c read error (status = %d)\n", result); deb_info("i2c read error (status = %d)\n", result);
break; goto unlock;
} }
if (msg[i].len > sizeof(st->buf)) { if (msg[i].len > sizeof(st->buf)) {
deb_info("buffer too small to fit %d bytes\n", deb_info("buffer too small to fit %d bytes\n",
msg[i].len); msg[i].len);
return -EIO; result = -EIO;
goto unlock;
} }
memcpy(msg[i].buf, st->buf, msg[i].len); memcpy(msg[i].buf, st->buf, msg[i].len);
...@@ -233,8 +234,8 @@ static int dib0700_i2c_xfer_new(struct i2c_adapter *adap, struct i2c_msg *msg, ...@@ -233,8 +234,8 @@ static int dib0700_i2c_xfer_new(struct i2c_adapter *adap, struct i2c_msg *msg,
/* Write request */ /* Write request */
if (mutex_lock_interruptible(&d->usb_mutex) < 0) { if (mutex_lock_interruptible(&d->usb_mutex) < 0) {
err("could not acquire lock"); err("could not acquire lock");
mutex_unlock(&d->i2c_mutex); result = -EINTR;
return -EINTR; goto unlock;
} }
st->buf[0] = REQUEST_NEW_I2C_WRITE; st->buf[0] = REQUEST_NEW_I2C_WRITE;
st->buf[1] = msg[i].addr << 1; st->buf[1] = msg[i].addr << 1;
...@@ -247,7 +248,9 @@ static int dib0700_i2c_xfer_new(struct i2c_adapter *adap, struct i2c_msg *msg, ...@@ -247,7 +248,9 @@ static int dib0700_i2c_xfer_new(struct i2c_adapter *adap, struct i2c_msg *msg,
if (msg[i].len > sizeof(st->buf) - 4) { if (msg[i].len > sizeof(st->buf) - 4) {
deb_info("i2c message to big: %d\n", deb_info("i2c message to big: %d\n",
msg[i].len); msg[i].len);
return -EIO; mutex_unlock(&d->usb_mutex);
result = -EIO;
goto unlock;
} }
/* The Actual i2c payload */ /* The Actual i2c payload */
...@@ -269,8 +272,11 @@ static int dib0700_i2c_xfer_new(struct i2c_adapter *adap, struct i2c_msg *msg, ...@@ -269,8 +272,11 @@ static int dib0700_i2c_xfer_new(struct i2c_adapter *adap, struct i2c_msg *msg,
} }
} }
} }
result = i;
unlock:
mutex_unlock(&d->i2c_mutex); mutex_unlock(&d->i2c_mutex);
return i; return result;
} }
/* /*
......
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