CVE-2021-47369

MEDIUM

Linux Kernel 5.7.16-5.7.99 - NULL Pointer Dereference in qeth_clear_working_pool_list

Title source: llm
STIX 2.1

Description

In the Linux kernel, the following vulnerability has been resolved: s390/qeth: fix NULL deref in qeth_clear_working_pool_list() When qeth_set_online() calls qeth_clear_working_pool_list() to roll back after an error exit from qeth_hardsetup_card(), we are at risk of accessing card->qdio.in_q before it was allocated by qeth_alloc_qdio_queues() via qeth_mpc_initialize(). qeth_clear_working_pool_list() then dereferences NULL, and by writing to queue->bufs[i].pool_entry scribbles all over the CPU's lowcore. Resulting in a crash when those lowcore areas are used next (eg. on the next machine-check interrupt). Such a scenario would typically happen when the device is first set online and its queues aren't allocated yet. An early IO error or certain misconfigs (eg. mismatched transport mode, bad portno) then cause us to error out from qeth_hardsetup_card() with card->qdio.in_q still being NULL. Fix it by checking the pointer for NULL before accessing it. Note that we also have (rare) paths inside qeth_mpc_initialize() where a configuration change can cause us to free the existing queues, expecting that subsequent code will allocate them again. If we then error out before that re-allocation happens, the same bug occurs. Root-caused-by: Heiko Carstens <[email protected]>

Scores

CVSS v3 5.5
EPSS 0.0024
EPSS Percentile 14.8%
Attack Vector LOCAL
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H

CISA SSVC

Vulnrichment
Exploitation none
Automatable no
Technical Impact partial

Details

CWE
CWE-476
Status published
Products (14)
Linux/Linux < 5.9
Linux/Linux 22697ca855c06a4a1264d5651542b7d98870a8c4
Linux/Linux 5.10.70 - 5.10.*
Linux/Linux 5.14.9 - 5.14.*
Linux/Linux 5.15
Linux/Linux 5.7.16 - 5.8
Linux/Linux 5.8.2 - 5.9
Linux/Linux 5.9
Linux/Linux b2400fe7e1011c5f3dc2268e8382082465b1c8a2
Linux/Linux eff73e16ee116f6eafa2be48fab42659a27cb453 - 248f064af222a1f97ee02c84a98013dfbccad386
... and 4 more
Published May 21, 2024
Tracked Since Feb 18, 2026