diff options
author | Chun-Yi Lee <joeyli.kernel@gmail.com> | 2024-10-02 05:54:58 +0200 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2024-10-02 15:16:44 +0200 |
commit | 6d6e54fc71ad1ab0a87047fd9c211e75d86084a3 (patch) | |
tree | ef0941159805ef5625ae238c18120388bb6a1ce3 /drivers/block/drbd | |
parent | blk_iocost: remove some duplicate irq disable/enables (diff) | |
download | linux-6d6e54fc71ad1ab0a87047fd9c211e75d86084a3.tar.xz linux-6d6e54fc71ad1ab0a87047fd9c211e75d86084a3.zip |
aoe: fix the potential use-after-free problem in more places
For fixing CVE-2023-6270, f98364e92662 ("aoe: fix the potential
use-after-free problem in aoecmd_cfg_pkts") makes tx() calling dev_put()
instead of doing in aoecmd_cfg_pkts(). It avoids that the tx() runs
into use-after-free.
Then Nicolai Stange found more places in aoe have potential use-after-free
problem with tx(). e.g. revalidate(), aoecmd_ata_rw(), resend(), probe()
and aoecmd_cfg_rsp(). Those functions also use aoenet_xmit() to push
packet to tx queue. So they should also use dev_hold() to increase the
refcnt of skb->dev.
On the other hand, moving dev_put() to tx() causes that the refcnt of
skb->dev be reduced to a negative value, because corresponding
dev_hold() are not called in revalidate(), aoecmd_ata_rw(), resend(),
probe(), and aoecmd_cfg_rsp(). This patch fixed this issue.
Cc: stable@vger.kernel.org
Link: https://nvd.nist.gov/vuln/detail/CVE-2023-6270
Fixes: f98364e92662 ("aoe: fix the potential use-after-free problem in aoecmd_cfg_pkts")
Reported-by: Nicolai Stange <nstange@suse.com>
Signed-off-by: Chun-Yi Lee <jlee@suse.com>
Link: https://lore.kernel.org/stable/20240624064418.27043-1-jlee%40suse.com
Link: https://lore.kernel.org/r/20241002035458.24401-1-jlee@suse.com
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'drivers/block/drbd')
0 files changed, 0 insertions, 0 deletions