ffmpeg | branch: master | Christophe Gisquet <christophe.gisq...@gmail.com> | Sat Oct 3 18:59:17 2015 +0200| [1f4ff53aea7c5090f31cd1323d95f7c407c9b2bb] | committer: Michael Niedermayer
dnxhddec: Introduce DNXHD_VARIABLE Currently not used, but will be used to indicate that a CIDEntry field is not set, because it is variable, and that checks should be adapted. Signed-off-by: Michael Niedermayer <mich...@niedermayer.cc> > http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=1f4ff53aea7c5090f31cd1323d95f7c407c9b2bb --- libavcodec/dnxhddata.h | 3 +++ libavcodec/dnxhddec.c | 6 ++++-- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/libavcodec/dnxhddata.h b/libavcodec/dnxhddata.h index ade0b0b..e960fc9 100644 --- a/libavcodec/dnxhddata.h +++ b/libavcodec/dnxhddata.h @@ -30,6 +30,9 @@ #define DNXHD_INTERLACED (1<<0) #define DNXHD_444 (1<<1) +/** Indicate that a CIDEntry value must be read in the bitstream */ +#define DNXHD_VARIABLE 0 + typedef struct CIDEntry { int cid; unsigned int width, height; diff --git a/libavcodec/dnxhddec.c b/libavcodec/dnxhddec.c index 713ce6a..f71977a 100644 --- a/libavcodec/dnxhddec.c +++ b/libavcodec/dnxhddec.c @@ -106,7 +106,8 @@ static int dnxhd_init_vlc(DNXHDContext *ctx, uint32_t cid) av_log(ctx->avctx, AV_LOG_ERROR, "unsupported cid %d\n", cid); return AVERROR(ENOSYS); } - if (ff_dnxhd_cid_table[index].bit_depth != ctx->bit_depth) { + if (ff_dnxhd_cid_table[index].bit_depth != ctx->bit_depth && + ff_dnxhd_cid_table[index].bit_depth != DNXHD_VARIABLE) { av_log(ctx->avctx, AV_LOG_ERROR, "bit depth mismatches %d %d\n", ff_dnxhd_cid_table[index].bit_depth, ctx->bit_depth); return AVERROR_INVALIDDATA; } @@ -228,7 +229,8 @@ static int dnxhd_decode_header(DNXHDContext *ctx, AVFrame *frame, // make sure profile size constraints are respected // DNx100 allows 1920->1440 and 1280->960 subsampling - if (ctx->width != ctx->cid_table->width) { + if (ctx->width != ctx->cid_table->width && + ctx->cid_table->width != DNXHD_VARIABLE) { av_reduce(&ctx->avctx->sample_aspect_ratio.num, &ctx->avctx->sample_aspect_ratio.den, ctx->width, ctx->cid_table->width, 255); _______________________________________________ ffmpeg-cvslog mailing list ffmpeg-cvslog@ffmpeg.org http://ffmpeg.org/mailman/listinfo/ffmpeg-cvslog