mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
mpegvideo: allocate edges when encoding.
Allocating edges will be removed from generic code, so the encoder must handle this explicitly.
This commit is contained in:
parent
f7e85ee996
commit
024db24912
@ -422,15 +422,21 @@ fail:
|
||||
*/
|
||||
static int alloc_frame_buffer(MpegEncContext *s, Picture *pic)
|
||||
{
|
||||
int edges_needed = av_codec_is_encoder(s->avctx->codec);
|
||||
int r, ret;
|
||||
|
||||
pic->tf.f = &pic->f;
|
||||
if (s->codec_id != AV_CODEC_ID_WMV3IMAGE &&
|
||||
s->codec_id != AV_CODEC_ID_VC1IMAGE &&
|
||||
s->codec_id != AV_CODEC_ID_MSS2)
|
||||
s->codec_id != AV_CODEC_ID_MSS2) {
|
||||
if (edges_needed) {
|
||||
pic->f.width = s->avctx->width + 2 * EDGE_WIDTH;
|
||||
pic->f.height = s->avctx->height + 2 * EDGE_WIDTH;
|
||||
}
|
||||
|
||||
r = ff_thread_get_buffer(s->avctx, &pic->tf,
|
||||
pic->reference ? AV_GET_BUFFER_FLAG_REF : 0);
|
||||
else {
|
||||
} else {
|
||||
pic->f.width = s->avctx->width;
|
||||
pic->f.height = s->avctx->height;
|
||||
pic->f.format = s->avctx->pix_fmt;
|
||||
@ -443,6 +449,18 @@ static int alloc_frame_buffer(MpegEncContext *s, Picture *pic)
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (edges_needed) {
|
||||
int i;
|
||||
for (i = 0; pic->f.data[i]; i++) {
|
||||
int offset = (EDGE_WIDTH >> (i ? s->chroma_y_shift : 0)) *
|
||||
pic->f.linesize[i] +
|
||||
(EDGE_WIDTH >> (i ? s->chroma_x_shift : 0));
|
||||
pic->f.data[i] += offset;
|
||||
}
|
||||
pic->f.width = s->avctx->width;
|
||||
pic->f.height = s->avctx->height;
|
||||
}
|
||||
|
||||
if (s->avctx->hwaccel) {
|
||||
assert(!pic->hwaccel_picture_private);
|
||||
if (s->avctx->hwaccel->priv_data_size) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user