Commit 3244a176 authored by Michael Niedermayer's avatar Michael Niedermayer

Merge commit '9bb11be0'

* commit '9bb11be0':
  mpegvideo: Split picture allocation for encoding and decoding

Conflicts:
	libavcodec/mpegvideo.c
Merged-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parents b18eac7f 9bb11be0
This diff is collapsed.
...@@ -748,7 +748,11 @@ void ff_mpv_motion(MpegEncContext *s, ...@@ -748,7 +748,11 @@ void ff_mpv_motion(MpegEncContext *s,
* Allocate a Picture. * Allocate a Picture.
* The pixels are allocated/set by calling get_buffer() if shared = 0. * The pixels are allocated/set by calling get_buffer() if shared = 0.
*/ */
int ff_alloc_picture(MpegEncContext *s, Picture *pic, int shared); int ff_alloc_picture(AVCodecContext *avctx, Picture *pic, MotionEstContext *me,
ScratchpadContext *sc, int shared, int encoding,
int chroma_x_shift, int chroma_y_shift, int out_format,
int mb_stride, int mb_width, int mb_height, int b8_stride,
ptrdiff_t *linesize, ptrdiff_t *uvlinesize);
int ff_mpeg_framesize_alloc(AVCodecContext *avctx, MotionEstContext *me, int ff_mpeg_framesize_alloc(AVCodecContext *avctx, MotionEstContext *me,
ScratchpadContext *sc, int linesize); ScratchpadContext *sc, int linesize);
......
...@@ -1075,6 +1075,13 @@ static int get_intra_count(MpegEncContext *s, uint8_t *src, ...@@ -1075,6 +1075,13 @@ static int get_intra_count(MpegEncContext *s, uint8_t *src,
return acc; return acc;
} }
static int alloc_picture(MpegEncContext *s, Picture *pic, int shared)
{
return ff_alloc_picture(s->avctx, pic, &s->me, &s->sc, shared, 1,
s->chroma_x_shift, s->chroma_y_shift, s->out_format,
s->mb_stride, s->mb_width, s->mb_height, s->b8_stride,
&s->linesize, &s->uvlinesize);
}
static int load_input_picture(MpegEncContext *s, const AVFrame *pic_arg) static int load_input_picture(MpegEncContext *s, const AVFrame *pic_arg)
{ {
...@@ -1144,7 +1151,7 @@ static int load_input_picture(MpegEncContext *s, const AVFrame *pic_arg) ...@@ -1144,7 +1151,7 @@ static int load_input_picture(MpegEncContext *s, const AVFrame *pic_arg)
if ((ret = av_frame_ref(pic->f, pic_arg)) < 0) if ((ret = av_frame_ref(pic->f, pic_arg)) < 0)
return ret; return ret;
} }
ret = ff_alloc_picture(s, pic, direct); ret = alloc_picture(s, pic, direct);
if (ret < 0) if (ret < 0)
return ret; return ret;
...@@ -1536,7 +1543,7 @@ no_output_pic: ...@@ -1536,7 +1543,7 @@ no_output_pic:
pic = &s->picture[i]; pic = &s->picture[i];
pic->reference = s->reordered_input_picture[0]->reference; pic->reference = s->reordered_input_picture[0]->reference;
if (ff_alloc_picture(s, pic, 0) < 0) { if (alloc_picture(s, pic, 0) < 0) {
return -1; return -1;
} }
......
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