]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
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)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 14 Jul 2021 14:59:57 +0000 (16:59 +0200)
[ Upstream commit e4b8700e07a86e8eab6916aa5c5ba99042c34089 ]

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>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/ethernet/ezchip/nps_enet.c

index 815fb62c4b02e8738c052f86e2b0f9b93121b5b5..026a3ec19b6e8e3f84f1f912912df9717a402ca2 100644 (file)
@@ -645,8 +645,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;
 }