CVE Database
/

CVE-2022-49607

Back to search

CVE-2022-49607

Published: Feb 26, 2025

Modified: May 23, 2026

PUBLISHED

Description

In the Linux kernel, the following vulnerability has been resolved: perf/core: Fix data race between perf_event_set_output() and perf_mmap_close() Yang Jihing reported a race between perf_event_set_output() and perf_mmap_close(): CPU1 CPU2 perf_mmap_close(e2) if (atomic_dec_and_test(&e2->rb->mmap_count)) // 1 - > 0 detach_rest = true ioctl(e1, IOC_SET_OUTPUT, e2) perf_event_set_output(e1, e2) ... list_for_each_entry_rcu(e, &e2->rb->event_list, rb_entry) ring_buffer_attach(e, NULL); // e1 isn't yet added and // therefore not detached ring_buffer_attach(e1, e2->rb) list_add_rcu(&e1->rb_entry, &e2->rb->event_list) After this; e1 is attached to an unmapped rb and a subsequent perf_mmap() will loop forever more: again: mutex_lock(&e->mmap_mutex); if (event->rb) { ... if (!atomic_inc_not_zero(&e->rb->mmap_count)) { ... mutex_unlock(&e->mmap_mutex); goto again; } } The loop in perf_mmap_close() holds e2->mmap_mutex, while the attach in perf_event_set_output() holds e1->mmap_mutex. As such there is no serialization to avoid this race. Change perf_event_set_output() to take both e1->mmap_mutex and e2->mmap_mutex to alleviate that problem. Additionally, have the loop in perf_mmap() detach the rb directly, this avoids having to wait for the concurrent perf_mmap_close() to get around to doing it to make progress.

VendorProductVersions

Linux

Linux

affected
9bb5d40cd93c9dd4be74834b1dcb1ba03629716b - < 3bbd868099287ff9027db59029b502fcfa2202a0
affected
9bb5d40cd93c9dd4be74834b1dcb1ba03629716b - < f836f9ac95df15f1e0af4beb0ec20021e8c91998
affected
9bb5d40cd93c9dd4be74834b1dcb1ba03629716b - < 17f5417194136517ee9bbd6511249e5310e5617c
affected
9bb5d40cd93c9dd4be74834b1dcb1ba03629716b - < 98c3c8fd0d4c560e0f8335b79c407bbf7fc9462c
affected
9bb5d40cd93c9dd4be74834b1dcb1ba03629716b - < 43128b3eee337824158f34da6648163d2f2fb937

+9 more versions

Linux

Linux

affected
3.10
unaffected
0 - < 3.10
unaffected
4.9.325 - <= 4.9.*
unaffected
4.14.290 - <= 4.14.*
unaffected
4.19.254 - <= 4.19.*

+5 more versions

Security Training

Train your team to recognize and prevent security threats with our comprehensive security awareness program.

Start Training

Vulnerability Scanning

Discover vulnerabilities in your applications and infrastructure before attackers do.

Scan Now