lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [day] [month] [year] [list]
Message-ID: <2025022612-CVE-2022-49171-83e6@gregkh>
Date: Wed, 26 Feb 2025 02:56:16 +0100
From: Greg Kroah-Hartman <gregkh@...uxfoundation.org>
To: linux-cve-announce@...r.kernel.org
Cc: Greg Kroah-Hartman <gregkh@...uxfoundation.org>
Subject: CVE-2022-49171: ext4: don't BUG if someone dirty pages without asking ext4 first

Description
===========

In the Linux kernel, the following vulnerability has been resolved:

ext4: don't BUG if someone dirty pages without asking ext4 first

[un]pin_user_pages_remote is dirtying pages without properly warning
the file system in advance.  A related race was noted by Jan Kara in
2018[1]; however, more recently instead of it being a very hard-to-hit
race, it could be reliably triggered by process_vm_writev(2) which was
discovered by Syzbot[2].

This is technically a bug in mm/gup.c, but arguably ext4 is fragile in
that if some other kernel subsystem dirty pages without properly
notifying the file system using page_mkwrite(), ext4 will BUG, while
other file systems will not BUG (although data will still be lost).

So instead of crashing with a BUG, issue a warning (since there may be
potential data loss) and just mark the page as clean to avoid
unprivileged denial of service attacks until the problem can be
properly fixed.  More discussion and background can be found in the
thread starting at [2].

[1] https://lore.kernel.org/linux-mm/20180103100430.GE4911@quack2.suse.cz
[2] https://lore.kernel.org/r/Yg0m6IjcNmfaSokM@google.com

The Linux kernel CVE team has assigned CVE-2022-49171 to this issue.


Affected and fixed versions
===========================

	Fixed in 4.9.311 with commit 5db60e76edf5680ff1f3a7221036fc44b308f146
	Fixed in 4.14.276 with commit d666dfaa571465a19f014534a214c255ea33f301
	Fixed in 4.19.238 with commit 0d3a6926f7e8be3c897fa46216ce13b119a9f56a
	Fixed in 5.4.189 with commit 5a016c053f426a73752c3b41b60b497b58694d48
	Fixed in 5.10.110 with commit 330d0e44fc5a47c27df958ecdd4693a3cb1d8b81
	Fixed in 5.15.33 with commit a0856764dc1276ad2dc7891288c2e9246bf11a37
	Fixed in 5.16.19 with commit 343117559ef41e992e326f7a92da1a8f254dfa8c
	Fixed in 5.17.2 with commit 677c9d30e8487bee6c8e3b034070319d98f6e203
	Fixed in 5.18 with commit cc5095747edfb054ca2068d01af20be3fcc3634f

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-2022-49171
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:
	fs/ext4/inode.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/5db60e76edf5680ff1f3a7221036fc44b308f146
	https://git.kernel.org/stable/c/d666dfaa571465a19f014534a214c255ea33f301
	https://git.kernel.org/stable/c/0d3a6926f7e8be3c897fa46216ce13b119a9f56a
	https://git.kernel.org/stable/c/5a016c053f426a73752c3b41b60b497b58694d48
	https://git.kernel.org/stable/c/330d0e44fc5a47c27df958ecdd4693a3cb1d8b81
	https://git.kernel.org/stable/c/a0856764dc1276ad2dc7891288c2e9246bf11a37
	https://git.kernel.org/stable/c/343117559ef41e992e326f7a92da1a8f254dfa8c
	https://git.kernel.org/stable/c/677c9d30e8487bee6c8e3b034070319d98f6e203
	https://git.kernel.org/stable/c/cc5095747edfb054ca2068d01af20be3fcc3634f

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ