Original thread: Date: Thu, 22 Mar 2007 20:23:08 -0400 Subject: [Ffmpeg-devel] [PATCH] Theora in MKV (GSoC '07 Qualification) Originally committed as revision 8505 to svn://svn.ffmpeg.org/ffmpeg/trunktags/v0.5
| @@ -156,7 +156,7 @@ OBJS-$(CONFIG_VCR1_ENCODER) += vcr1.o | |||||
| OBJS-$(CONFIG_VMDAUDIO_DECODER) += vmdav.o | OBJS-$(CONFIG_VMDAUDIO_DECODER) += vmdav.o | ||||
| OBJS-$(CONFIG_VMDVIDEO_DECODER) += vmdav.o | OBJS-$(CONFIG_VMDVIDEO_DECODER) += vmdav.o | ||||
| OBJS-$(CONFIG_VMNC_DECODER) += vmnc.o | OBJS-$(CONFIG_VMNC_DECODER) += vmnc.o | ||||
| OBJS-$(CONFIG_VORBIS_DECODER) += vorbis.o vorbis_data.o | |||||
| OBJS-$(CONFIG_VORBIS_DECODER) += vorbis.o vorbis_data.o xiph.o | |||||
| OBJS-$(CONFIG_VORBIS_ENCODER) += vorbis_enc.o vorbis.o vorbis_data.o | OBJS-$(CONFIG_VORBIS_ENCODER) += vorbis_enc.o vorbis.o vorbis_data.o | ||||
| OBJS-$(CONFIG_VP3_DECODER) += vp3.o | OBJS-$(CONFIG_VP3_DECODER) += vp3.o | ||||
| OBJS-$(CONFIG_VP5_DECODER) += vp5.o vp56.o vp56data.o | OBJS-$(CONFIG_VP5_DECODER) += vp5.o vp56.o vp56data.o | ||||
| @@ -33,6 +33,7 @@ | |||||
| #include "dsputil.h" | #include "dsputil.h" | ||||
| #include "vorbis.h" | #include "vorbis.h" | ||||
| #include "xiph.h" | |||||
| #define V_NB_BITS 8 | #define V_NB_BITS 8 | ||||
| #define V_NB_BITS2 11 | #define V_NB_BITS2 11 | ||||
| @@ -1039,7 +1040,7 @@ static int vorbis_decode_init(AVCodecContext *avccontext) { | |||||
| uint8_t *header_start[3]; | uint8_t *header_start[3]; | ||||
| int header_len[3]; | int header_len[3]; | ||||
| GetBitContext *gb = &(vc->gb); | GetBitContext *gb = &(vc->gb); | ||||
| int i, j, hdr_type; | |||||
| int hdr_type; | |||||
| vc->avccontext = avccontext; | vc->avccontext = avccontext; | ||||
| dsputil_init(&vc->dsp, avccontext); | dsputil_init(&vc->dsp, avccontext); | ||||
| @@ -1057,32 +1058,7 @@ static int vorbis_decode_init(AVCodecContext *avccontext) { | |||||
| return -1; | return -1; | ||||
| } | } | ||||
| if(headers[0] == 0 && headers[1] == 30) { | |||||
| for(i = 0; i < 3; i++){ | |||||
| header_len[i] = *headers++ << 8; | |||||
| header_len[i] += *headers++; | |||||
| header_start[i] = headers; | |||||
| headers += header_len[i]; | |||||
| } | |||||
| } else if(headers[0] == 2) { | |||||
| for(j=1,i=0;i<2;++i, ++j) { | |||||
| header_len[i]=0; | |||||
| while(j<headers_len && headers[j]==0xff) { | |||||
| header_len[i]+=0xff; | |||||
| ++j; | |||||
| } | |||||
| if (j>=headers_len) { | |||||
| av_log(avccontext, AV_LOG_ERROR, "Extradata corrupt.\n"); | |||||
| return -1; | |||||
| } | |||||
| header_len[i]+=headers[j]; | |||||
| } | |||||
| header_len[2]=headers_len-header_len[0]-header_len[1]-j; | |||||
| headers+=j; | |||||
| header_start[0] = headers; | |||||
| header_start[1] = header_start[0] + header_len[0]; | |||||
| header_start[2] = header_start[1] + header_len[1]; | |||||
| } else { | |||||
| if (ff_split_xiph_headers(headers, headers_len, 30, header_start, header_len) < 0) { | |||||
| av_log(avccontext, AV_LOG_ERROR, "Extradata corrupt.\n"); | av_log(avccontext, AV_LOG_ERROR, "Extradata corrupt.\n"); | ||||
| return -1; | return -1; | ||||
| } | } | ||||
| @@ -0,0 +1,56 @@ | |||||
| /* | |||||
| * Copyright (C) 2007 FFmpeg Project | |||||
| * | |||||
| * 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 "xiph.h" | |||||
| int ff_split_xiph_headers(uint8_t *extradata, int extradata_size, | |||||
| int first_header_size, uint8_t *header_start[3], | |||||
| int header_len[3]) | |||||
| { | |||||
| int i, j; | |||||
| if (AV_RB16(extradata) == first_header_size) { | |||||
| for (i=0; i<3; i++) { | |||||
| header_len[i] = AV_RB16(extradata); | |||||
| extradata += 2; | |||||
| header_start[i] = extradata; | |||||
| extradata += header_len[i]; | |||||
| } | |||||
| } else if (extradata[0] == 2) { | |||||
| for (i=0,j=1; i<2; i++,j++) { | |||||
| header_len[i] = 0; | |||||
| for (; j<extradata_size && extradata[j]==0xff; j++) { | |||||
| header_len[i] += 0xff; | |||||
| } | |||||
| if (j >= extradata_size) | |||||
| return -1; | |||||
| header_len[i] += extradata[j]; | |||||
| } | |||||
| header_len[2] = extradata_size - header_len[0] - header_len[1] - j; | |||||
| extradata += j; | |||||
| header_start[0] = extradata; | |||||
| header_start[1] = header_start[0] + header_len[0]; | |||||
| header_start[2] = header_start[1] + header_len[1]; | |||||
| } else { | |||||
| return -1; | |||||
| } | |||||
| return 0; | |||||
| } | |||||
| @@ -0,0 +1,38 @@ | |||||
| /* | |||||
| * Copyright (C) 2007 FFmpeg Project | |||||
| * | |||||
| * 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 "common.h" | |||||
| /** | |||||
| * Splits a single extradata buffer into the three headers that most | |||||
| * Xiph codecs use. (e.g. Theora and Vorbis) | |||||
| * Works both with Matroska's packing and lavc's packing. | |||||
| * | |||||
| * @param[in] extradata The single chunk that combines all three headers | |||||
| * @param[in] extradata_size The size of the extradata buffer | |||||
| * @param[in] first_header_size The size of the first header, used to | |||||
| * differentiate between the Matroska packing and lavc packing. | |||||
| * @param[out] header_start Pointers to the start of the three separate headers. | |||||
| * @param[out] header_len The sizes of each of the three headers. | |||||
| * @return On error a negative value is returned, on success zero. | |||||
| */ | |||||
| int ff_split_xiph_headers(uint8_t *extradata, int extradata_size, | |||||
| int first_header_size, uint8_t *header_start[3], | |||||
| int header_len[3]); | |||||