Commit 5de6ef49 authored by Markus Elfring's avatar Markus Elfring Committed by Mathieu Poirier

remoteproc: imx_dsp_rproc: Improve exception handling in imx_dsp_rproc_mbox_alloc()

The label “err_out” was used to jump to another pointer check
despite of the detail in the implementation of the function
“imx_dsp_rproc_mbox_alloc” that it was determined already
that the corresponding variable contained an error pointer
because of a failed call of the function “mbox_request_channel_byname”.

Thus perform the following adjustments:

1. Return directly after a call of the function
   “mbox_request_channel_byname” failed for the input parameter “tx”.

2. Use more appropriate labels instead.

3. Reorder jump targets at the end.

4. Omit a function call and three extra checks.

This issue was detected by using the Coccinelle software.
Signed-off-by: default avatarMarkus Elfring <elfring@users.sourceforge.net>
Link: https://lore.kernel.org/r/d0e18bb1-afc4-8b6f-bb1c-b74b3bad908e@web.deSigned-off-by: default avatarMathieu Poirier <mathieu.poirier@linaro.org>
parent 3a87fc6f
...@@ -530,7 +530,7 @@ static int imx_dsp_rproc_mbox_alloc(struct imx_dsp_rproc *priv) ...@@ -530,7 +530,7 @@ static int imx_dsp_rproc_mbox_alloc(struct imx_dsp_rproc *priv)
ret = PTR_ERR(priv->tx_ch); ret = PTR_ERR(priv->tx_ch);
dev_dbg(cl->dev, "failed to request tx mailbox channel: %d\n", dev_dbg(cl->dev, "failed to request tx mailbox channel: %d\n",
ret); ret);
goto err_out; return ret;
} }
/* Channel for receiving message */ /* Channel for receiving message */
...@@ -539,7 +539,7 @@ static int imx_dsp_rproc_mbox_alloc(struct imx_dsp_rproc *priv) ...@@ -539,7 +539,7 @@ static int imx_dsp_rproc_mbox_alloc(struct imx_dsp_rproc *priv)
ret = PTR_ERR(priv->rx_ch); ret = PTR_ERR(priv->rx_ch);
dev_dbg(cl->dev, "failed to request rx mailbox channel: %d\n", dev_dbg(cl->dev, "failed to request rx mailbox channel: %d\n",
ret); ret);
goto err_out; goto free_channel_tx;
} }
cl = &priv->cl_rxdb; cl = &priv->cl_rxdb;
...@@ -555,19 +555,15 @@ static int imx_dsp_rproc_mbox_alloc(struct imx_dsp_rproc *priv) ...@@ -555,19 +555,15 @@ static int imx_dsp_rproc_mbox_alloc(struct imx_dsp_rproc *priv)
ret = PTR_ERR(priv->rxdb_ch); ret = PTR_ERR(priv->rxdb_ch);
dev_dbg(cl->dev, "failed to request mbox chan rxdb, ret %d\n", dev_dbg(cl->dev, "failed to request mbox chan rxdb, ret %d\n",
ret); ret);
goto err_out; goto free_channel_rx;
} }
return 0; return 0;
err_out: free_channel_rx:
if (!IS_ERR(priv->tx_ch))
mbox_free_channel(priv->tx_ch);
if (!IS_ERR(priv->rx_ch))
mbox_free_channel(priv->rx_ch); mbox_free_channel(priv->rx_ch);
if (!IS_ERR(priv->rxdb_ch)) free_channel_tx:
mbox_free_channel(priv->rxdb_ch); mbox_free_channel(priv->tx_ch);
return ret; return ret;
} }
......
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