We use these services and cookies to improve your user experience. You may opt out if you wish, however, this may limit some features on this site.

Please see our statement on Data Privacy.

Crisp.chat (Helpdesk and Chat)

Ok

THREATINT
PUBLISHED

CVE-2025-38017

fs/eventpoll: fix endless busy loop after timeout has expired



Description

In the Linux kernel, the following vulnerability has been resolved: fs/eventpoll: fix endless busy loop after timeout has expired After commit 0a65bc27bd64 ("eventpoll: Set epoll timeout if it's in the future"), the following program would immediately enter a busy loop in the kernel: ``` int main() { int e = epoll_create1(0); struct epoll_event event = {.events = EPOLLIN}; epoll_ctl(e, EPOLL_CTL_ADD, 0, &event); const struct timespec timeout = {.tv_nsec = 1}; epoll_pwait2(e, &event, 1, &timeout, 0); } ``` This happens because the given (non-zero) timeout of 1 nanosecond usually expires before ep_poll() is entered and then ep_schedule_timeout() returns false, but `timed_out` is never set because the code line that sets it is skipped. This quickly turns into a soft lockup, RCU stalls and deadlocks, inflicting severe headaches to the whole system. When the timeout has expired, we don't need to schedule a hrtimer, but we should set the `timed_out` variable. Therefore, I suggest moving the ep_schedule_timeout() check into the `timed_out` expression instead of skipping it. brauner: Note that there was an earlier fix by Joe Damato in response to my bug report in [1].

Reserved 2025-04-16 | Published 2025-06-18 | Updated 2025-06-18 | Assigner Linux

Product status

Default status
unaffected

99a0ad16dfd114a429df665065dcc576dad743c0 before 7631dca012593c95d36199082546a24a0058fc50
affected

0a65bc27bd645894175c059397b4916e31955fb2 before d9ec73301099ec5975505e1c3effbe768bab9490
affected

Default status
unaffected

6.14.4 before 6.14.8
affected

References

git.kernel.org/...c/7631dca012593c95d36199082546a24a0058fc50

git.kernel.org/...c/d9ec73301099ec5975505e1c3effbe768bab9490

cve.org (CVE-2025-38017)

nvd.nist.gov (CVE-2025-38017)

Download JSON

Share this page
https://cve.threatint.eu/CVE/CVE-2025-38017

Support options

Helpdesk Chat, Email, Knowledgebase