summaryrefslogtreecommitdiff
path: root/libavcodec/rawenc.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-09-09 13:01:37 +0200
committerMichael Niedermayer <michaelni@gmx.at>2014-09-09 13:22:33 +0200
commit881f96c4c2ef0c0162f63a370cbfff3c1e1feb2a (patch)
treecd3053d0453d225b614c6183ae71135752dd9cbc /libavcodec/rawenc.c
parentb63052839a6b247bd13daab74a869c8f837eda84 (diff)
avcodec/rawenc: drop sizeof(AVFrame) dependency
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec/rawenc.c')
-rw-r--r--libavcodec/rawenc.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/libavcodec/rawenc.c b/libavcodec/rawenc.c
index c5d3d2e955..c579230013 100644
--- a/libavcodec/rawenc.c
+++ b/libavcodec/rawenc.c
@@ -35,8 +35,7 @@ static av_cold int raw_encode_init(AVCodecContext *avctx)
{
const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(avctx->pix_fmt);
- avctx->coded_frame = avctx->priv_data;
- avcodec_get_frame_defaults(avctx->coded_frame);
+ avctx->coded_frame = av_frame_alloc();
avctx->coded_frame->pict_type = AV_PICTURE_TYPE_I;
avctx->bits_per_coded_sample = av_get_bits_per_pixel(desc);
if(!avctx->codec_tag)
@@ -69,12 +68,18 @@ static int raw_encode(AVCodecContext *avctx, AVPacket *pkt,
return 0;
}
+static av_cold int raw_close(AVCodecContext *avctx)
+{
+ av_frame_free(&avctx->coded_frame);
+ return 0;
+}
+
AVCodec ff_rawvideo_encoder = {
.name = "rawvideo",
.long_name = NULL_IF_CONFIG_SMALL("raw video"),
.type = AVMEDIA_TYPE_VIDEO,
.id = AV_CODEC_ID_RAWVIDEO,
- .priv_data_size = sizeof(AVFrame),
.init = raw_encode_init,
.encode2 = raw_encode,
+ .close = raw_close,
};