Merge remote-tracking branch 'qatar/master'
* qatar/master: swscale: convert yuv2yuvX() to using named arguments. swscale: rename "dstw" to "w" to prevent name collisions. swscale: use named registers in yuv2yuv1_plane() place. lavf: fix aspect ratio mismatch message. avconv: set AVFormatContext.duration from '-t' cljr: implement encode2. cljr: set the properties of the coded_frame, not input frame. dnxhdenc: switch to encode2. bmpenc: switch to encode2(). Conflicts: libavcodec/bmpenc.c libavcodec/cljr.c libavformat/utils.c tests/ref/vsynth1/cljr tests/ref/vsynth2/cljr Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
@@ -29,6 +29,7 @@
|
||||
#include "libavutil/opt.h"
|
||||
#include "avcodec.h"
|
||||
#include "dsputil.h"
|
||||
#include "internal.h"
|
||||
#include "mpegvideo.h"
|
||||
#include "mpegvideo_common.h"
|
||||
#include "dnxhdenc.h"
|
||||
@@ -901,18 +902,21 @@ static void dnxhd_load_picture(DNXHDEncContext *ctx, const AVFrame *frame)
|
||||
ctx->cur_field = frame->interlaced_frame && !frame->top_field_first;
|
||||
}
|
||||
|
||||
static int dnxhd_encode_picture(AVCodecContext *avctx, unsigned char *buf, int buf_size, void *data)
|
||||
static int dnxhd_encode_picture(AVCodecContext *avctx, AVPacket *pkt,
|
||||
const AVFrame *frame, int *got_packet)
|
||||
{
|
||||
DNXHDEncContext *ctx = avctx->priv_data;
|
||||
int first_field = 1;
|
||||
int offset, i, ret;
|
||||
uint8_t *buf;
|
||||
|
||||
if (buf_size < ctx->cid_table->frame_size) {
|
||||
if ((ret = ff_alloc_packet(pkt, ctx->cid_table->frame_size)) < 0) {
|
||||
av_log(avctx, AV_LOG_ERROR, "output buffer is too small to compress picture\n");
|
||||
return -1;
|
||||
return ret;
|
||||
}
|
||||
buf = pkt->data;
|
||||
|
||||
dnxhd_load_picture(ctx, data);
|
||||
dnxhd_load_picture(ctx, frame);
|
||||
|
||||
encode_coding_unit:
|
||||
for (i = 0; i < 3; i++) {
|
||||
@@ -953,13 +957,14 @@ static int dnxhd_encode_picture(AVCodecContext *avctx, unsigned char *buf, int b
|
||||
first_field = 0;
|
||||
ctx->cur_field ^= 1;
|
||||
buf += ctx->cid_table->coding_unit_size;
|
||||
buf_size -= ctx->cid_table->coding_unit_size;
|
||||
goto encode_coding_unit;
|
||||
}
|
||||
|
||||
ctx->frame.quality = ctx->qscale*FF_QP2LAMBDA;
|
||||
|
||||
return ctx->cid_table->frame_size;
|
||||
pkt->flags |= AV_PKT_FLAG_KEY;
|
||||
*got_packet = 1;
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int dnxhd_encode_end(AVCodecContext *avctx)
|
||||
@@ -1002,7 +1007,7 @@ AVCodec ff_dnxhd_encoder = {
|
||||
.id = CODEC_ID_DNXHD,
|
||||
.priv_data_size = sizeof(DNXHDEncContext),
|
||||
.init = dnxhd_encode_init,
|
||||
.encode = dnxhd_encode_picture,
|
||||
.encode2 = dnxhd_encode_picture,
|
||||
.close = dnxhd_encode_end,
|
||||
.capabilities = CODEC_CAP_SLICE_THREADS,
|
||||
.pix_fmts = (const enum PixelFormat[]){PIX_FMT_YUV422P, PIX_FMT_YUV422P10, PIX_FMT_NONE},
|
||||
|
||||
Reference in New Issue
Block a user