]> 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>
Tue, 20 Jul 2021 14:22:35 +0000 (16:22 +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 b1026689b78f4075d30b240b4f8dc625d3b9299a..73d2bc349b2f9da0b9a32c8ee2e9f0f07f0cbef9 100644 (file)
@@ -621,8 +621,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;
 }