Skip to content

Commit 4be585f

Browse files
Kaixin Wanggregkh
Kaixin Wang
authored andcommitted
net: seeq: Fix use after free vulnerability in ether3 Driver Due to Race Condition
[ Upstream commit b5109b6 ] 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]> Signed-off-by: Sasha Levin <[email protected]>
1 parent 6307255 commit 4be585f

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
@@ -851,9 +851,11 @@ static void ether3_remove(struct expansion_card *ec)
851851
{
852852
struct net_device *dev = ecard_get_drvdata(ec);
853853

854+
ether3_outw(priv(dev)->regs.config2 |= CFG2_CTRLO, REG_CONFIG2);
854855
ecard_set_drvdata(ec, NULL);
855856

856857
unregister_netdev(dev);
858+
del_timer_sync(&priv(dev)->timer);
857859
free_netdev(dev);
858860
ecard_release_resources(ec);
859861
}

0 commit comments

Comments
 (0)