FFmpeg coverage


Directory: ../../../ffmpeg/
File: src/libavcodec/packet.c
Date: 2026-04-10 22:11:37
Exec Total Coverage
Lines: 366 461 79.4%
Functions: 38 40 95.0%
Branches: 157 242 64.9%

Line Branch Exec Source
1 /*
2 * AVPacket functions for libavcodec
3 * Copyright (c) 2000, 2001, 2002 Fabrice Bellard
4 *
5 * This file is part of FFmpeg.
6 *
7 * FFmpeg is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
11 *
12 * FFmpeg is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
16 *
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with FFmpeg; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 */
21
22 #include <string.h>
23
24 #include "libavutil/avassert.h"
25 #include "libavutil/avutil.h"
26 #include "libavutil/container_fifo.h"
27 #include "libavutil/mathematics.h"
28 #include "libavutil/mem.h"
29 #include "libavutil/rational.h"
30
31 #include "defs.h"
32 #include "packet.h"
33 #include "packet_internal.h"
34
35 #if FF_API_INIT_PACKET
36 1376247 void av_init_packet(AVPacket *pkt)
37 {
38 1376247 pkt->pts = AV_NOPTS_VALUE;
39 1376247 pkt->dts = AV_NOPTS_VALUE;
40 1376247 pkt->pos = -1;
41 1376247 pkt->duration = 0;
42 1376247 pkt->flags = 0;
43 1376247 pkt->stream_index = 0;
44 1376247 pkt->buf = NULL;
45 1376247 pkt->side_data = NULL;
46 1376247 pkt->side_data_elems = 0;
47 1376247 pkt->opaque = NULL;
48 1376247 pkt->opaque_ref = NULL;
49 1376247 pkt->time_base = av_make_q(0, 1);
50 1376247 }
51 #endif
52
53 13743625 static void get_packet_defaults(AVPacket *pkt)
54 {
55 13743625 memset(pkt, 0, sizeof(*pkt));
56
57 13743625 pkt->pts = AV_NOPTS_VALUE;
58 13743625 pkt->dts = AV_NOPTS_VALUE;
59 13743625 pkt->pos = -1;
60 13743625 pkt->time_base = av_make_q(0, 1);
61 13743625 }
62
63 310185 AVPacket *av_packet_alloc(void)
64 {
65 310185 AVPacket *pkt = av_malloc(sizeof(AVPacket));
66
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 310185 times.
310185 if (!pkt)
67 return pkt;
68
69 310185 get_packet_defaults(pkt);
70
71 310185 return pkt;
72 }
73
74 389724 void av_packet_free(AVPacket **pkt)
75 {
76
3/4
✓ Branch 0 taken 389724 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 79539 times.
✓ Branch 3 taken 310185 times.
389724 if (!pkt || !*pkt)
77 79539 return;
78
79 310185 av_packet_unref(*pkt);
80 310185 av_freep(pkt);
81 }
82
83 936740 static int packet_alloc(AVBufferRef **buf, int size)
84 {
85 int ret;
86
3/4
✓ Branch 0 taken 936740 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 1 times.
✓ Branch 3 taken 936739 times.
936740 if (size < 0 || size >= INT_MAX - AV_INPUT_BUFFER_PADDING_SIZE)
87 1 return AVERROR(EINVAL);
88
89 936739 ret = av_buffer_realloc(buf, size + AV_INPUT_BUFFER_PADDING_SIZE);
90
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 936739 times.
936739 if (ret < 0)
91 return ret;
92
93 936739 memset((*buf)->data + size, 0, AV_INPUT_BUFFER_PADDING_SIZE);
94
95 936739 return 0;
96 }
97
98 772389 int av_new_packet(AVPacket *pkt, int size)
99 {
100 772389 AVBufferRef *buf = NULL;
101 772389 int ret = packet_alloc(&buf, size);
102
2/2
✓ Branch 0 taken 1 times.
✓ Branch 1 taken 772388 times.
772389 if (ret < 0)
103 1 return ret;
104
105 772388 get_packet_defaults(pkt);
106 772388 pkt->buf = buf;
107 772388 pkt->data = buf->data;
108 772388 pkt->size = size;
109
110 772388 return 0;
111 }
112
113 602347 void av_shrink_packet(AVPacket *pkt, int size)
114 {
115
2/2
✓ Branch 0 taken 596871 times.
✓ Branch 1 taken 5476 times.
602347 if (pkt->size <= size)
116 596871 return;
117 5476 pkt->size = size;
118 5476 memset(pkt->data + size, 0, AV_INPUT_BUFFER_PADDING_SIZE);
119 }
120
121 280642 int av_grow_packet(AVPacket *pkt, int grow_by)
122 {
123 int new_size;
124
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 280642 times.
280642 av_assert0((unsigned)pkt->size <= INT_MAX - AV_INPUT_BUFFER_PADDING_SIZE);
125 280642 if ((unsigned)grow_by >
126
2/2
✓ Branch 0 taken 1 times.
✓ Branch 1 taken 280641 times.
280642 INT_MAX - (pkt->size + AV_INPUT_BUFFER_PADDING_SIZE))
127 1 return AVERROR(ENOMEM);
128
129 280641 new_size = pkt->size + grow_by + AV_INPUT_BUFFER_PADDING_SIZE;
130
2/2
✓ Branch 0 taken 11737 times.
✓ Branch 1 taken 268904 times.
280641 if (pkt->buf) {
131 size_t data_offset;
132 11737 uint8_t *old_data = pkt->data;
133
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 11737 times.
11737 if (pkt->data == NULL) {
134 data_offset = 0;
135 pkt->data = pkt->buf->data;
136 } else {
137 11737 data_offset = pkt->data - pkt->buf->data;
138
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 11737 times.
11737 if (data_offset > INT_MAX - new_size)
139 return AVERROR(ENOMEM);
140 }
141
142
3/4
✓ Branch 0 taken 1774 times.
✓ Branch 1 taken 9963 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 1774 times.
13511 if (new_size + data_offset > pkt->buf->size ||
143 1774 !av_buffer_is_writable(pkt->buf)) {
144 int ret;
145
146 // allocate slightly more than requested to avoid excessive
147 // reallocations
148
1/2
✓ Branch 0 taken 9963 times.
✗ Branch 1 not taken.
9963 if (new_size + data_offset < INT_MAX - new_size/16)
149 9963 new_size += new_size/16;
150
151 9963 ret = av_buffer_realloc(&pkt->buf, new_size + data_offset);
152
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 9963 times.
9963 if (ret < 0) {
153 pkt->data = old_data;
154 return ret;
155 }
156 9963 pkt->data = pkt->buf->data + data_offset;
157 }
158 } else {
159 268904 pkt->buf = av_buffer_alloc(new_size);
160
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 268904 times.
268904 if (!pkt->buf)
161 return AVERROR(ENOMEM);
162
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 268904 times.
268904 if (pkt->size > 0)
163 memcpy(pkt->buf->data, pkt->data, pkt->size);
164 268904 pkt->data = pkt->buf->data;
165 }
166 280641 pkt->size += grow_by;
167 280641 memset(pkt->data + pkt->size, 0, AV_INPUT_BUFFER_PADDING_SIZE);
168
169 280641 return 0;
170 }
171
172 29 int av_packet_from_data(AVPacket *pkt, uint8_t *data, int size)
173 {
174
2/2
✓ Branch 0 taken 1 times.
✓ Branch 1 taken 28 times.
29 if (size >= INT_MAX - AV_INPUT_BUFFER_PADDING_SIZE)
175 1 return AVERROR(EINVAL);
176
177 28 pkt->buf = av_buffer_create(data, size + AV_INPUT_BUFFER_PADDING_SIZE,
178 av_buffer_default_free, NULL, 0);
179
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 28 times.
28 if (!pkt->buf)
180 return AVERROR(ENOMEM);
181
182 28 pkt->data = data;
183 28 pkt->size = size;
184
185 28 return 0;
186 }
187
188 8679020 void av_packet_free_side_data(AVPacket *pkt)
189 {
190 int i;
191
2/2
✓ Branch 0 taken 76541 times.
✓ Branch 1 taken 8679020 times.
8755561 for (i = 0; i < pkt->side_data_elems; i++)
192 76541 av_freep(&pkt->side_data[i].data);
193 8679020 av_freep(&pkt->side_data);
194 8679020 pkt->side_data_elems = 0;
195 8679020 }
196
197 76543 int av_packet_add_side_data(AVPacket *pkt, enum AVPacketSideDataType type,
198 uint8_t *data, size_t size)
199 {
200 AVPacketSideData *tmp;
201 76543 int i, elems = pkt->side_data_elems;
202
203
2/2
✓ Branch 0 taken 230 times.
✓ Branch 1 taken 76542 times.
76772 for (i = 0; i < elems; i++) {
204 230 AVPacketSideData *sd = &pkt->side_data[i];
205
206
2/2
✓ Branch 0 taken 1 times.
✓ Branch 1 taken 229 times.
230 if (sd->type == type) {
207 1 av_free(sd->data);
208 1 sd->data = data;
209 1 sd->size = size;
210 1 return 0;
211 }
212 }
213
214
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 76542 times.
76542 if ((unsigned)elems + 1 > AV_PKT_DATA_NB)
215 return AVERROR(ERANGE);
216
217 76542 tmp = av_realloc(pkt->side_data, (elems + 1) * sizeof(*tmp));
218
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 76542 times.
76542 if (!tmp)
219 return AVERROR(ENOMEM);
220
221 76542 pkt->side_data = tmp;
222 76542 pkt->side_data[elems].data = data;
223 76542 pkt->side_data[elems].size = size;
224 76542 pkt->side_data[elems].type = type;
225 76542 pkt->side_data_elems++;
226
227 76542 return 0;
228 }
229
230
231 75067 uint8_t *av_packet_new_side_data(AVPacket *pkt, enum AVPacketSideDataType type,
232 size_t size)
233 {
234 int ret;
235 uint8_t *data;
236
237
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 75067 times.
75067 if (size > SIZE_MAX - AV_INPUT_BUFFER_PADDING_SIZE)
238 return NULL;
239 75067 data = av_mallocz(size + AV_INPUT_BUFFER_PADDING_SIZE);
240
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 75067 times.
75067 if (!data)
241 return NULL;
242
243 75067 ret = av_packet_add_side_data(pkt, type, data, size);
244
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 75067 times.
75067 if (ret < 0) {
245 av_freep(&data);
246 return NULL;
247 }
248
249 75067 return data;
250 }
251
252 1255328 uint8_t *av_packet_get_side_data(const AVPacket *pkt, enum AVPacketSideDataType type,
253 size_t *size)
254 {
255 int i;
256
257
2/2
✓ Branch 0 taken 42914 times.
✓ Branch 1 taken 1241255 times.
1284169 for (i = 0; i < pkt->side_data_elems; i++) {
258
2/2
✓ Branch 0 taken 14073 times.
✓ Branch 1 taken 28841 times.
42914 if (pkt->side_data[i].type == type) {
259
2/2
✓ Branch 0 taken 1158 times.
✓ Branch 1 taken 12915 times.
14073 if (size)
260 1158 *size = pkt->side_data[i].size;
261 14073 return pkt->side_data[i].data;
262 }
263 }
264
2/2
✓ Branch 0 taken 1063265 times.
✓ Branch 1 taken 177990 times.
1241255 if (size)
265 1063265 *size = 0;
266 1241255 return NULL;
267 }
268
269 4447 const char *av_packet_side_data_name(enum AVPacketSideDataType type)
270 {
271
23/42
✗ Branch 0 not taken.
✓ Branch 1 taken 11 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 44 times.
✓ Branch 6 taken 480 times.
✓ Branch 7 taken 16 times.
✓ Branch 8 taken 1463 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 349 times.
✓ Branch 11 taken 67 times.
✗ Branch 12 not taken.
✓ Branch 13 taken 162 times.
✗ Branch 14 not taken.
✓ Branch 15 taken 7 times.
✓ Branch 16 taken 12 times.
✓ Branch 17 taken 24 times.
✗ Branch 18 not taken.
✓ Branch 19 taken 1652 times.
✓ Branch 20 taken 29 times.
✓ Branch 21 taken 25 times.
✓ Branch 22 taken 22 times.
✗ Branch 23 not taken.
✓ Branch 24 taken 4 times.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✗ Branch 27 not taken.
✓ Branch 28 taken 8 times.
✓ Branch 29 taken 15 times.
✗ Branch 30 not taken.
✓ Branch 31 taken 4 times.
✓ Branch 32 taken 8 times.
✗ Branch 33 not taken.
✗ Branch 34 not taken.
✗ Branch 35 not taken.
✓ Branch 36 taken 21 times.
✗ Branch 37 not taken.
✓ Branch 38 taken 2 times.
✗ Branch 39 not taken.
✓ Branch 40 taken 22 times.
✗ Branch 41 not taken.
4447 switch(type) {
272 case AV_PKT_DATA_PALETTE: return "Palette";
273 11 case AV_PKT_DATA_NEW_EXTRADATA: return "New Extradata";
274 case AV_PKT_DATA_PARAM_CHANGE: return "Param Change";
275 case AV_PKT_DATA_H263_MB_INFO: return "H263 MB Info";
276 case AV_PKT_DATA_REPLAYGAIN: return "Replay Gain";
277 44 case AV_PKT_DATA_DISPLAYMATRIX: return "Display Matrix";
278 480 case AV_PKT_DATA_STEREO3D: return "Stereo 3D";
279 16 case AV_PKT_DATA_AUDIO_SERVICE_TYPE: return "Audio Service Type";
280 1463 case AV_PKT_DATA_QUALITY_STATS: return "Quality stats";
281 case AV_PKT_DATA_FALLBACK_TRACK: return "Fallback track";
282 349 case AV_PKT_DATA_CPB_PROPERTIES: return "CPB properties";
283 67 case AV_PKT_DATA_SKIP_SAMPLES: return "Skip Samples";
284 case AV_PKT_DATA_JP_DUALMONO: return "JP Dual Mono";
285 162 case AV_PKT_DATA_STRINGS_METADATA: return "Strings Metadata";
286 case AV_PKT_DATA_SUBTITLE_POSITION: return "Subtitle Position";
287 7 case AV_PKT_DATA_MATROSKA_BLOCKADDITIONAL: return "Matroska BlockAdditional";
288 12 case AV_PKT_DATA_WEBVTT_IDENTIFIER: return "WebVTT ID";
289 24 case AV_PKT_DATA_WEBVTT_SETTINGS: return "WebVTT Settings";
290 case AV_PKT_DATA_METADATA_UPDATE: return "Metadata Update";
291 1652 case AV_PKT_DATA_MPEGTS_STREAM_ID: return "MPEGTS Stream ID";
292 29 case AV_PKT_DATA_MASTERING_DISPLAY_METADATA: return "Mastering display metadata";
293 25 case AV_PKT_DATA_CONTENT_LIGHT_LEVEL: return "Content light level metadata";
294 22 case AV_PKT_DATA_SPHERICAL: return "Spherical Mapping";
295 case AV_PKT_DATA_A53_CC: return "A53 Closed Captions";
296 4 case AV_PKT_DATA_ENCRYPTION_INIT_INFO: return "Encryption initialization data";
297 case AV_PKT_DATA_ENCRYPTION_INFO: return "Encryption info";
298 case AV_PKT_DATA_AFD: return "Active Format Description data";
299 case AV_PKT_DATA_PRFT: return "Producer Reference Time";
300 8 case AV_PKT_DATA_ICC_PROFILE: return "ICC Profile";
301 15 case AV_PKT_DATA_DOVI_CONF: return "DOVI configuration record";
302 case AV_PKT_DATA_S12M_TIMECODE: return "SMPTE ST 12-1:2014 timecode";
303 4 case AV_PKT_DATA_DYNAMIC_HDR10_PLUS: return "HDR10+ Dynamic Metadata (SMPTE 2094-40)";
304 8 case AV_PKT_DATA_AMBIENT_VIEWING_ENVIRONMENT:return "Ambient viewing environment";
305 case AV_PKT_DATA_IAMF_MIX_GAIN_PARAM: return "IAMF Mix Gain Parameter Data";
306 case AV_PKT_DATA_IAMF_DEMIXING_INFO_PARAM: return "IAMF Demixing Info Parameter Data";
307 case AV_PKT_DATA_IAMF_RECON_GAIN_INFO_PARAM: return "IAMF Recon Gain Info Parameter Data";
308 21 case AV_PKT_DATA_FRAME_CROPPING: return "Frame Cropping";
309 case AV_PKT_DATA_LCEVC: return "LCEVC NAL data";
310 2 case AV_PKT_DATA_3D_REFERENCE_DISPLAYS: return "3D Reference Displays Info";
311 case AV_PKT_DATA_RTCP_SR: return "RTCP Sender Report";
312 22 case AV_PKT_DATA_EXIF: return "EXIF metadata";
313 }
314 return NULL;
315 }
316
317 650 uint8_t *av_packet_pack_dictionary(AVDictionary *dict, size_t *size)
318 {
319 650 uint8_t *data = NULL;
320 650 *size = 0;
321
322
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 650 times.
650 if (!dict)
323 return NULL;
324
325
1/2
✓ Branch 0 taken 1300 times.
✗ Branch 1 not taken.
1300 for (int pass = 0; pass < 2; pass++) {
326 1300 const AVDictionaryEntry *t = NULL;
327 1300 size_t total_length = 0;
328
329
2/2
✓ Branch 1 taken 5120 times.
✓ Branch 2 taken 1300 times.
6420 while ((t = av_dict_iterate(dict, t))) {
330
2/2
✓ Branch 0 taken 10240 times.
✓ Branch 1 taken 5120 times.
15360 for (int i = 0; i < 2; i++) {
331
2/2
✓ Branch 0 taken 5120 times.
✓ Branch 1 taken 5120 times.
10240 const char *str = i ? t->value : t->key;
332 10240 const size_t len = strlen(str) + 1;
333
334
2/2
✓ Branch 0 taken 5120 times.
✓ Branch 1 taken 5120 times.
10240 if (pass)
335 5120 memcpy(data + total_length, str, len);
336
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 5120 times.
5120 else if (len > SIZE_MAX - total_length)
337 return NULL;
338 10240 total_length += len;
339 }
340 }
341
2/2
✓ Branch 0 taken 650 times.
✓ Branch 1 taken 650 times.
1300 if (pass)
342 650 break;
343 650 data = av_malloc(total_length);
344
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 650 times.
650 if (!data)
345 return NULL;
346 650 *size = total_length;
347 }
348
349 650 return data;
350 }
351
352 439236 int av_packet_unpack_dictionary(const uint8_t *data, size_t size,
353 AVDictionary **dict)
354 {
355 const uint8_t *end;
356 int ret;
357
358
5/6
✓ Branch 0 taken 439236 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 622 times.
✓ Branch 3 taken 438614 times.
✓ Branch 4 taken 20 times.
✓ Branch 5 taken 602 times.
439236 if (!dict || !data || !size)
359 438634 return 0;
360 602 end = data + size;
361
2/4
✓ Branch 0 taken 602 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 602 times.
602 if (size && end[-1])
362 return AVERROR_INVALIDDATA;
363
2/2
✓ Branch 0 taken 2516 times.
✓ Branch 1 taken 602 times.
3118 while (data < end) {
364 2516 const uint8_t *key = data;
365 2516 const uint8_t *val = data + strlen(key) + 1;
366
367
2/4
✓ Branch 0 taken 2516 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2516 times.
2516 if (val >= end || !*key)
368 return AVERROR_INVALIDDATA;
369
370 2516 ret = av_dict_set(dict, key, val, 0);
371
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 2516 times.
2516 if (ret < 0)
372 return ret;
373 2516 data = val + strlen(val) + 1;
374 }
375
376 602 return 0;
377 }
378
379 int av_packet_shrink_side_data(AVPacket *pkt, enum AVPacketSideDataType type,
380 size_t size)
381 {
382 int i;
383
384 for (i = 0; i < pkt->side_data_elems; i++) {
385 if (pkt->side_data[i].type == type) {
386 if (size > pkt->side_data[i].size)
387 return AVERROR(ENOMEM);
388 pkt->side_data[i].size = size;
389 return 0;
390 }
391 }
392 return AVERROR(ENOENT);
393 }
394
395 861304 int av_packet_copy_props(AVPacket *dst, const AVPacket *src)
396 {
397 int i, ret;
398
399 861304 dst->pts = src->pts;
400 861304 dst->dts = src->dts;
401 861304 dst->pos = src->pos;
402 861304 dst->duration = src->duration;
403 861304 dst->flags = src->flags;
404 861304 dst->stream_index = src->stream_index;
405 861304 dst->opaque = src->opaque;
406 861304 dst->time_base = src->time_base;
407 861304 dst->opaque_ref = NULL;
408 861304 dst->side_data = NULL;
409 861304 dst->side_data_elems = 0;
410
411 861304 ret = av_buffer_replace(&dst->opaque_ref, src->opaque_ref);
412
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 861304 times.
861304 if (ret < 0)
413 return ret;
414
415
2/2
✓ Branch 0 taken 22492 times.
✓ Branch 1 taken 861304 times.
883796 for (i = 0; i < src->side_data_elems; i++) {
416 22492 enum AVPacketSideDataType type = src->side_data[i].type;
417 22492 size_t size = src->side_data[i].size;
418 22492 uint8_t *src_data = src->side_data[i].data;
419 22492 uint8_t *dst_data = av_packet_new_side_data(dst, type, size);
420
421
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 22492 times.
22492 if (!dst_data) {
422 av_buffer_unref(&dst->opaque_ref);
423 av_packet_free_side_data(dst);
424 return AVERROR(ENOMEM);
425 }
426 22492 memcpy(dst_data, src_data, size);
427 }
428
429 861304 return 0;
430 }
431
432 8679020 void av_packet_unref(AVPacket *pkt)
433 {
434 8679020 av_packet_free_side_data(pkt);
435 8679020 av_buffer_unref(&pkt->opaque_ref);
436 8679020 av_buffer_unref(&pkt->buf);
437 8679020 get_packet_defaults(pkt);
438 8679020 }
439
440 427789 int av_packet_ref(AVPacket *dst, const AVPacket *src)
441 {
442 int ret;
443
444 427789 dst->buf = NULL;
445
446 427789 ret = av_packet_copy_props(dst, src);
447
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 427789 times.
427789 if (ret < 0)
448 goto fail;
449
450
2/2
✓ Branch 0 taken 1030 times.
✓ Branch 1 taken 426759 times.
427789 if (!src->buf) {
451 1030 ret = packet_alloc(&dst->buf, src->size);
452
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 1030 times.
1030 if (ret < 0)
453 goto fail;
454 av_assert1(!src->size || src->data);
455
1/2
✓ Branch 0 taken 1030 times.
✗ Branch 1 not taken.
1030 if (src->size)
456 1030 memcpy(dst->buf->data, src->data, src->size);
457
458 1030 dst->data = dst->buf->data;
459 } else {
460 426759 dst->buf = av_buffer_ref(src->buf);
461
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 426759 times.
426759 if (!dst->buf) {
462 ret = AVERROR(ENOMEM);
463 goto fail;
464 }
465 426759 dst->data = src->data;
466 }
467
468 427789 dst->size = src->size;
469
470 427789 return 0;
471 fail:
472 av_packet_unref(dst);
473 return ret;
474 }
475
476 6 AVPacket *av_packet_clone(const AVPacket *src)
477 {
478 6 AVPacket *ret = av_packet_alloc();
479
480
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 6 times.
6 if (!ret)
481 return ret;
482
483
1/2
✗ Branch 1 not taken.
✓ Branch 2 taken 6 times.
6 if (av_packet_ref(ret, src))
484 av_packet_free(&ret);
485
486 6 return ret;
487 }
488
489 3981908 void av_packet_move_ref(AVPacket *dst, AVPacket *src)
490 {
491 3981908 *dst = *src;
492 3981908 get_packet_defaults(src);
493 3981908 }
494
495 2199467 int av_packet_make_refcounted(AVPacket *pkt)
496 {
497 int ret;
498
499
2/2
✓ Branch 0 taken 2036146 times.
✓ Branch 1 taken 163321 times.
2199467 if (pkt->buf)
500 2036146 return 0;
501
502 163321 ret = packet_alloc(&pkt->buf, pkt->size);
503
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 163321 times.
163321 if (ret < 0)
504 return ret;
505 av_assert1(!pkt->size || pkt->data);
506
2/2
✓ Branch 0 taken 161761 times.
✓ Branch 1 taken 1560 times.
163321 if (pkt->size)
507 161761 memcpy(pkt->buf->data, pkt->data, pkt->size);
508
509 163321 pkt->data = pkt->buf->data;
510
511 163321 return 0;
512 }
513
514 142 int av_packet_make_writable(AVPacket *pkt)
515 {
516 142 AVBufferRef *buf = NULL;
517 int ret;
518
519
2/4
✓ Branch 0 taken 142 times.
✗ Branch 1 not taken.
✓ Branch 3 taken 142 times.
✗ Branch 4 not taken.
142 if (pkt->buf && av_buffer_is_writable(pkt->buf))
520 142 return 0;
521
522 ret = packet_alloc(&buf, pkt->size);
523 if (ret < 0)
524 return ret;
525 av_assert1(!pkt->size || pkt->data);
526 if (pkt->size)
527 memcpy(buf->data, pkt->data, pkt->size);
528
529 av_buffer_unref(&pkt->buf);
530 pkt->buf = buf;
531 pkt->data = buf->data;
532
533 return 0;
534 }
535
536 557814 void av_packet_rescale_ts(AVPacket *pkt, AVRational src_tb, AVRational dst_tb)
537 {
538
2/2
✓ Branch 0 taken 542245 times.
✓ Branch 1 taken 15569 times.
557814 if (pkt->pts != AV_NOPTS_VALUE)
539 542245 pkt->pts = av_rescale_q(pkt->pts, src_tb, dst_tb);
540
2/2
✓ Branch 0 taken 557798 times.
✓ Branch 1 taken 16 times.
557814 if (pkt->dts != AV_NOPTS_VALUE)
541 557798 pkt->dts = av_rescale_q(pkt->dts, src_tb, dst_tb);
542
2/2
✓ Branch 0 taken 538674 times.
✓ Branch 1 taken 19140 times.
557814 if (pkt->duration > 0)
543 538674 pkt->duration = av_rescale_q(pkt->duration, src_tb, dst_tb);
544 557814 }
545
546 479761 int avpriv_packet_list_put(PacketList *packet_buffer,
547 AVPacket *pkt,
548 int (*copy)(AVPacket *dst, const AVPacket *src),
549 int flags)
550 {
551 479761 PacketListEntry *pktl = av_malloc(sizeof(*pktl));
552 479761 unsigned int update_end_point = 1;
553 int ret;
554
555
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 479761 times.
479761 if (!pktl)
556 return AVERROR(ENOMEM);
557
558
2/2
✓ Branch 0 taken 124 times.
✓ Branch 1 taken 479637 times.
479761 if (copy) {
559 124 get_packet_defaults(&pktl->pkt);
560 124 ret = copy(&pktl->pkt, pkt);
561
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 124 times.
124 if (ret < 0) {
562 av_free(pktl);
563 return ret;
564 }
565 } else {
566 479637 ret = av_packet_make_refcounted(pkt);
567
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 479637 times.
479637 if (ret < 0) {
568 av_free(pktl);
569 return ret;
570 }
571 479637 av_packet_move_ref(&pktl->pkt, pkt);
572 }
573
574 479761 pktl->next = NULL;
575
576
2/2
✓ Branch 0 taken 299354 times.
✓ Branch 1 taken 180407 times.
479761 if (packet_buffer->head) {
577
2/2
✓ Branch 0 taken 20 times.
✓ Branch 1 taken 299334 times.
299354 if (flags & FF_PACKETLIST_FLAG_PREPEND) {
578 20 pktl->next = packet_buffer->head;
579 20 packet_buffer->head = pktl;
580 20 update_end_point = 0;
581 } else {
582 299334 packet_buffer->tail->next = pktl;
583 }
584 } else
585 180407 packet_buffer->head = pktl;
586
587
2/2
✓ Branch 0 taken 479741 times.
✓ Branch 1 taken 20 times.
479761 if (update_end_point) {
588 /* Add the packet in the buffered packet list. */
589 479741 packet_buffer->tail = pktl;
590 }
591
592 479761 return 0;
593 }
594
595 429809 int avpriv_packet_list_get(PacketList *pkt_buffer,
596 AVPacket *pkt)
597 {
598 429809 PacketListEntry *pktl = pkt_buffer->head;
599
2/2
✓ Branch 0 taken 54 times.
✓ Branch 1 taken 429755 times.
429809 if (!pktl)
600 54 return AVERROR(EAGAIN);
601 429755 *pkt = pktl->pkt;
602 429755 pkt_buffer->head = pktl->next;
603
2/2
✓ Branch 0 taken 176352 times.
✓ Branch 1 taken 253403 times.
429755 if (!pkt_buffer->head)
604 176352 pkt_buffer->tail = NULL;
605 429755 av_freep(&pktl);
606 429755 return 0;
607 }
608
609 56393 void avpriv_packet_list_free(PacketList *pkt_buf)
610 {
611 56393 PacketListEntry *tmp = pkt_buf->head;
612
613
2/2
✓ Branch 0 taken 79925 times.
✓ Branch 1 taken 56393 times.
136318 while (tmp) {
614 79925 PacketListEntry *pktl = tmp;
615 79925 tmp = pktl->next;
616 79925 av_packet_unref(&pktl->pkt);
617 79925 av_freep(&pktl);
618 }
619 56393 pkt_buf->head = pkt_buf->tail = NULL;
620 56393 }
621
622 int ff_side_data_set_prft(AVPacket *pkt, int64_t timestamp)
623 {
624 AVProducerReferenceTime *prft;
625 uint8_t *side_data;
626 size_t side_data_size;
627
628 side_data = av_packet_get_side_data(pkt, AV_PKT_DATA_PRFT, &side_data_size);
629 if (!side_data) {
630 side_data_size = sizeof(AVProducerReferenceTime);
631 side_data = av_packet_new_side_data(pkt, AV_PKT_DATA_PRFT, side_data_size);
632 }
633
634 if (!side_data || side_data_size < sizeof(AVProducerReferenceTime))
635 return AVERROR(ENOMEM);
636
637 prft = (AVProducerReferenceTime *)side_data;
638 prft->wallclock = timestamp;
639 prft->flags = 0;
640
641 return 0;
642 }
643
644 1151941 const AVPacketSideData *av_packet_side_data_get(const AVPacketSideData *sd, int nb_sd,
645 enum AVPacketSideDataType type)
646 {
647
2/2
✓ Branch 0 taken 65664 times.
✓ Branch 1 taken 1151836 times.
1217500 for (int i = 0; i < nb_sd; i++)
648
2/2
✓ Branch 0 taken 105 times.
✓ Branch 1 taken 65559 times.
65664 if (sd[i].type == type)
649 105 return &sd[i];
650
651 1151836 return NULL;
652 }
653
654 858 static AVPacketSideData *packet_side_data_add(AVPacketSideData **psd, int *pnb_sd,
655 enum AVPacketSideDataType type,
656 void *data, size_t size)
657 {
658 858 AVPacketSideData *sd = *psd, *tmp;
659 858 int nb_sd = *pnb_sd;
660
661
2/2
✓ Branch 0 taken 69 times.
✓ Branch 1 taken 857 times.
926 for (int i = 0; i < nb_sd; i++) {
662
2/2
✓ Branch 0 taken 68 times.
✓ Branch 1 taken 1 times.
69 if (sd[i].type != type)
663 68 continue;
664
665 1 av_free(sd[i].data);
666 1 sd[i].data = data;
667 1 sd[i].size = size;
668 1 return &sd[i];
669 }
670
671
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 857 times.
857 if (nb_sd == INT_MAX)
672 return NULL;
673
674 857 tmp = av_realloc_array(sd, nb_sd + 1, sizeof(*tmp));
675
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 857 times.
857 if (!tmp)
676 return NULL;
677
678 857 *psd = sd = tmp;
679 857 sd[nb_sd].type = type;
680 857 sd[nb_sd].data = data;
681 857 sd[nb_sd].size = size;
682 857 *pnb_sd = nb_sd + 1;
683
684 857 return &sd[nb_sd];
685 }
686
687 488 AVPacketSideData *av_packet_side_data_add(AVPacketSideData **psd, int *pnb_sd,
688 enum AVPacketSideDataType type,
689 void *data, size_t size, int flags)
690 {
691 488 return packet_side_data_add(psd, pnb_sd, type, data, size);
692 }
693
694 370 AVPacketSideData *av_packet_side_data_new(AVPacketSideData **psd, int *pnb_sd,
695 enum AVPacketSideDataType type,
696 size_t size, int flags)
697 {
698 370 AVPacketSideData *sd = NULL;
699 uint8_t *data;
700
701
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 370 times.
370 if (size > SIZE_MAX - AV_INPUT_BUFFER_PADDING_SIZE)
702 return NULL;
703
704 370 data = av_malloc(size + AV_INPUT_BUFFER_PADDING_SIZE);
705
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 370 times.
370 if (!data)
706 return NULL;
707 370 memset(data + size, 0, AV_INPUT_BUFFER_PADDING_SIZE);
708
709 370 sd = packet_side_data_add(psd, pnb_sd, type, data, size);
710
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 370 times.
370 if (!sd)
711 av_freep(&data);
712
713 370 return sd;
714 }
715
716 1 void av_packet_side_data_remove(AVPacketSideData *sd, int *pnb_sd,
717 enum AVPacketSideDataType type)
718 {
719 1 int nb_sd = *pnb_sd;
720
721
1/2
✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
1 for (int i = nb_sd - 1; i >= 0; i--) {
722
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 1 times.
1 if (sd[i].type != type)
723 continue;
724 1 av_free(sd[i].data);
725 1 sd[i] = sd[--nb_sd];
726 1 break;
727 }
728
729 1 *pnb_sd = nb_sd;
730 1 }
731
732 336271 void av_packet_side_data_free(AVPacketSideData **psd, int *pnb_sd)
733 {
734 336271 AVPacketSideData *sd = *psd;
735 336271 int nb_sd = *pnb_sd;
736
737
2/2
✓ Branch 0 taken 5152 times.
✓ Branch 1 taken 336271 times.
341423 for (int i = 0; i < nb_sd; i++)
738 5152 av_free(sd[i].data);
739
740 336271 av_freep(psd);
741 336271 *pnb_sd = 0;
742 336271 }
743
744 68968 static void *container_packet_alloc(void *opaque)
745 {
746 68968 return av_packet_alloc();
747 }
748
749 1020929 static void container_packet_reset(void *opaque, void *obj)
750 {
751 1020929 av_packet_unref(obj);
752 1020929 }
753
754 68968 static void container_packet_free(void *opaque, void *obj)
755 {
756 68968 AVPacket *pkt = obj;
757 68968 av_packet_free(&pkt);
758 68968 }
759
760 2013708 static int container_packet_transfer(void *opaque, void *dst, void *src, unsigned flags)
761 {
762
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 2013708 times.
2013708 if (flags & AV_CONTAINER_FIFO_FLAG_REF)
763 return av_packet_ref(dst, src);
764
765 2013708 av_packet_move_ref(dst, src);
766 2013708 return 0;
767 }
768
769 15589 AVContainerFifo *av_container_fifo_alloc_avpacket(unsigned flags)
770 {
771 15589 return av_container_fifo_alloc(NULL, container_packet_alloc,
772 container_packet_reset, container_packet_free,
773 container_packet_transfer, 0);
774 }
775