Skip to content

Commit 327a273

Browse files
WhiteFox-ProjectSherryYang1
authored andcommitted
net: davicom: fix UAF in dm9000_drv_remove
[ Upstream commit 19e65c4 ] dm is netdev private data and it cannot be used after free_netdev() call. Using dm after free_netdev() can cause UAF bug. Fix it by moving free_netdev() at the end of the function. This is similar to the issue fixed in commit ad297cd ("net: qcom/emac: fix UAF in emac_remove"). This bug is detected by our static analysis tool. Fixes: cf9e60a ("net: davicom: Fix regulator not turned off on driver removal") Signed-off-by: Chenyuan Yang <[email protected]> CC: Uwe Kleine-König <[email protected]> Link: https://patch.msgid.link/[email protected] Signed-off-by: Jakub Kicinski <[email protected]> Signed-off-by: Sasha Levin <[email protected]> (cherry picked from commit db79e982c5f9e39ab710cbce55b05f2f5e6f1ca9) Signed-off-by: Sherry Yang <[email protected]>
1 parent 4af56c9 commit 327a273

File tree

1 file changed

+2
-1
lines changed

1 file changed

+2
-1
lines changed

drivers/net/ethernet/davicom/dm9000.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1781,10 +1781,11 @@ dm9000_drv_remove(struct platform_device *pdev)
17811781

17821782
unregister_netdev(ndev);
17831783
dm9000_release_board(pdev, dm);
1784-
free_netdev(ndev); /* free device structure */
17851784
if (dm->power_supply)
17861785
regulator_disable(dm->power_supply);
17871786

1787+
free_netdev(ndev); /* free device structure */
1788+
17881789
dev_dbg(&pdev->dev, "released and freed device\n");
17891790
return 0;
17901791
}

0 commit comments

Comments
 (0)