Description
In the Linux kernel, the following vulnerability has been resolved: media: dvb-core: fix wrong reinitialization of ringbuffer on reopen dvb_dvr_open() calls dvb_ringbuffer_init() when a new reader opens the DVR device. dvb_ringbuffer_init() calls init_waitqueue_head(), which reinitializes the waitqueue list head to empty. Since dmxdev->dvr_buffer.queue is a shared waitqueue (all opens of the same DVR device share it), this orphans any existing waitqueue entries from io_uring poll or epoll, leaving them with stale prev/next pointers while the list head is reset to {self, self}. The waitqueue and spinlock in dvr_buffer are already properly initialized once in dvb_dmxdev_init(). The open path only needs to reset the buffer data pointer, size, and read/write positions. Replace the dvb_ringbuffer_init() call in dvb_dvr_open() with direct assignment of data/size and a call to dvb_ringbuffer_reset(), which properly resets pread, pwrite, and error with correct memory ordering without touching the waitqueue or spinlock.
Product status
34731df288a5ffe4b0c396caf8cd24c6a710a222 (git) before 527cfa8a3486b3555c5c15e2f62be484a11398dc
34731df288a5ffe4b0c396caf8cd24c6a710a222 (git) before fb378cf89be434ed1f10ab79cc4788fba8ae868d
34731df288a5ffe4b0c396caf8cd24c6a710a222 (git) before f1e520ca2e83ece6731af6167c9e5e16931ecba0
34731df288a5ffe4b0c396caf8cd24c6a710a222 (git) before af050ab44fa1b1897a940d7d756e512232f5e5df
34731df288a5ffe4b0c396caf8cd24c6a710a222 (git) before d71781bad59b1c9d60d7068004581f9bf19c0c9d
34731df288a5ffe4b0c396caf8cd24c6a710a222 (git) before cfd94642025e6f71c8f754bdec0800ee95e4f3dd
34731df288a5ffe4b0c396caf8cd24c6a710a222 (git) before 32eb8e4adc207ef31bc6e5ae56bab940b0176066
34731df288a5ffe4b0c396caf8cd24c6a710a222 (git) before bfbc0b5b32a8f28ce284add619bf226716a59bc0
2.6.17
Any version before 2.6.17
5.10.253 (semver)
5.15.203 (semver)
6.1.167 (semver)
6.6.130 (semver)
6.12.77 (semver)
6.18.17 (semver)
6.19.7 (semver)
7.0 (original_commit_for_fix)
References
git.kernel.org/...c/527cfa8a3486b3555c5c15e2f62be484a11398dc
git.kernel.org/...c/fb378cf89be434ed1f10ab79cc4788fba8ae868d
git.kernel.org/...c/f1e520ca2e83ece6731af6167c9e5e16931ecba0
git.kernel.org/...c/af050ab44fa1b1897a940d7d756e512232f5e5df
git.kernel.org/...c/d71781bad59b1c9d60d7068004581f9bf19c0c9d
git.kernel.org/...c/cfd94642025e6f71c8f754bdec0800ee95e4f3dd
git.kernel.org/...c/32eb8e4adc207ef31bc6e5ae56bab940b0176066
git.kernel.org/...c/bfbc0b5b32a8f28ce284add619bf226716a59bc0