Oliver Chang
a795ca89fa
avcodec/qdm2: fix heap-use-after-free in qdm2_decode_frame
...
The `sub_packet` index in `QDM2Context` was not reset to 0 when
`qdm2_decode_frame` started processing a new packet. If an error
occurred during the decoding of a previous packet, `sub_packet` would
retain a non-zero value.
In subsequent calls to `qdm2_decode_frame` with a new packet, this
non-zero `sub_packet` value caused `qdm2_decode` to skip
`qdm2_decode_super_block`. This function is responsible for initializing
packet lists with pointers to the current packet's data. Skipping it led
to the use of stale pointers from the previous (freed) packet, resulting
in a heap-use-after-free vulnerability.
This patch explicitly resets `s->sub_packet = 0` at the beginning of
`qdm2_decode_frame`, ensuring correct initialization for each new
packet.
Fixes: OSS-Fuzz issue 476179569
(https://issues.oss-fuzz.com/issues/476179569 ).
2026-02-03 18:17:32 +00:00
..
2026-01-15 19:32:52 +00:00
2026-01-30 05:21:27 +00:00
2026-01-25 22:53:25 +01:00
2026-01-19 16:51:47 +05:30
2026-01-29 12:25:33 +01:00
2026-01-25 22:53:25 +01:00
2026-01-25 22:53:25 +01:00
2025-12-03 13:53:54 +02:00
2026-01-29 21:09:02 -03:00
2026-01-25 22:53:25 +01:00
2026-01-25 22:53:25 +01:00
2026-01-19 16:37:15 +01:00
2026-01-31 13:46:13 +00:00
2025-12-04 08:40:43 +00:00
2026-01-29 12:25:33 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2026-01-23 14:40:52 +01:00
2025-11-30 22:20:13 +01:00
2025-12-29 14:18:35 +00:00
2025-11-30 22:20:13 +01:00
2025-12-13 19:00:35 -03:00
2025-12-03 11:52:54 +01:00
2026-01-07 17:32:06 +01:00
2026-01-19 15:36:37 +00:00
2026-01-19 15:36:37 +00:00
2026-01-19 15:36:37 +00:00
2026-01-19 15:36:37 +00:00
2025-11-30 22:20:13 +01:00
2025-12-18 01:24:35 +00:00
2025-11-30 22:20:13 +01:00
2026-01-14 23:56:39 +00:00
2025-12-03 11:52:54 +01:00
2025-12-05 19:42:41 +01:00
2025-12-07 12:47:46 -03:00
2025-12-07 12:47:46 -03:00
2025-11-30 22:20:13 +01:00
2026-01-10 18:56:26 +00:00
2025-12-11 20:01:01 -03:00
2025-11-30 22:20:13 +01:00
2025-12-24 12:21:39 -03:00
2025-12-03 11:52:54 +01:00
2025-12-30 13:39:40 +00:00
2025-12-12 15:21:48 -03:00
2025-12-12 15:21:48 -03:00
2025-12-12 15:21:48 -03:00
2025-12-03 11:52:54 +01:00
2025-12-03 11:52:54 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-12-13 18:45:17 -03:00
2025-12-13 18:45:17 -03:00
2026-01-23 13:25:55 +00:00
2026-01-23 13:25:55 +00:00
2026-01-23 13:25:55 +00:00
2026-01-23 13:25:55 +00:00
2026-01-12 02:45:48 +00:00
2025-11-30 22:20:13 +01:00
2025-12-07 11:58:01 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-12-03 11:52:54 +01:00
2025-11-30 22:20:13 +01:00
2026-01-07 13:14:11 +00:00
2026-01-07 13:14:11 +00:00
2025-12-12 18:18:46 +00:00
2025-12-03 11:52:54 +01:00
2025-11-28 19:52:51 +01:00
2026-01-07 04:01:51 -05:00
2026-01-19 20:41:04 +00:00
2025-11-30 22:20:13 +01:00
2026-01-19 16:37:17 +01:00
2025-12-31 15:00:46 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-12-03 11:52:54 +01:00
2025-11-30 22:20:13 +01:00
2026-01-12 14:03:25 +01:00
2025-12-23 14:34:13 +00:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2025-11-30 22:20:13 +01:00
2026-01-25 22:53:25 +01:00
2026-01-25 22:53:25 +01:00
2026-01-25 22:53:25 +01:00
2025-12-03 11:52:54 +01:00
2025-12-05 13:54:08 +00:00
2025-11-30 22:20:13 +01:00
2026-01-25 22:53:25 +01:00
2026-01-25 22:53:25 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-12-03 11:52:54 +01:00
2025-11-30 22:20:13 +01:00
2025-12-13 05:57:47 +01:00
2025-12-13 05:57:47 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-12-28 12:55:59 -03:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-02-03 12:39:32 +01:00
2025-11-30 22:20:13 +01:00
2026-02-03 12:39:32 +01:00
2026-01-08 23:05:28 +00:00
2025-12-30 17:30:45 +00:00
2025-12-16 10:38:56 -03:00
2025-12-13 18:45:17 -03:00
2026-01-11 17:59:15 -03:00
2025-12-28 15:31:13 -03:00
2025-12-22 07:05:58 +01:00
2025-12-28 15:32:57 -03:00
2025-12-03 11:52:54 +01:00
2025-12-24 02:43:50 +00:00
2025-12-11 05:38:36 -05:00
2026-01-29 14:08:15 +01:00
2026-01-29 14:08:15 +01:00
2026-01-23 23:07:18 -03:00
2025-12-14 18:22:04 -03:00
2025-12-14 17:34:57 -03:00
2026-01-19 21:32:00 +00:00
2026-01-19 21:32:00 +00:00
2026-01-25 13:09:30 +08:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-12-14 10:16:25 +01:00
2026-01-02 18:39:48 +01:00
2025-12-19 19:56:13 +02:00
2025-11-30 22:20:13 +01:00
2026-01-17 12:02:31 -03:00
2025-12-30 17:30:45 +00:00
2026-01-05 13:14:15 +00:00
2026-01-21 03:26:02 +00:00
2026-01-19 22:42:09 +00:00
2025-12-03 11:52:54 +01:00
2026-01-22 17:44:46 -03:00
2026-01-20 00:38:35 +00:00
2026-01-25 22:46:39 +01:00
2026-01-02 18:39:48 +01:00
2025-12-03 10:20:41 +01:00
2026-01-02 18:39:48 +01:00
2025-12-03 11:52:54 +01:00
2025-12-03 11:52:54 +01:00
2025-12-03 11:52:54 +01:00
2025-12-03 11:52:54 +01:00
2026-01-02 18:39:48 +01:00
2025-12-07 20:20:38 +02:00
2025-12-07 20:20:38 +02:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2025-12-03 11:52:54 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-05 13:14:15 +00:00
2026-01-05 13:30:38 +00:00
2026-01-27 12:58:46 +00:00
2026-01-27 12:58:46 +00:00
2026-01-27 12:58:46 +00:00
2026-01-19 20:47:22 +00:00
2025-12-13 18:45:17 -03:00
2025-11-30 22:20:13 +01:00
2026-01-10 22:47:22 +01:00
2026-01-10 22:47:22 +01:00
2026-01-10 22:47:22 +01:00
2026-01-10 22:47:22 +01:00
2026-01-11 00:47:17 +00:00
2026-01-18 18:52:55 +01:00
2025-11-30 22:20:13 +01:00
2025-12-05 19:42:41 +01:00
2026-02-03 18:17:32 +00:00
2025-11-30 22:20:13 +01:00
2025-12-31 08:06:48 +00:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2026-01-20 09:47:47 +00:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2026-01-25 22:53:25 +01:00
2025-11-30 22:20:13 +01:00
2025-12-05 11:31:23 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2026-01-02 18:39:48 +01:00
2026-01-17 17:56:06 -03:00
2025-11-30 22:20:13 +01:00
2026-01-27 12:58:08 +00:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-11-30 22:20:13 +01:00
2025-12-04 15:17:37 +01:00
2025-11-30 22:20:13 +01:00
2026-01-21 10:42:02 +00:00
2026-01-19 16:37:16 +01:00
2025-12-13 19:12:24 +01:00
2026-01-19 16:37:17 +01:00
2025-12-03 11:52:54 +01:00
2025-12-03 11:52:54 +01:00
2025-12-03 11:52:54 +01:00
2025-12-31 15:00:46 +01:00
2025-12-31 15:00:46 +01:00
2025-12-13 19:12:20 +01:00
2025-12-13 19:12:20 +01:00
2026-01-12 17:28:42 +01:00
2026-01-17 17:33:31 +00:00
2025-12-30 14:39:08 -05:00
2025-12-30 14:39:08 -05:00
2025-12-13 19:12:20 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2026-01-02 18:39:48 +01:00
2025-11-30 22:20:13 +01:00
2025-12-03 11:52:54 +01:00