CVE-2022-49257
Severity CVSS v4.0:
Pending analysis
Type:
CWE-476
NULL Pointer Dereference
Publication date:
26/02/2025
Last modified:
22/09/2025
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
watch_queue: Fix NULL dereference in error cleanup<br />
<br />
In watch_queue_set_size(), the error cleanup code doesn&#39;t take account of<br />
the fact that __free_page() can&#39;t handle a NULL pointer when trying to free<br />
up buffer pages that did get allocated.<br />
<br />
Fix this by only calling __free_page() on the pages actually allocated.<br />
<br />
Without the fix, this can lead to something like the following:<br />
<br />
BUG: KASAN: null-ptr-deref in __free_pages+0x1f/0x1b0 mm/page_alloc.c:5473<br />
Read of size 4 at addr 0000000000000034 by task syz-executor168/3599<br />
...<br />
Call Trace:<br />
<br />
__dump_stack lib/dump_stack.c:88 [inline]<br />
dump_stack_lvl+0xcd/0x134 lib/dump_stack.c:106<br />
__kasan_report mm/kasan/report.c:446 [inline]<br />
kasan_report.cold+0x66/0xdf mm/kasan/report.c:459<br />
check_region_inline mm/kasan/generic.c:183 [inline]<br />
kasan_check_range+0x13d/0x180 mm/kasan/generic.c:189<br />
instrument_atomic_read include/linux/instrumented.h:71 [inline]<br />
atomic_read include/linux/atomic/atomic-instrumented.h:27 [inline]<br />
page_ref_count include/linux/page_ref.h:67 [inline]<br />
put_page_testzero include/linux/mm.h:717 [inline]<br />
__free_pages+0x1f/0x1b0 mm/page_alloc.c:5473<br />
watch_queue_set_size+0x499/0x630 kernel/watch_queue.c:275<br />
pipe_ioctl+0xac/0x2b0 fs/pipe.c:632<br />
vfs_ioctl fs/ioctl.c:51 [inline]<br />
__do_sys_ioctl fs/ioctl.c:874 [inline]<br />
__se_sys_ioctl fs/ioctl.c:860 [inline]<br />
__x64_sys_ioctl+0x193/0x200 fs/ioctl.c:860<br />
do_syscall_x64 arch/x86/entry/common.c:50 [inline]<br />
do_syscall_64+0x35/0xb0 arch/x86/entry/common.c:80<br />
entry_SYSCALL_64_after_hwframe+0x44/0xae
Impact
Base Score 3.x
5.50
Severity 3.x
MEDIUM
Vulnerable products and versions
| CPE | From | Up to |
|---|---|---|
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.8 (including) | 5.10.110 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.11 (including) | 5.15.33 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.16 (including) | 5.16.19 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.17 (including) | 5.17.2 (excluding) |
To consult the complete list of CPE names with products and versions, see this page
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/112a2f9b0a8457794095a0450598f150724ec456
- https://git.kernel.org/stable/c/5ae75b4ed30322b42abaa75ef1b784addfdb7dc9
- https://git.kernel.org/stable/c/695c47cea02b9101e2fc2e7d36d552128592b347
- https://git.kernel.org/stable/c/a635415a064e77bcfbf43da413fd9dfe0bbed9cb
- https://git.kernel.org/stable/c/b6f5ad3e45d19f9c4ee3e8a2aff829f28d68591d



