[FFmpeg-cvslog] a64multienc: use the AVFrame API properly.
Anton Khirnov
git at videolan.org
Sun Nov 17 00:20:34 CET 2013
ffmpeg | branch: master | Anton Khirnov <anton at khirnov.net> | Sat Nov 9 10:14:46 2013 +0100| [13e9cc9ce0646ba8e31d837b5e6372ec80fa7a73] | committer: Anton Khirnov
a64multienc: use the AVFrame API properly.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=13e9cc9ce0646ba8e31d837b5e6372ec80fa7a73
---
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 d5f8e9a..65c1d30 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 f2c6c4a..11d6e2c 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;
More information about the ffmpeg-cvslog
mailing list