blob: 9b90ec53d01e253bf77d5b748b4048730f185ce0 [file] [log] [blame]
From bippy-5f407fcff5a0 Mon Sep 17 00:00:00 2001
From: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
To: <linux-cve-announce@vger.kernel.org>
Reply-to: <cve@kernel.org>, <linux-kernel@vger.kernel.org>
Subject: CVE-2024-47747: net: seeq: Fix use after free vulnerability in ether3 Driver Due to Race Condition
Description
===========
In the Linux kernel, the following vulnerability has been resolved:
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.
The Linux kernel CVE team has assigned CVE-2024-47747 to this issue.
Affected and fixed versions
===========================
Issue introduced in 4.15 with commit 6fd9c53f71862a4797b7ed8a5de80e2c64829f56 and fixed in 4.19.323 with commit 25d559ed2beec9b34045886100dac46d1ad92eba
Issue introduced in 4.15 with commit 6fd9c53f71862a4797b7ed8a5de80e2c64829f56 and fixed in 5.4.285 with commit b5a84b6c772564c8359a9a0fbaeb2a2944aa1ee9
Issue introduced in 4.15 with commit 6fd9c53f71862a4797b7ed8a5de80e2c64829f56 and fixed in 5.10.227 with commit 338a0582b28e69460df03af50e938b86b4206353
Issue introduced in 4.15 with commit 6fd9c53f71862a4797b7ed8a5de80e2c64829f56 and fixed in 5.15.168 with commit 822c7bb1f6f8b0331e8d1927151faf8db3b33afd
Issue introduced in 4.15 with commit 6fd9c53f71862a4797b7ed8a5de80e2c64829f56 and fixed in 6.1.113 with commit 1c57d61a43293252ad732007c7070fdb112545fd
Issue introduced in 4.15 with commit 6fd9c53f71862a4797b7ed8a5de80e2c64829f56 and fixed in 6.6.54 with commit d2abc379071881798d20e2ac1d332ad855ae22f3
Issue introduced in 4.15 with commit 6fd9c53f71862a4797b7ed8a5de80e2c64829f56 and fixed in 6.10.13 with commit 516dbc6d16637430808c39568cbb6b841d32b55b
Issue introduced in 4.15 with commit 6fd9c53f71862a4797b7ed8a5de80e2c64829f56 and fixed in 6.11.2 with commit 77a77331cef0a219b8dd91361435eeef04cb741c
Issue introduced in 4.15 with commit 6fd9c53f71862a4797b7ed8a5de80e2c64829f56 and fixed in 6.12 with commit b5109b60ee4fcb2f2bb24f589575e10cc5283ad4
Please see https://www.kernel.org for a full list of currently supported
kernel versions by the kernel community.
Unaffected versions might change over time as fixes are backported to
older supported kernel versions. The official CVE entry at
https://cve.org/CVERecord/?id=CVE-2024-47747
will be updated if fixes are backported, please check that for the most
up to date information about this issue.
Affected files
==============
The file(s) affected by this issue are:
drivers/net/ethernet/seeq/ether3.c
Mitigation
==========
The Linux kernel CVE team recommends that you update to the latest
stable kernel version for this, and many other bugfixes. Individual
changes are never tested alone, but rather are part of a larger kernel
release. Cherry-picking individual commits is not recommended or
supported by the Linux kernel community at all. If however, updating to
the latest release is impossible, the individual changes to resolve this
issue can be found at these commits:
https://git.kernel.org/stable/c/25d559ed2beec9b34045886100dac46d1ad92eba
https://git.kernel.org/stable/c/b5a84b6c772564c8359a9a0fbaeb2a2944aa1ee9
https://git.kernel.org/stable/c/338a0582b28e69460df03af50e938b86b4206353
https://git.kernel.org/stable/c/822c7bb1f6f8b0331e8d1927151faf8db3b33afd
https://git.kernel.org/stable/c/1c57d61a43293252ad732007c7070fdb112545fd
https://git.kernel.org/stable/c/d2abc379071881798d20e2ac1d332ad855ae22f3
https://git.kernel.org/stable/c/516dbc6d16637430808c39568cbb6b841d32b55b
https://git.kernel.org/stable/c/77a77331cef0a219b8dd91361435eeef04cb741c
https://git.kernel.org/stable/c/b5109b60ee4fcb2f2bb24f589575e10cc5283ad4