]> git.baikalelectronics.ru Git - kernel.git/commitdiff
net: gemini: Fix memory leak in gmac_setup_txqs
authorNavid Emamdoost <navid.emamdoost@gmail.com>
Sun, 15 Dec 2019 01:10:44 +0000 (19:10 -0600)
committerDavid S. Miller <davem@davemloft.net>
Tue, 17 Dec 2019 00:26:54 +0000 (16:26 -0800)
In the implementation of gmac_setup_txqs() the allocated desc_ring is
leaked if TX queue base is not aligned. Release it via
dma_free_coherent.

Fixes: 4d5ae32f5e1e ("net: ethernet: Add a driver for Gemini gigabit ethernet")
Signed-off-by: Navid Emamdoost <navid.emamdoost@gmail.com>
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/cortina/gemini.c

index a8f4c69252ff886a6a48bcdc1454489750a201a7..2814b96751b4f2e50f11e9e31dbdbcde08c3ec3e 100644 (file)
@@ -576,6 +576,8 @@ static int gmac_setup_txqs(struct net_device *netdev)
 
        if (port->txq_dma_base & ~DMA_Q_BASE_MASK) {
                dev_warn(geth->dev, "TX queue base is not aligned\n");
+               dma_free_coherent(geth->dev, len * sizeof(*desc_ring),
+                                 desc_ring, port->txq_dma_base);
                kfree(skb_tab);
                return -ENOMEM;
        }