From 6d01a97c864a1d7e087b7669caf1df0a6e2caf99 Mon Sep 17 00:00:00 2001 From: Tomas Härdin Date: Fri, 11 Dec 2009 23:56:49 +0000 Subject: Fail earlier for unsupported resolutions or pixel formats when encoding dv. MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Patch by Tomas Härdin, tomas D hardin A codemill D se Originally committed as revision 20803 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavcodec/dv.c | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) (limited to 'libavcodec') diff --git a/libavcodec/dv.c b/libavcodec/dv.c index 91b1c80522..1219bf1070 100644 --- a/libavcodec/dv.c +++ b/libavcodec/dv.c @@ -398,6 +398,17 @@ static av_cold int dvvideo_init(AVCodecContext *avctx) return 0; } +static av_cold int dvvideo_init_encoder(AVCodecContext *avctx) +{ + if (!ff_dv_codec_profile(avctx)) { + av_log(avctx, AV_LOG_ERROR, "Found no DV profile for %ix%i %s video\n", + avctx->width, avctx->height, avcodec_get_pix_fmt_name(avctx->pix_fmt)); + return -1; + } + + return dvvideo_init(avctx); +} + // #define VLC_DEBUG // #define printf(...) av_log(NULL, AV_LOG_ERROR, __VA_ARGS__) @@ -1326,7 +1337,7 @@ AVCodec dvvideo_encoder = { CODEC_TYPE_VIDEO, CODEC_ID_DVVIDEO, sizeof(DVVideoContext), - dvvideo_init, + dvvideo_init_encoder, dvvideo_encode_frame, .pix_fmts = (const enum PixelFormat[]) {PIX_FMT_YUV411P, PIX_FMT_YUV422P, PIX_FMT_YUV420P, PIX_FMT_NONE}, .long_name = NULL_IF_CONFIG_SMALL("DV (Digital Video)"), -- cgit v1.2.3