CVE 7.8 HIGH

media: dvb-core: fix wrong reinitialization of ringbuffer on reopen_CVE-2026-23253

7.8 / 10
HIGH
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

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.

Basic Information

ID CVE-2026-23253
Source Linux
Published Mar 18, 2026 at 17:01
Modified Apr 2, 2026 at 14:44

Affected Product

Vendor Linux
Product Linux
Version 34731df288a5ffe4b0c396caf8cd24c6a710a222
Affected Versions Linux Linux 34731df288a5ffe4b0c396caf8cd24c6a710a222
Linux Linux 34731df288a5ffe4b0c396caf8cd24c6a710a222
Linux Linux 34731df288a5ffe4b0c396caf8cd24c6a710a222
Linux Linux 34731df288a5ffe4b0c396caf8cd24c6a710a222
Linux Linux 34731df288a5ffe4b0c396caf8cd24c6a710a222
Linux Linux 34731df288a5ffe4b0c396caf8cd24c6a710a222
Linux Linux 2.6.17

References

💭 Join the Security Discussion

🔒 Your email address will not be published. Required fields are marked *

⚠️ Please be respectful and constructive in your comments. Security discussions should remain professional.