diff options
author | Octavian Purdila <octavian.purdila@intel.com> | 2014-11-18 14:57:57 +0200 |
---|---|---|
committer | Lee Jones <lee.jones@linaro.org> | 2014-11-19 17:12:19 +0000 |
commit | 7ca2b1c6724b150d8305ce06e4b07904ecbcb3fb (patch) | |
tree | 963bedac8667475277826c83958302c3ae6de6ef | |
parent | 6732127f62a7635db072294c74795a20a8996db2 (diff) | |
download | talos-obmc-linux-7ca2b1c6724b150d8305ce06e4b07904ecbcb3fb.tar.gz talos-obmc-linux-7ca2b1c6724b150d8305ce06e4b07904ecbcb3fb.zip |
mfd: dln2: Fix _dln2_transfer return code
If wait_for_completion_interruptible_timeout returns a positive value
it may be propagated as the return value of _dln2_transfer. This
contradicts the documentation of the function and exposes unnecessary
internals to the callers.
This patch makes sure to set the return value to 0 in that case.
Reported-by: Julia Lawall <julia.lawall@lip6.fr>
Signed-off-by: Octavian Purdila <octavian.purdila@intel.com>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
-rw-r--r-- | drivers/mfd/dln2.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/mfd/dln2.c b/drivers/mfd/dln2.c index 9765a174d2c5..cf22841c1e3c 100644 --- a/drivers/mfd/dln2.c +++ b/drivers/mfd/dln2.c @@ -462,6 +462,8 @@ static int _dln2_transfer(struct dln2_dev *dln2, u16 handle, u16 cmd, if (!ret) ret = -ETIMEDOUT; goto out_free_rx_slot; + } else { + ret = 0; } if (dln2->disconnect) { @@ -484,10 +486,8 @@ static int _dln2_transfer(struct dln2_dev *dln2, u16 handle, u16 cmd, goto out_free_rx_slot; } - if (!ibuf) { - ret = 0; + if (!ibuf) goto out_free_rx_slot; - } if (*ibuf_len > rsp->hdr.size - sizeof(*rsp)) *ibuf_len = rsp->hdr.size - sizeof(*rsp); |