Mercurial > libavformat.hg
changeset 6436:505105fc99ab libavformat
move h263 demuxer to its own file
author | aurel |
---|---|
date | Sun, 29 Aug 2010 21:34:18 +0000 |
parents | 67433b0c29d5 |
children | c0f18afd0074 |
files | Makefile h263dec.c raw.c |
diffstat | 3 files changed, 78 insertions(+), 59 deletions(-) [+] |
line wrap: on
line diff
--- a/Makefile Sun Aug 29 21:28:51 2010 +0000 +++ b/Makefile Sun Aug 29 21:34:18 2010 +0000 @@ -87,7 +87,7 @@ OBJS-$(CONFIG_GXF_MUXER) += gxfenc.o audiointerleave.o OBJS-$(CONFIG_H261_DEMUXER) += raw.o OBJS-$(CONFIG_H261_MUXER) += raw.o -OBJS-$(CONFIG_H263_DEMUXER) += raw.o +OBJS-$(CONFIG_H263_DEMUXER) += h263dec.o raw.o OBJS-$(CONFIG_H263_MUXER) += raw.o OBJS-$(CONFIG_H264_DEMUXER) += h264dec.o raw.o OBJS-$(CONFIG_H264_MUXER) += raw.o
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/h263dec.c Sun Aug 29 21:34:18 2010 +0000 @@ -0,0 +1,77 @@ +/* + * RAW H.263 video demuxer + * Copyright (c) 2009 Michael Niedermayer <michaelni@gmx.at> + * + * This file is part of FFmpeg. + * + * FFmpeg is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * FFmpeg is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with FFmpeg; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + */ + +#include "avformat.h" +#include "raw.h" + +static int h263_probe(AVProbeData *p) +{ + uint64_t code= -1; + int i; + int valid_psc=0; + int invalid_psc=0; + int res_change=0; + int src_fmt, last_src_fmt=-1; + int last_gn=0; + + for(i=0; i<p->buf_size; i++){ + code = (code<<8) + p->buf[i]; + if ((code & 0xfffffc0000) == 0x800000) { + src_fmt= (code>>2)&3; + if( src_fmt != last_src_fmt + && last_src_fmt>0 && last_src_fmt<6 + && src_fmt<6) + res_change++; + + if((code&0x300)==0x200 && src_fmt){ + valid_psc++; + last_gn=0; + }else + invalid_psc++; + last_src_fmt= src_fmt; + } else if((code & 0xffff800000) == 0x800000) { + int gn= (code>>(23-5)) & 0x1F; + if(gn<last_gn){ + invalid_psc++; + }else + last_gn= gn; + } + } +//av_log(NULL, AV_LOG_ERROR, "h263_probe: psc:%d invalid:%d res_change:%d\n", valid_psc, invalid_psc, res_change); +//h263_probe: psc:3 invalid:0 res_change:0 (1588/recent_ffmpeg_parses_mpg_incorrectly.mpg) + if(valid_psc > 2*invalid_psc + 2*res_change + 3){ + return 50; + }else if(valid_psc > 2*invalid_psc) + return 25; + return 0; +} + +AVInputFormat h263_demuxer = { + "h263", + NULL_IF_CONFIG_SMALL("raw H.263"), + 0, + h263_probe, + ff_raw_video_read_header, + ff_raw_read_partial_packet, + .flags= AVFMT_GENERIC_INDEX, +// .extensions = "h263", //FIXME remove after writing mpeg4_probe + .value = CODEC_ID_H263, +};
--- a/raw.c Sun Aug 29 21:28:51 2010 +0000 +++ b/raw.c Sun Aug 29 21:34:18 2010 +0000 @@ -241,50 +241,6 @@ } #endif -#if CONFIG_H263_DEMUXER -static int h263_probe(AVProbeData *p) -{ - uint64_t code= -1; - int i; - int valid_psc=0; - int invalid_psc=0; - int res_change=0; - int src_fmt, last_src_fmt=-1; - int last_gn=0; - - for(i=0; i<p->buf_size; i++){ - code = (code<<8) + p->buf[i]; - if ((code & 0xfffffc0000) == 0x800000) { - src_fmt= (code>>2)&3; - if( src_fmt != last_src_fmt - && last_src_fmt>0 && last_src_fmt<6 - && src_fmt<6) - res_change++; - - if((code&0x300)==0x200 && src_fmt){ - valid_psc++; - last_gn=0; - }else - invalid_psc++; - last_src_fmt= src_fmt; - } else if((code & 0xffff800000) == 0x800000) { - int gn= (code>>(23-5)) & 0x1F; - if(gn<last_gn){ - invalid_psc++; - }else - last_gn= gn; - } - } -//av_log(NULL, AV_LOG_ERROR, "h263_probe: psc:%d invalid:%d res_change:%d\n", valid_psc, invalid_psc, res_change); -//h263_probe: psc:3 invalid:0 res_change:0 (1588/recent_ffmpeg_parses_mpg_incorrectly.mpg) - if(valid_psc > 2*invalid_psc + 2*res_change + 3){ - return 50; - }else if(valid_psc > 2*invalid_psc) - return 25; - return 0; -} -#endif - #if CONFIG_H261_DEMUXER static int h261_probe(AVProbeData *p) { @@ -586,20 +542,6 @@ }; #endif -#if CONFIG_H263_DEMUXER -AVInputFormat h263_demuxer = { - "h263", - NULL_IF_CONFIG_SMALL("raw H.263"), - 0, - h263_probe, - ff_raw_video_read_header, - ff_raw_read_partial_packet, - .flags= AVFMT_GENERIC_INDEX, -// .extensions = "h263", //FIXME remove after writing mpeg4_probe - .value = CODEC_ID_H263, -}; -#endif - #if CONFIG_H263_MUXER AVOutputFormat h263_muxer = { "h263",