[FFmpeg-devel] [PATCH 07/11] examples/extract_mvs: Do not use stack packet
Andreas Rheinhardt
andreas.rheinhardt at outlook.com
Sat Sep 4 02:18:09 EEST 2021
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt at outlook.com>
---
doc/examples/extract_mvs.c | 18 +++++++++++++-----
1 file changed, 13 insertions(+), 5 deletions(-)
diff --git a/doc/examples/extract_mvs.c b/doc/examples/extract_mvs.c
index 84f071075a..cc1311da91 100644
--- a/doc/examples/extract_mvs.c
+++ b/doc/examples/extract_mvs.c
@@ -124,7 +124,7 @@ static int open_codec_context(AVFormatContext *fmt_ctx, enum AVMediaType type)
int main(int argc, char **argv)
{
int ret = 0;
- AVPacket pkt = { 0 };
+ AVPacket *pkt = NULL;
if (argc != 2) {
fprintf(stderr, "Usage: %s <video>\n", argv[0]);
@@ -159,13 +159,20 @@ int main(int argc, char **argv)
goto end;
}
+ pkt = av_packet_alloc();
+ if (!pkt) {
+ fprintf(stderr, "Could not allocate AVPacket\n");
+ ret = AVERROR(ENOMEM);
+ goto end;
+ }
+
printf("framenum,source,blockw,blockh,srcx,srcy,dstx,dsty,flags\n");
/* read frames from the file */
- while (av_read_frame(fmt_ctx, &pkt) >= 0) {
- if (pkt.stream_index == video_stream_idx)
- ret = decode_packet(&pkt);
- av_packet_unref(&pkt);
+ while (av_read_frame(fmt_ctx, pkt) >= 0) {
+ if (pkt->stream_index == video_stream_idx)
+ ret = decode_packet(pkt);
+ av_packet_unref(pkt);
if (ret < 0)
break;
}
@@ -177,5 +184,6 @@ end:
avcodec_free_context(&video_dec_ctx);
avformat_close_input(&fmt_ctx);
av_frame_free(&frame);
+ av_packet_free(&pkt);
return ret < 0;
}
--
2.30.2
More information about the ffmpeg-devel
mailing list