Commit 881f96c4 authored by Michael Niedermayer's avatar Michael Niedermayer

avcodec/rawenc: drop sizeof(AVFrame) dependency

Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent b6305283
...@@ -35,8 +35,7 @@ static av_cold int raw_encode_init(AVCodecContext *avctx) ...@@ -35,8 +35,7 @@ static av_cold int raw_encode_init(AVCodecContext *avctx)
{ {
const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(avctx->pix_fmt); const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(avctx->pix_fmt);
avctx->coded_frame = avctx->priv_data; avctx->coded_frame = av_frame_alloc();
avcodec_get_frame_defaults(avctx->coded_frame);
avctx->coded_frame->pict_type = AV_PICTURE_TYPE_I; avctx->coded_frame->pict_type = AV_PICTURE_TYPE_I;
avctx->bits_per_coded_sample = av_get_bits_per_pixel(desc); avctx->bits_per_coded_sample = av_get_bits_per_pixel(desc);
if(!avctx->codec_tag) if(!avctx->codec_tag)
...@@ -69,12 +68,18 @@ static int raw_encode(AVCodecContext *avctx, AVPacket *pkt, ...@@ -69,12 +68,18 @@ static int raw_encode(AVCodecContext *avctx, AVPacket *pkt,
return 0; return 0;
} }
static av_cold int raw_close(AVCodecContext *avctx)
{
av_frame_free(&avctx->coded_frame);
return 0;
}
AVCodec ff_rawvideo_encoder = { AVCodec ff_rawvideo_encoder = {
.name = "rawvideo", .name = "rawvideo",
.long_name = NULL_IF_CONFIG_SMALL("raw video"), .long_name = NULL_IF_CONFIG_SMALL("raw video"),
.type = AVMEDIA_TYPE_VIDEO, .type = AVMEDIA_TYPE_VIDEO,
.id = AV_CODEC_ID_RAWVIDEO, .id = AV_CODEC_ID_RAWVIDEO,
.priv_data_size = sizeof(AVFrame),
.init = raw_encode_init, .init = raw_encode_init,
.encode2 = raw_encode, .encode2 = raw_encode,
.close = raw_close,
}; };
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment