From 13e9cc9ce0646ba8e31d837b5e6372ec80fa7a73 Mon Sep 17 00:00:00 2001 From: Anton Khirnov Date: Sat, 9 Nov 2013 10:14:46 +0100 Subject: [PATCH] a64multienc: use the AVFrame API properly. --- libavcodec/a64enc.h | 3 --- libavcodec/a64multienc.c | 11 ++++++++--- 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/libavcodec/a64enc.h b/libavcodec/a64enc.h index d5f8e9ac99..65c1d30951 100644 --- a/libavcodec/a64enc.h +++ b/libavcodec/a64enc.h @@ -34,9 +34,6 @@ #define C64YRES 200 typedef struct A64Context { - /* general variables */ - AVFrame picture; - /* variables for multicolor modes */ AVLFG randctx; int mc_lifetime; diff --git a/libavcodec/a64multienc.c b/libavcodec/a64multienc.c index f2c6c4a357..11d6e2c300 100644 --- a/libavcodec/a64multienc.c +++ b/libavcodec/a64multienc.c @@ -165,6 +165,7 @@ static void render_charset(AVCodecContext *avctx, uint8_t *charset, static av_cold int a64multi_close_encoder(AVCodecContext *avctx) { A64Context *c = avctx->priv_data; + av_frame_free(&avctx->coded_frame); av_free(c->mc_meta_charset); av_free(c->mc_best_cb); av_free(c->mc_charset); @@ -216,8 +217,12 @@ static av_cold int a64multi_init_encoder(AVCodecContext *avctx) AV_WB32(avctx->extradata, c->mc_lifetime); AV_WB32(avctx->extradata + 16, INTERLACED); - avcodec_get_frame_defaults(&c->picture); - avctx->coded_frame = &c->picture; + avctx->coded_frame = av_frame_alloc(); + if (!avctx->coded_frame) { + a64multi_close_encoder(avctx); + return AVERROR(ENOMEM); + } + avctx->coded_frame->pict_type = AV_PICTURE_TYPE_I; avctx->coded_frame->key_frame = 1; if (!avctx->codec_tag) @@ -247,7 +252,7 @@ static int a64multi_encode_frame(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *pict, int *got_packet) { A64Context *c = avctx->priv_data; - AVFrame *const p = &c->picture; + AVFrame *const p = avctx->coded_frame; int frame; int x, y;