CVE-2022-49607
Published: Feb 26, 2025
Modified: May 23, 2026
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.
| Vendor | Product | Versions |
|---|---|---|
Linux | Linux | affected 9bb5d40cd93c9dd4be74834b1dcb1ba03629716b - < 3bbd868099287ff9027db59029b502fcfa2202a0affected 9bb5d40cd93c9dd4be74834b1dcb1ba03629716b - < f836f9ac95df15f1e0af4beb0ec20021e8c91998affected 9bb5d40cd93c9dd4be74834b1dcb1ba03629716b - < 17f5417194136517ee9bbd6511249e5310e5617caffected 9bb5d40cd93c9dd4be74834b1dcb1ba03629716b - < 98c3c8fd0d4c560e0f8335b79c407bbf7fc9462caffected 9bb5d40cd93c9dd4be74834b1dcb1ba03629716b - < 43128b3eee337824158f34da6648163d2f2fb937+9 more versions |
Linux | Linux | affected 3.10unaffected 0 - < 3.10unaffected 4.9.325 - <= 4.9.*unaffected 4.14.290 - <= 4.14.*unaffected 4.19.254 - <= 4.19.*+5 more versions |
References
Security Training
Train your team to recognize and prevent security threats with our comprehensive security awareness program.
Start TrainingVulnerability Scanning
Discover vulnerabilities in your applications and infrastructure before attackers do.
Scan Now