net: ethernet: ti: cpdma: correct error handling for chan create
authorIvan Khoronzhuk <ivan.khoronzhuk@linaro.org>
Tue, 12 Dec 2017 21:06:35 +0000 (23:06 +0200)
committerDavid S. Miller <davem@davemloft.net>
Wed, 13 Dec 2017 20:49:53 +0000 (15:49 -0500)
It's not correct to return NULL when that is actually an error and
function returns errors in any other wrong case. In the same time,
the cpsw driver and davinci emac doesn't check error case while
creating channel and it can miss actual error. Also remove WARNs
replacing them on dev_err msgs.

Signed-off-by: Ivan Khoronzhuk <ivan.khoronzhuk@linaro.org>
Reviewed-by: Grygorii Strashko <grygorii.strashko@ti.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/ti/cpsw.c
drivers/net/ethernet/ti/davinci_cpdma.c
drivers/net/ethernet/ti/davinci_emac.c

index a60a378b8b298e8a3d3031ed9916187fe80c2663..3c85a0885f9bb1edd2e06ffc30d2c0e9c873decc 100644 (file)
@@ -3065,10 +3065,16 @@ static int cpsw_probe(struct platform_device *pdev)
        }
 
        cpsw->txv[0].ch = cpdma_chan_create(cpsw->dma, 0, cpsw_tx_handler, 0);
+       if (IS_ERR(cpsw->txv[0].ch)) {
+               dev_err(priv->dev, "error initializing tx dma channel\n");
+               ret = PTR_ERR(cpsw->txv[0].ch);
+               goto clean_dma_ret;
+       }
+
        cpsw->rxv[0].ch = cpdma_chan_create(cpsw->dma, 0, cpsw_rx_handler, 1);
-       if (WARN_ON(!cpsw->rxv[0].ch || !cpsw->txv[0].ch)) {
-               dev_err(priv->dev, "error initializing dma channels\n");
-               ret = -ENOMEM;
+       if (IS_ERR(cpsw->rxv[0].ch)) {
+               dev_err(priv->dev, "error initializing rx dma channel\n");
+               ret = PTR_ERR(cpsw->rxv[0].ch);
                goto clean_dma_ret;
        }
 
index e4d6edf387b34571242b720306602528ddf94fe3..6f9173ff941495564a1567d5fe1c3b2962188857 100644 (file)
@@ -893,7 +893,7 @@ struct cpdma_chan *cpdma_chan_create(struct cpdma_ctlr *ctlr, int chan_num,
        chan_num = rx_type ? rx_chan_num(chan_num) : tx_chan_num(chan_num);
 
        if (__chan_linear(chan_num) >= ctlr->num_chan)
-               return NULL;
+               return ERR_PTR(-EINVAL);
 
        chan = devm_kzalloc(ctlr->dev, sizeof(*chan), GFP_KERNEL);
        if (!chan)
index f58c0c620356be35f4cdca54a1e05bab4343f28e..abceea802ea1b0b351628a264aca624696e2c290 100644 (file)
@@ -1870,10 +1870,17 @@ static int davinci_emac_probe(struct platform_device *pdev)
 
        priv->txchan = cpdma_chan_create(priv->dma, EMAC_DEF_TX_CH,
                                         emac_tx_handler, 0);
+       if (IS_ERR(priv->txchan)) {
+               dev_err(&pdev->dev, "error initializing tx dma channel\n");
+               rc = PTR_ERR(priv->txchan);
+               goto no_cpdma_chan;
+       }
+
        priv->rxchan = cpdma_chan_create(priv->dma, EMAC_DEF_RX_CH,
                                         emac_rx_handler, 1);
-       if (WARN_ON(!priv->txchan || !priv->rxchan)) {
-               rc = -ENOMEM;
+       if (IS_ERR(priv->rxchan)) {
+               dev_err(&pdev->dev, "error initializing rx dma channel\n");
+               rc = PTR_ERR(priv->rxchan);
                goto no_cpdma_chan;
        }