net: ethernet: ezchip: fix UAF in nps_enet_remove
authorPavel Skripkin <paskripkin@gmail.com>
Fri, 18 Jun 2021 16:14:31 +0000 (19:14 +0300)
committerDavid S. Miller <davem@davemloft.net>
Sat, 19 Jun 2021 18:46:00 +0000 (11:46 -0700)
priv is netdev private data, but it is used
after free_netdev(). It can cause use-after-free when accessing priv
pointer. So, fix it by moving free_netdev() after netif_napi_del()
call.

Fixes: 0dd077093636 ("NET: Add ezchip ethernet driver")
Signed-off-by: Pavel Skripkin <paskripkin@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/ezchip/nps_enet.c

index e3954d8835e71156fe900405263e5ab5f8525b32..20d2c2bb26e4a9dbd2841e9005c74e263ffb4af8 100644 (file)
@@ -642,8 +642,8 @@ static s32 nps_enet_remove(struct platform_device *pdev)
        struct nps_enet_priv *priv = netdev_priv(ndev);
 
        unregister_netdev(ndev);
-       free_netdev(ndev);
        netif_napi_del(&priv->napi);
+       free_netdev(ndev);
 
        return 0;
 }