CVE-2022-49990

HIGH

Linux Kernel 4.4.105-4.4.999 - Use-After-Free in s390 Task Struct Copy

Title source: llm
STIX 2.1

Description

In the Linux kernel, the following vulnerability has been resolved: s390: fix double free of GS and RI CBs on fork() failure The pointers for guarded storage and runtime instrumentation control blocks are stored in the thread_struct of the associated task. These pointers are initially copied on fork() via arch_dup_task_struct() and then cleared via copy_thread() before fork() returns. If fork() happens to fail after the initial task dup and before copy_thread(), the newly allocated task and associated thread_struct memory are freed via free_task() -> arch_release_task_struct(). This results in a double free of the guarded storage and runtime info structs because the fields in the failed task still refer to memory associated with the source task. This problem can manifest as a BUG_ON() in set_freepointer() (with CONFIG_SLAB_FREELIST_HARDENED enabled) or KASAN splat (if enabled) when running trinity syscall fuzz tests on s390x. To avoid this problem, clear the associated pointer fields in arch_dup_task_struct() immediately after the new task is copied. Note that the RI flag is still cleared in copy_thread() because it resides in thread stack memory and that is where stack info is copied.

Scores

CVSS v3 7.8
EPSS 0.0022
EPSS Percentile 12.0%
Attack Vector LOCAL
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

Details

CWE
CWE-415
Status published
Products (22)
Linux/Linux < 4.15
Linux/Linux 232b47b3c88af1da737cd7760f247c4ed58168cf
Linux/Linux 4.14.5 - 4.15
Linux/Linux 4.15
Linux/Linux 4.19.257 - 4.19.*
Linux/Linux 4.4.105 - 4.5
Linux/Linux 4.9.68 - 4.10
Linux/Linux 5.10.140 - 5.10.*
Linux/Linux 5.15.64 - 5.15.*
Linux/Linux 5.19.6 - 5.19.*
... and 12 more
Published Jun 18, 2025
Tracked Since Feb 18, 2026