Skip to content

Commit b5109b6

Browse files
Kaixin WangPaolo Abeni
Kaixin Wang
authored and
Paolo Abeni
committed
net: seeq: Fix use after free vulnerability in ether3 Driver Due to Race Condition
In the ether3_probe function, a timer is initialized with a callback function ether3_ledoff, bound to &prev(dev)->timer. Once the timer is started, there is a risk of a race condition if the module or device is removed, triggering the ether3_remove function to perform cleanup. The sequence of operations that may lead to a UAF bug is as follows: CPU0 CPU1 | ether3_ledoff ether3_remove | free_netdev(dev); | put_devic | kfree(dev); | | ether3_outw(priv(dev)->regs.config2 |= CFG2_CTRLO, REG_CONFIG2); | // use dev Fix it by ensuring that the timer is canceled before proceeding with the cleanup in ether3_remove. Fixes: 6fd9c53 ("net: seeq: Convert timers to use timer_setup()") Signed-off-by: Kaixin Wang <[email protected]> Link: https://patch.msgid.link/[email protected] Signed-off-by: Paolo Abeni <[email protected]>
1 parent 9c778fe commit b5109b6

File tree

1 file changed

+2
-0
lines changed

1 file changed

+2
-0
lines changed

drivers/net/ethernet/seeq/ether3.c

+2
Original file line numberDiff line numberDiff line change
@@ -847,9 +847,11 @@ static void ether3_remove(struct expansion_card *ec)
847847
{
848848
struct net_device *dev = ecard_get_drvdata(ec);
849849

850+
ether3_outw(priv(dev)->regs.config2 |= CFG2_CTRLO, REG_CONFIG2);
850851
ecard_set_drvdata(ec, NULL);
851852

852853
unregister_netdev(dev);
854+
del_timer_sync(&priv(dev)->timer);
853855
free_netdev(dev);
854856
ecard_release_resources(ec);
855857
}

0 commit comments

Comments
 (0)