* qatar/master: fate: split off DPCM codec FATE tests into their own file fate: split off PCM codec FATE tests into their own file libvorbis: K&R reformatting cosmetics libmp3lame: K&R formatting cosmetics fate: Add a video test for xxan decoder mpegvideo_enc: K&R cosmetics (line 1000-2000). avconv: K&R cosmetics qt-faststart: Fix up indentation indeo4: remove two unused variables doxygen: cleanup style to support older doxy fate: add more tests for VC-1 decoder applehttpproto: Apply the same reload interval changes as for the demuxer applehttp: Use half the target duration as interval if the playlist didn't update applehttp: Use the last segment duration as reload interval lagarith: add decode support for arith rgb24 mode Conflicts: avconv.c libavcodec/libmp3lame.c libavcodec/mpegvideo_enc.c Merged-by: Michael Niedermayer <michaelni@gmx.at>tags/n0.10
| @@ -235,6 +235,8 @@ div.center img { | |||
| #footer { | |||
| margin: -10px 1em 0; | |||
| padding-top: 20px; | |||
| text-align: center; | |||
| font-size: small; | |||
| } | |||
| address.footer { | |||
| @@ -962,7 +964,7 @@ dl.citelist dd { | |||
| } | |||
| .tabs3 .tablist a { | |||
| padding: 0 10px; | |||
| padding-left: 10px; | |||
| } | |||
| @@ -981,19 +983,6 @@ h1 a, h2 a, h3 a { | |||
| color: inherit; | |||
| } | |||
| #banner, #top { | |||
| background-color: #BBC9D8; | |||
| border-bottom: 1px solid #7A96B3; | |||
| border-top: 1px solid #7A96B3; | |||
| position: relative; | |||
| text-align: center; | |||
| } | |||
| #banner img, #top img { | |||
| padding-bottom: 1px; | |||
| padding-top: 5px; | |||
| } | |||
| #body { | |||
| margin: 0 1em; | |||
| } | |||
| @@ -1041,12 +1030,12 @@ img { | |||
| border: 0; | |||
| } | |||
| #navrow1 { | |||
| .tabs { | |||
| margin-top: 12px; | |||
| border-top: 1px solid #5C665C; | |||
| } | |||
| #navrow1, #navrow2, #navrow3, #navrow4 { | |||
| .tabs, .tabs2, .tabs3, .tabs4 { | |||
| background-color: #738073; | |||
| border-bottom: 1px solid #5C665C; | |||
| border-left: 1px solid #5C665C; | |||
| @@ -1055,24 +1044,36 @@ img { | |||
| text-align: center; | |||
| } | |||
| #navrow1 a, #navrow2 a, #navrow3 a, #navrow4 a { | |||
| .tabs a, | |||
| .tabs2 a, | |||
| .tabs3 a, | |||
| .tabs4 a { | |||
| color: white; | |||
| padding: 0.3em; | |||
| text-decoration: none; | |||
| } | |||
| #navrow1 ul, #navrow2 ul, #navrow3 ul, #navrow4 ul { | |||
| .tabs ul, | |||
| .tabs2 ul, | |||
| .tabs3 ul, | |||
| .tabs4 ul { | |||
| padding: 0; | |||
| } | |||
| #navrow1 li.current a, #navrow2 li.current a, #navrow3 li.current a, #navrow4 li.current a { | |||
| .tabs li.current a, | |||
| .tabs2 li.current a, | |||
| .tabs3 li.current a, | |||
| .tabs4 li.current a { | |||
| background-color: #414141; | |||
| color: white; | |||
| text-decoration: none; | |||
| } | |||
| #navrow1 a:hover, #navrow2 a:hover, #navrow3 a:hover, #navrow4 a:hover { | |||
| .tabs a:hover, | |||
| .tabs2 a:hover, | |||
| .tabs3 a:hover, | |||
| .tabs4 a:hover { | |||
| background-color: #313131 !important; | |||
| color: white; | |||
| text-decoration: none; | |||
| @@ -1094,37 +1095,3 @@ pre { | |||
| #proj_desc { | |||
| font-size: 1.2em; | |||
| } | |||
| #repos { | |||
| margin-left: 1em; | |||
| margin-right: 1em; | |||
| border-collapse: collapse; | |||
| border: solid 1px #6A996A; | |||
| } | |||
| #repos th { | |||
| background-color: #7BB37B; | |||
| border: solid 1px #6A996A; | |||
| } | |||
| #repos td { | |||
| padding: 0.2em; | |||
| border: solid 1px #6A996A; | |||
| } | |||
| #distro_status { | |||
| margin-left: 1em; | |||
| margin-right: 1em; | |||
| border-collapse: collapse; | |||
| border: solid 1px #6A996A; | |||
| } | |||
| #distro_status th { | |||
| background-color: #7BB37B; | |||
| border: solid 1px #6A996A; | |||
| } | |||
| #distro_status td { | |||
| padding: 0.2em; | |||
| border: solid 1px #6A996A; | |||
| } | |||
| @@ -160,7 +160,7 @@ static inline int scale_tile_size(int def_size, int size_factor) | |||
| */ | |||
| static int decode_pic_hdr(IVI4DecContext *ctx, AVCodecContext *avctx) | |||
| { | |||
| int pic_size_indx, val, i, p; | |||
| int pic_size_indx, i, p; | |||
| IVIPicConfig pic_conf; | |||
| if (get_bits(&ctx->gb, 18) != 0x3FFF8) { | |||
| @@ -301,7 +301,7 @@ static int decode_pic_hdr(IVI4DecContext *ctx, AVCodecContext *avctx) | |||
| /* skip picture header extension if any */ | |||
| while (get_bits1(&ctx->gb)) { | |||
| av_dlog(avctx, "Pic hdr extension encountered!\n"); | |||
| val = get_bits(&ctx->gb, 8); | |||
| skip_bits(&ctx->gb, 8); | |||
| } | |||
| if (get_bits1(&ctx->gb)) { | |||
| @@ -325,7 +325,7 @@ static int decode_pic_hdr(IVI4DecContext *ctx, AVCodecContext *avctx) | |||
| static int decode_band_hdr(IVI4DecContext *ctx, IVIBandDesc *band, | |||
| AVCodecContext *avctx) | |||
| { | |||
| int plane, band_num, hdr_size, indx, transform_id, scan_indx; | |||
| int plane, band_num, indx, transform_id, scan_indx; | |||
| int i; | |||
| plane = get_bits(&ctx->gb, 2); | |||
| @@ -337,7 +337,10 @@ static int decode_band_hdr(IVI4DecContext *ctx, IVIBandDesc *band, | |||
| band->is_empty = get_bits1(&ctx->gb); | |||
| if (!band->is_empty) { | |||
| hdr_size = get_bits1(&ctx->gb) ? get_bits(&ctx->gb, 16) : 4; | |||
| /* skip header size | |||
| * If header size is not given, header size is 4 bytes. */ | |||
| if (get_bits1(&ctx->gb)) | |||
| skip_bits(&ctx->gb, 16); | |||
| band->is_halfpel = get_bits(&ctx->gb, 2); | |||
| if (band->is_halfpel >= 2) { | |||
| @@ -31,7 +31,7 @@ | |||
| #include "mpegaudio.h" | |||
| #include <lame/lame.h> | |||
| #define BUFFER_SIZE (7200 + 2*MPA_FRAME_SIZE + MPA_FRAME_SIZE/4) | |||
| #define BUFFER_SIZE (7200 + 2 * MPA_FRAME_SIZE + MPA_FRAME_SIZE / 4) | |||
| typedef struct Mp3AudioContext { | |||
| AVClass *class; | |||
| lame_global_flags *gfp; | |||
| @@ -62,17 +62,17 @@ static av_cold int MP3lame_encode_init(AVCodecContext *avctx) | |||
| lame_set_in_samplerate(s->gfp, avctx->sample_rate); | |||
| lame_set_out_samplerate(s->gfp, avctx->sample_rate); | |||
| lame_set_num_channels(s->gfp, avctx->channels); | |||
| if(avctx->compression_level == FF_COMPRESSION_DEFAULT) { | |||
| if (avctx->compression_level == FF_COMPRESSION_DEFAULT) { | |||
| lame_set_quality(s->gfp, 5); | |||
| } else { | |||
| lame_set_quality(s->gfp, avctx->compression_level); | |||
| } | |||
| lame_set_mode(s->gfp, s->stereo ? JOINT_STEREO : MONO); | |||
| lame_set_brate(s->gfp, avctx->bit_rate/1000); | |||
| if(avctx->flags & CODEC_FLAG_QSCALE) { | |||
| lame_set_brate(s->gfp, avctx->bit_rate / 1000); | |||
| if (avctx->flags & CODEC_FLAG_QSCALE) { | |||
| lame_set_brate(s->gfp, 0); | |||
| lame_set_VBR(s->gfp, vbr_default); | |||
| lame_set_VBR_quality(s->gfp, avctx->global_quality/(float)FF_QP2LAMBDA); | |||
| lame_set_VBR_quality(s->gfp, avctx->global_quality / (float)FF_QP2LAMBDA); | |||
| } | |||
| lame_set_bWriteVbrTag(s->gfp,0); | |||
| #if FF_API_LAME_GLOBAL_OPTS | |||
| @@ -82,14 +82,14 @@ static av_cold int MP3lame_encode_init(AVCodecContext *avctx) | |||
| if (lame_init_params(s->gfp) < 0) | |||
| goto err_close; | |||
| avctx->frame_size = lame_get_framesize(s->gfp); | |||
| avctx->frame_size = lame_get_framesize(s->gfp); | |||
| if(!(avctx->coded_frame= avcodec_alloc_frame())) { | |||
| lame_close(s->gfp); | |||
| return AVERROR(ENOMEM); | |||
| } | |||
| avctx->coded_frame->key_frame= 1; | |||
| avctx->coded_frame->key_frame = 1; | |||
| if(AV_SAMPLE_FMT_S32 == avctx->sample_fmt && s->stereo) { | |||
| int nelem = 2 * avctx->frame_size; | |||
| @@ -117,60 +117,62 @@ static const int sSampleRates[] = { | |||
| }; | |||
| static const int sBitRates[2][3][15] = { | |||
| { { 0, 32, 64, 96,128,160,192,224,256,288,320,352,384,416,448}, | |||
| { 0, 32, 48, 56, 64, 80, 96,112,128,160,192,224,256,320,384}, | |||
| { 0, 32, 40, 48, 56, 64, 80, 96,112,128,160,192,224,256,320} | |||
| { | |||
| { 0, 32, 64, 96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448 }, | |||
| { 0, 32, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384 }, | |||
| { 0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320 } | |||
| }, | |||
| { { 0, 32, 48, 56, 64, 80, 96,112,128,144,160,176,192,224,256}, | |||
| { 0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96,112,128,144,160}, | |||
| { 0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96,112,128,144,160} | |||
| { | |||
| { 0, 32, 48, 56, 64, 80, 96, 112, 128, 144, 160, 176, 192, 224, 256 }, | |||
| { 0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160 }, | |||
| { 0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160 } | |||
| }, | |||
| }; | |||
| static const int sSamplesPerFrame[2][3] = | |||
| { | |||
| { 384, 1152, 1152 }, | |||
| { 384, 1152, 576 } | |||
| static const int sSamplesPerFrame[2][3] = { | |||
| { 384, 1152, 1152 }, | |||
| { 384, 1152, 576 } | |||
| }; | |||
| static const int sBitsPerSlot[3] = { | |||
| 32, | |||
| 8, | |||
| 8 | |||
| }; | |||
| static const int sBitsPerSlot[3] = { 32, 8, 8 }; | |||
| static int mp3len(void *data, int *samplesPerFrame, int *sampleRate) | |||
| { | |||
| uint32_t header = AV_RB32(data); | |||
| int layerID = 3 - ((header >> 17) & 0x03); | |||
| int bitRateID = ((header >> 12) & 0x0f); | |||
| uint32_t header = AV_RB32(data); | |||
| int layerID = 3 - ((header >> 17) & 0x03); | |||
| int bitRateID = ((header >> 12) & 0x0f); | |||
| int sampleRateID = ((header >> 10) & 0x03); | |||
| int bitsPerSlot = sBitsPerSlot[layerID]; | |||
| int isPadded = ((header >> 9) & 0x01); | |||
| static int const mode_tab[4]= {2,3,1,0}; | |||
| int mode= mode_tab[(header >> 19) & 0x03]; | |||
| int mpeg_id= mode>0; | |||
| int bitsPerSlot = sBitsPerSlot[layerID]; | |||
| int isPadded = ((header >> 9) & 0x01); | |||
| static int const mode_tab[4] = { 2, 3, 1, 0 }; | |||
| int mode = mode_tab[(header >> 19) & 0x03]; | |||
| int mpeg_id = mode > 0; | |||
| int temp0, temp1, bitRate; | |||
| if ( (( header >> 21 ) & 0x7ff) != 0x7ff || mode == 3 || layerID==3 || sampleRateID==3) { | |||
| if (((header >> 21) & 0x7ff) != 0x7ff || mode == 3 || layerID == 3 || | |||
| sampleRateID == 3) { | |||
| return -1; | |||
| } | |||
| if(!samplesPerFrame) samplesPerFrame= &temp0; | |||
| if(!sampleRate ) sampleRate = &temp1; | |||
| if (!samplesPerFrame) | |||
| samplesPerFrame = &temp0; | |||
| if (!sampleRate) | |||
| sampleRate = &temp1; | |||
| // *isMono = ((header >> 6) & 0x03) == 0x03; | |||
| //*isMono = ((header >> 6) & 0x03) == 0x03; | |||
| *sampleRate = sSampleRates[sampleRateID]>>mode; | |||
| bitRate = sBitRates[mpeg_id][layerID][bitRateID] * 1000; | |||
| *sampleRate = sSampleRates[sampleRateID] >> mode; | |||
| bitRate = sBitRates[mpeg_id][layerID][bitRateID] * 1000; | |||
| *samplesPerFrame = sSamplesPerFrame[mpeg_id][layerID]; | |||
| //av_log(NULL, AV_LOG_DEBUG, "sr:%d br:%d spf:%d l:%d m:%d\n", *sampleRate, bitRate, *samplesPerFrame, layerID, mode); | |||
| //av_log(NULL, AV_LOG_DEBUG, | |||
| // "sr:%d br:%d spf:%d l:%d m:%d\n", | |||
| // *sampleRate, bitRate, *samplesPerFrame, layerID, mode); | |||
| return *samplesPerFrame * bitRate / (bitsPerSlot * *sampleRate) + isPadded; | |||
| } | |||
| static int MP3lame_encode_frame(AVCodecContext *avctx, | |||
| unsigned char *frame, int buf_size, void *data) | |||
| static int MP3lame_encode_frame(AVCodecContext *avctx, unsigned char *frame, | |||
| int buf_size, void *data) | |||
| { | |||
| Mp3AudioContext *s = avctx->priv_data; | |||
| int len; | |||
| @@ -178,7 +180,7 @@ static int MP3lame_encode_frame(AVCodecContext *avctx, | |||
| /* lame 3.91 dies on '1-channel interleaved' data */ | |||
| if(!data){ | |||
| if (!data){ | |||
| lame_result= lame_encode_flush( | |||
| s->gfp, | |||
| s->buffer + s->buffer_index, | |||
| @@ -237,32 +239,35 @@ static int MP3lame_encode_frame(AVCodecContext *avctx, | |||
| } | |||
| } | |||
| if(lame_result < 0){ | |||
| if(lame_result==-1) { | |||
| if (lame_result < 0) { | |||
| if (lame_result == -1) { | |||
| /* output buffer too small */ | |||
| av_log(avctx, AV_LOG_ERROR, "lame: output buffer too small (buffer index: %d, free bytes: %d)\n", s->buffer_index, BUFFER_SIZE - s->buffer_index); | |||
| av_log(avctx, AV_LOG_ERROR, | |||
| "lame: output buffer too small (buffer index: %d, free bytes: %d)\n", | |||
| s->buffer_index, BUFFER_SIZE - s->buffer_index); | |||
| } | |||
| return -1; | |||
| } | |||
| s->buffer_index += lame_result; | |||
| if(s->buffer_index<4) | |||
| if (s->buffer_index < 4) | |||
| return 0; | |||
| len= mp3len(s->buffer, NULL, NULL); | |||
| //av_log(avctx, AV_LOG_DEBUG, "in:%d packet-len:%d index:%d\n", avctx->frame_size, len, s->buffer_index); | |||
| if(len <= s->buffer_index){ | |||
| len = mp3len(s->buffer, NULL, NULL); | |||
| //av_log(avctx, AV_LOG_DEBUG, "in:%d packet-len:%d index:%d\n", | |||
| // avctx->frame_size, len, s->buffer_index); | |||
| if (len <= s->buffer_index) { | |||
| memcpy(frame, s->buffer, len); | |||
| s->buffer_index -= len; | |||
| memmove(s->buffer, s->buffer+len, s->buffer_index); | |||
| //FIXME fix the audio codec API, so we do not need the memcpy() | |||
| /*for(i=0; i<len; i++){ | |||
| av_log(avctx, AV_LOG_DEBUG, "%2X ", frame[i]); | |||
| }*/ | |||
| memmove(s->buffer, s->buffer + len, s->buffer_index); | |||
| // FIXME fix the audio codec API, so we do not need the memcpy() | |||
| /*for(i=0; i<len; i++) { | |||
| av_log(avctx, AV_LOG_DEBUG, "%2X ", frame[i]); | |||
| }*/ | |||
| return len; | |||
| }else | |||
| } else | |||
| return 0; | |||
| } | |||
| @@ -280,7 +285,7 @@ static av_cold int MP3lame_encode_close(AVCodecContext *avctx) | |||
| #define OFFSET(x) offsetof(Mp3AudioContext, x) | |||
| #define AE AV_OPT_FLAG_AUDIO_PARAM | AV_OPT_FLAG_ENCODING_PARAM | |||
| static const AVOption options[] = { | |||
| { "reservoir", "Use bit reservoir.", OFFSET(reservoir), AV_OPT_TYPE_INT, { 1 }, 0, 1, AE }, | |||
| { "reservoir", "Use bit reservoir.", OFFSET(reservoir), AV_OPT_TYPE_INT, { 1 }, 0, 1, AE }, | |||
| { NULL }, | |||
| }; | |||
| @@ -292,20 +297,20 @@ static const AVClass libmp3lame_class = { | |||
| }; | |||
| AVCodec ff_libmp3lame_encoder = { | |||
| .name = "libmp3lame", | |||
| .type = AVMEDIA_TYPE_AUDIO, | |||
| .id = CODEC_ID_MP3, | |||
| .priv_data_size = sizeof(Mp3AudioContext), | |||
| .init = MP3lame_encode_init, | |||
| .encode = MP3lame_encode_frame, | |||
| .close = MP3lame_encode_close, | |||
| .capabilities= CODEC_CAP_DELAY, | |||
| .sample_fmts = (const enum AVSampleFormat[]){AV_SAMPLE_FMT_S16, | |||
| .name = "libmp3lame", | |||
| .type = AVMEDIA_TYPE_AUDIO, | |||
| .id = CODEC_ID_MP3, | |||
| .priv_data_size = sizeof(Mp3AudioContext), | |||
| .init = MP3lame_encode_init, | |||
| .encode = MP3lame_encode_frame, | |||
| .close = MP3lame_encode_close, | |||
| .capabilities = CODEC_CAP_DELAY, | |||
| .sample_fmts = (const enum AVSampleFormat[]) { AV_SAMPLE_FMT_S16, | |||
| #if 2147483647 == INT_MAX | |||
| AV_SAMPLE_FMT_S32, | |||
| #endif | |||
| AV_SAMPLE_FMT_NONE}, | |||
| .supported_samplerates= sSampleRates, | |||
| .long_name= NULL_IF_CONFIG_SMALL("libmp3lame MP3 (MPEG audio layer 3)"), | |||
| .priv_class = &libmp3lame_class, | |||
| AV_SAMPLE_FMT_NONE }, | |||
| .supported_samplerates = sSampleRates, | |||
| .long_name = NULL_IF_CONFIG_SMALL("libmp3lame MP3 (MPEG audio layer 3)"), | |||
| .priv_class = &libmp3lame_class, | |||
| }; | |||
| @@ -37,63 +37,65 @@ | |||
| #define OGGVORBIS_FRAME_SIZE 64 | |||
| #define BUFFER_SIZE (1024*64) | |||
| #define BUFFER_SIZE (1024 * 64) | |||
| typedef struct OggVorbisContext { | |||
| AVClass *av_class; | |||
| vorbis_info vi ; | |||
| vorbis_dsp_state vd ; | |||
| vorbis_block vb ; | |||
| vorbis_info vi; | |||
| vorbis_dsp_state vd; | |||
| vorbis_block vb; | |||
| uint8_t buffer[BUFFER_SIZE]; | |||
| int buffer_index; | |||
| int eof; | |||
| /* decoder */ | |||
| vorbis_comment vc ; | |||
| vorbis_comment vc; | |||
| ogg_packet op; | |||
| double iblock; | |||
| } OggVorbisContext ; | |||
| } OggVorbisContext; | |||
| static const AVOption options[]={ | |||
| {"iblock", "Sets the impulse block bias", offsetof(OggVorbisContext, iblock), AV_OPT_TYPE_DOUBLE, {.dbl = 0}, -15, 0, AV_OPT_FLAG_AUDIO_PARAM|AV_OPT_FLAG_ENCODING_PARAM}, | |||
| {NULL} | |||
| static const AVOption options[] = { | |||
| { "iblock", "Sets the impulse block bias", offsetof(OggVorbisContext, iblock), AV_OPT_TYPE_DOUBLE, { .dbl = 0 }, -15, 0, AV_OPT_FLAG_AUDIO_PARAM | AV_OPT_FLAG_ENCODING_PARAM }, | |||
| { NULL } | |||
| }; | |||
| static const AVClass class = { "libvorbis", av_default_item_name, options, LIBAVUTIL_VERSION_INT }; | |||
| static av_cold int oggvorbis_init_encoder(vorbis_info *vi, AVCodecContext *avccontext) { | |||
| OggVorbisContext *context = avccontext->priv_data ; | |||
| static av_cold int oggvorbis_init_encoder(vorbis_info *vi, AVCodecContext *avccontext) | |||
| { | |||
| OggVorbisContext *context = avccontext->priv_data; | |||
| double cfreq; | |||
| if(avccontext->flags & CODEC_FLAG_QSCALE) { | |||
| if (avccontext->flags & CODEC_FLAG_QSCALE) { | |||
| /* variable bitrate */ | |||
| if(vorbis_encode_setup_vbr(vi, avccontext->channels, | |||
| avccontext->sample_rate, | |||
| avccontext->global_quality / (float)FF_QP2LAMBDA / 10.0)) | |||
| if (vorbis_encode_setup_vbr(vi, avccontext->channels, | |||
| avccontext->sample_rate, | |||
| avccontext->global_quality / (float)FF_QP2LAMBDA / 10.0)) | |||
| return -1; | |||
| } else { | |||
| int minrate = avccontext->rc_min_rate > 0 ? avccontext->rc_min_rate : -1; | |||
| int maxrate = avccontext->rc_min_rate > 0 ? avccontext->rc_max_rate : -1; | |||
| /* constant bitrate */ | |||
| if(vorbis_encode_setup_managed(vi, avccontext->channels, | |||
| avccontext->sample_rate, minrate, avccontext->bit_rate, maxrate)) | |||
| if (vorbis_encode_setup_managed(vi, avccontext->channels, | |||
| avccontext->sample_rate, minrate, | |||
| avccontext->bit_rate, maxrate)) | |||
| return -1; | |||
| /* variable bitrate by estimate, disable slow rate management */ | |||
| if(minrate == -1 && maxrate == -1) | |||
| if(vorbis_encode_ctl(vi, OV_ECTL_RATEMANAGE2_SET, NULL)) | |||
| if (minrate == -1 && maxrate == -1) | |||
| if (vorbis_encode_ctl(vi, OV_ECTL_RATEMANAGE2_SET, NULL)) | |||
| return -1; | |||
| } | |||
| /* cutoff frequency */ | |||
| if(avccontext->cutoff > 0) { | |||
| if (avccontext->cutoff > 0) { | |||
| cfreq = avccontext->cutoff / 1000.0; | |||
| if(vorbis_encode_ctl(vi, OV_ECTL_LOWPASS_SET, &cfreq)) | |||
| if (vorbis_encode_ctl(vi, OV_ECTL_LOWPASS_SET, &cfreq)) | |||
| return -1; | |||
| } | |||
| if(context->iblock){ | |||
| if (context->iblock) { | |||
| vorbis_encode_ctl(vi, OV_ECTL_IBLOCK_SET, &context->iblock); | |||
| } | |||
| @@ -130,35 +132,39 @@ static av_cold int oggvorbis_init_encoder(vorbis_info *vi, AVCodecContext *avcco | |||
| } | |||
| /* How many bytes are needed for a buffer of length 'l' */ | |||
| static int xiph_len(int l) { return (1 + l / 255 + l); } | |||
| static int xiph_len(int l) | |||
| { | |||
| return (1 + l / 255 + l); | |||
| } | |||
| static av_cold int oggvorbis_encode_init(AVCodecContext *avccontext) { | |||
| OggVorbisContext *context = avccontext->priv_data ; | |||
| static av_cold int oggvorbis_encode_init(AVCodecContext *avccontext) | |||
| { | |||
| OggVorbisContext *context = avccontext->priv_data; | |||
| ogg_packet header, header_comm, header_code; | |||
| uint8_t *p; | |||
| unsigned int offset; | |||
| vorbis_info_init(&context->vi) ; | |||
| if(oggvorbis_init_encoder(&context->vi, avccontext) < 0) { | |||
| av_log(avccontext, AV_LOG_ERROR, "oggvorbis_encode_init: init_encoder failed\n") ; | |||
| return -1 ; | |||
| vorbis_info_init(&context->vi); | |||
| if (oggvorbis_init_encoder(&context->vi, avccontext) < 0) { | |||
| av_log(avccontext, AV_LOG_ERROR, "oggvorbis_encode_init: init_encoder failed\n"); | |||
| return -1; | |||
| } | |||
| vorbis_analysis_init(&context->vd, &context->vi) ; | |||
| vorbis_block_init(&context->vd, &context->vb) ; | |||
| vorbis_analysis_init(&context->vd, &context->vi); | |||
| vorbis_block_init(&context->vd, &context->vb); | |||
| vorbis_comment_init(&context->vc); | |||
| vorbis_comment_add_tag(&context->vc, "encoder", LIBAVCODEC_IDENT) ; | |||
| vorbis_comment_add_tag(&context->vc, "encoder", LIBAVCODEC_IDENT); | |||
| vorbis_analysis_headerout(&context->vd, &context->vc, &header, | |||
| &header_comm, &header_code); | |||
| &header_comm, &header_code); | |||
| avccontext->extradata_size= | |||
| avccontext->extradata_size = | |||
| 1 + xiph_len(header.bytes) + xiph_len(header_comm.bytes) + | |||
| header_code.bytes; | |||
| p = avccontext->extradata = | |||
| av_malloc(avccontext->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE); | |||
| p[0] = 2; | |||
| offset = 1; | |||
| av_malloc(avccontext->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE); | |||
| p[0] = 2; | |||
| offset = 1; | |||
| offset += av_xiphlacing(&p[offset], header.bytes); | |||
| offset += av_xiphlacing(&p[offset], header_comm.bytes); | |||
| memcpy(&p[offset], header.packet, header.bytes); | |||
| @@ -169,56 +175,57 @@ static av_cold int oggvorbis_encode_init(AVCodecContext *avccontext) { | |||
| offset += header_code.bytes; | |||
| assert(offset == avccontext->extradata_size); | |||
| /* vorbis_block_clear(&context->vb); | |||
| #if 0 | |||
| vorbis_block_clear(&context->vb); | |||
| vorbis_dsp_clear(&context->vd); | |||
| vorbis_info_clear(&context->vi);*/ | |||
| vorbis_info_clear(&context->vi); | |||
| #endif | |||
| vorbis_comment_clear(&context->vc); | |||
| avccontext->frame_size = OGGVORBIS_FRAME_SIZE ; | |||
| avccontext->frame_size = OGGVORBIS_FRAME_SIZE; | |||
| avccontext->coded_frame= avcodec_alloc_frame(); | |||
| avccontext->coded_frame->key_frame= 1; | |||
| avccontext->coded_frame = avcodec_alloc_frame(); | |||
| avccontext->coded_frame->key_frame = 1; | |||
| return 0 ; | |||
| return 0; | |||
| } | |||
| static int oggvorbis_encode_frame(AVCodecContext *avccontext, | |||
| unsigned char *packets, | |||
| int buf_size, void *data) | |||
| int buf_size, void *data) | |||
| { | |||
| OggVorbisContext *context = avccontext->priv_data ; | |||
| ogg_packet op ; | |||
| signed short *audio = data ; | |||
| OggVorbisContext *context = avccontext->priv_data; | |||
| ogg_packet op; | |||
| signed short *audio = data; | |||
| int l; | |||
| if(data) { | |||
| if (data) { | |||
| const int samples = avccontext->frame_size; | |||
| float **buffer ; | |||
| float **buffer; | |||
| int c, channels = context->vi.channels; | |||
| buffer = vorbis_analysis_buffer(&context->vd, samples) ; | |||
| buffer = vorbis_analysis_buffer(&context->vd, samples); | |||
| for (c = 0; c < channels; c++) { | |||
| int co = (channels > 8) ? c : | |||
| ff_vorbis_encoding_channel_layout_offsets[channels-1][c]; | |||
| for(l = 0 ; l < samples ; l++) | |||
| buffer[c][l]=audio[l*channels+co]/32768.f; | |||
| ff_vorbis_encoding_channel_layout_offsets[channels - 1][c]; | |||
| for (l = 0; l < samples; l++) | |||
| buffer[c][l] = audio[l * channels + co] / 32768.f; | |||
| } | |||
| vorbis_analysis_wrote(&context->vd, samples) ; | |||
| vorbis_analysis_wrote(&context->vd, samples); | |||
| } else { | |||
| if(!context->eof) | |||
| vorbis_analysis_wrote(&context->vd, 0) ; | |||
| if (!context->eof) | |||
| vorbis_analysis_wrote(&context->vd, 0); | |||
| context->eof = 1; | |||
| } | |||
| while(vorbis_analysis_blockout(&context->vd, &context->vb) == 1) { | |||
| while (vorbis_analysis_blockout(&context->vd, &context->vb) == 1) { | |||
| vorbis_analysis(&context->vb, NULL); | |||
| vorbis_bitrate_addblock(&context->vb) ; | |||
| vorbis_bitrate_addblock(&context->vb); | |||
| while(vorbis_bitrate_flushpacket(&context->vd, &op)) { | |||
| while (vorbis_bitrate_flushpacket(&context->vd, &op)) { | |||
| /* i'd love to say the following line is a hack, but sadly it's | |||
| * not, apparently the end of stream decision is in libogg. */ | |||
| if(op.bytes==1 && op.e_o_s) | |||
| if (op.bytes == 1 && op.e_o_s) | |||
| continue; | |||
| if (context->buffer_index + sizeof(ogg_packet) + op.bytes > BUFFER_SIZE) { | |||
| av_log(avccontext, AV_LOG_ERROR, "libvorbis: buffer overflow."); | |||
| @@ -232,13 +239,13 @@ static int oggvorbis_encode_frame(AVCodecContext *avccontext, | |||
| } | |||
| } | |||
| l=0; | |||
| if(context->buffer_index){ | |||
| ogg_packet *op2= (ogg_packet*)context->buffer; | |||
| l = 0; | |||
| if (context->buffer_index) { | |||
| ogg_packet *op2 = (ogg_packet *)context->buffer; | |||
| op2->packet = context->buffer + sizeof(ogg_packet); | |||
| l= op2->bytes; | |||
| avccontext->coded_frame->pts= av_rescale_q(op2->granulepos, (AVRational){1, avccontext->sample_rate}, avccontext->time_base); | |||
| l = op2->bytes; | |||
| avccontext->coded_frame->pts = av_rescale_q(op2->granulepos, (AVRational) { 1, avccontext->sample_rate }, avccontext->time_base); | |||
| //FIXME we should reorder the user supplied pts and not assume that they are spaced by 1/sample_rate | |||
| if (l > buf_size) { | |||
| @@ -255,12 +262,12 @@ static int oggvorbis_encode_frame(AVCodecContext *avccontext, | |||
| return l; | |||
| } | |||
| static av_cold int oggvorbis_encode_close(AVCodecContext *avccontext) { | |||
| OggVorbisContext *context = avccontext->priv_data ; | |||
| static av_cold int oggvorbis_encode_close(AVCodecContext *avccontext) | |||
| { | |||
| OggVorbisContext *context = avccontext->priv_data; | |||
| /* ogg_packet op ; */ | |||
| vorbis_analysis_wrote(&context->vd, 0) ; /* notify vorbisenc this is EOF */ | |||
| vorbis_analysis_wrote(&context->vd, 0); /* notify vorbisenc this is EOF */ | |||
| vorbis_block_clear(&context->vb); | |||
| vorbis_dsp_clear(&context->vd); | |||
| @@ -269,10 +276,9 @@ static av_cold int oggvorbis_encode_close(AVCodecContext *avccontext) { | |||
| av_freep(&avccontext->coded_frame); | |||
| av_freep(&avccontext->extradata); | |||
| return 0 ; | |||
| return 0; | |||
| } | |||
| AVCodec ff_libvorbis_encoder = { | |||
| .name = "libvorbis", | |||
| .type = AVMEDIA_TYPE_AUDIO, | |||
| @@ -282,7 +288,7 @@ AVCodec ff_libvorbis_encoder = { | |||
| .encode = oggvorbis_encode_frame, | |||
| .close = oggvorbis_encode_close, | |||
| .capabilities = CODEC_CAP_DELAY, | |||
| .sample_fmts = (const enum AVSampleFormat[]){AV_SAMPLE_FMT_S16,AV_SAMPLE_FMT_NONE}, | |||
| .sample_fmts = (const enum AVSampleFormat[]) { AV_SAMPLE_FMT_S16, AV_SAMPLE_FMT_NONE }, | |||
| .long_name = NULL_IF_CONFIG_SMALL("libvorbis Vorbis"), | |||
| .priv_class = &class, | |||
| }; | |||
| @@ -376,13 +376,23 @@ static int read_data(void *opaque, uint8_t *buf, int buf_size) | |||
| restart: | |||
| if (!v->input) { | |||
| reload: | |||
| /* If this is a live stream and target_duration has elapsed since | |||
| /* If this is a live stream and the reload interval has elapsed since | |||
| * the last playlist reload, reload the variant playlists now. */ | |||
| int64_t reload_interval = v->n_segments > 0 ? | |||
| v->segments[v->n_segments - 1]->duration : | |||
| v->target_duration; | |||
| reload_interval *= 1000000; | |||
| reload: | |||
| if (!v->finished && | |||
| av_gettime() - v->last_load_time >= v->target_duration*1000000 && | |||
| (ret = parse_playlist(c, v->url, v, NULL)) < 0) | |||
| av_gettime() - v->last_load_time >= reload_interval) { | |||
| if ((ret = parse_playlist(c, v->url, v, NULL)) < 0) | |||
| return ret; | |||
| /* If we need to reload the playlist again below (if | |||
| * there's still no more segments), switch to a reload | |||
| * interval of half the target duration. */ | |||
| reload_interval = v->target_duration * 500000; | |||
| } | |||
| if (v->cur_seq_no < v->start_seq_no) { | |||
| av_log(NULL, AV_LOG_WARNING, | |||
| "skipping %d segments ahead, expired from playlists\n", | |||
| @@ -392,8 +402,7 @@ reload: | |||
| if (v->cur_seq_no >= v->start_seq_no + v->n_segments) { | |||
| if (v->finished) | |||
| return AVERROR_EOF; | |||
| while (av_gettime() - v->last_load_time < | |||
| v->target_duration*1000000) { | |||
| while (av_gettime() - v->last_load_time < reload_interval) { | |||
| if (ff_check_interrupt(c->interrupt_callback)) | |||
| return AVERROR_EXIT; | |||
| usleep(100*1000); | |||
| @@ -244,6 +244,7 @@ static int applehttp_read(URLContext *h, uint8_t *buf, int size) | |||
| AppleHTTPContext *s = h->priv_data; | |||
| const char *url; | |||
| int ret; | |||
| int64_t reload_interval; | |||
| start: | |||
| if (s->seg_hd) { | |||
| @@ -256,12 +257,21 @@ start: | |||
| s->seg_hd = NULL; | |||
| s->cur_seq_no++; | |||
| } | |||
| reload_interval = s->n_segments > 0 ? | |||
| s->segments[s->n_segments - 1]->duration : | |||
| s->target_duration; | |||
| reload_interval *= 1000000; | |||
| retry: | |||
| if (!s->finished) { | |||
| int64_t now = av_gettime(); | |||
| if (now - s->last_load_time >= s->target_duration*1000000) | |||
| if (now - s->last_load_time >= reload_interval) { | |||
| if ((ret = parse_playlist(h, s->playlisturl)) < 0) | |||
| return ret; | |||
| /* If we need to reload the playlist again below (if | |||
| * there's still no more segments), switch to a reload | |||
| * interval of half the target duration. */ | |||
| reload_interval = s->target_duration * 500000; | |||
| } | |||
| } | |||
| if (s->cur_seq_no < s->start_seq_no) { | |||
| av_log(h, AV_LOG_WARNING, | |||
| @@ -272,7 +282,7 @@ retry: | |||
| if (s->cur_seq_no - s->start_seq_no >= s->n_segments) { | |||
| if (s->finished) | |||
| return AVERROR_EOF; | |||
| while (av_gettime() - s->last_load_time < s->target_duration*1000000) { | |||
| while (av_gettime() - s->last_load_time < reload_interval) { | |||
| if (ff_check_interrupt(&h->interrupt_callback)) | |||
| return AVERROR_EXIT; | |||
| usleep(100*1000); | |||
| @@ -50,6 +50,7 @@ include $(SRC_PATH)/tests/fate/amrnb.mak | |||
| include $(SRC_PATH)/tests/fate/amrwb.mak | |||
| include $(SRC_PATH)/tests/fate/atrac.mak | |||
| include $(SRC_PATH)/tests/fate/dct.mak | |||
| include $(SRC_PATH)/tests/fate/dpcm.mak | |||
| include $(SRC_PATH)/tests/fate/fft.mak | |||
| include $(SRC_PATH)/tests/fate/h264.mak | |||
| include $(SRC_PATH)/tests/fate/image.mak | |||
| @@ -62,6 +63,7 @@ include $(SRC_PATH)/tests/fate/lossless-video.mak | |||
| include $(SRC_PATH)/tests/fate/microsoft.mak | |||
| include $(SRC_PATH)/tests/fate/mp3.mak | |||
| include $(SRC_PATH)/tests/fate/mpc.mak | |||
| include $(SRC_PATH)/tests/fate/pcm.mak | |||
| include $(SRC_PATH)/tests/fate/prores.mak | |||
| include $(SRC_PATH)/tests/fate/qtrle.mak | |||
| include $(SRC_PATH)/tests/fate/real.mak | |||
| @@ -6,10 +6,6 @@ FATE_TESTS += fate-8bps | |||
| fate-8bps: CMD = framecrc -i $(SAMPLES)/8bps/full9iron-partial.mov -pix_fmt rgb24 | |||
| FATE_TESTS += fate-aasc | |||
| fate-aasc: CMD = framecrc -i $(SAMPLES)/aasc/AASC-1.5MB.AVI -pix_fmt rgb24 | |||
| FATE_TESTS += fate-adpcm-ea-r2 | |||
| fate-adpcm-ea-r2: CMD = crc -i $(SAMPLES)/ea-mpc/THX_logo.mpc -vn | |||
| FATE_TESTS += fate-adpcm-ea-r3 | |||
| fate-adpcm-ea-r3: CMD = crc -i $(SAMPLES)/ea-vp6/THX_logo.vp6 -vn | |||
| FATE_TESTS += fate-adts-demux | |||
| fate-adts-demux: CMD = crc -i $(SAMPLES)/aac/ct_faac-adts.aac -acodec copy | |||
| FATE_TESTS += fate-aea-demux | |||
| @@ -40,14 +36,6 @@ FATE_TESTS += fate-cljr | |||
| fate-cljr: CMD = framecrc -i $(SAMPLES)/cljr/testcljr-partial.avi | |||
| FATE_TESTS += fate-corepng | |||
| fate-corepng: CMD = framecrc -i $(SAMPLES)/png1/corepng-partial.avi | |||
| FATE_TESTS += fate-creative-adpcm | |||
| fate-creative-adpcm: CMD = md5 -i $(SAMPLES)/creative/intro-partial.wav -f s16le | |||
| FATE_TESTS += fate-creative-adpcm-8-2.6bit | |||
| fate-creative-adpcm-8-2.6bit: CMD = md5 -i $(SAMPLES)/creative/BBC_3BIT.VOC -f s16le | |||
| FATE_TESTS += fate-creative-adpcm-8-2bit | |||
| fate-creative-adpcm-8-2bit: CMD = md5 -i $(SAMPLES)/creative/BBC_2BIT.VOC -f s16le | |||
| FATE_TESTS += fate-creative-adpcm-8-4bit | |||
| fate-creative-adpcm-8-4bit: CMD = md5 -i $(SAMPLES)/creative/BBC_4BIT.VOC -f s16le | |||
| FATE_TESTS += fate-creatureshock-avs | |||
| fate-creatureshock-avs: CMD = framecrc -i $(SAMPLES)/creatureshock-avs/OUTATIME.AVS -pix_fmt rgb24 | |||
| FATE_TESTS += fate-cryo-apc | |||
| @@ -66,10 +54,6 @@ FATE_TESTS += fate-delphine-cin | |||
| fate-delphine-cin: CMD = framecrc -i $(SAMPLES)/delphine-cin/LOGO-partial.CIN -pix_fmt rgb24 -vsync 0 | |||
| FATE_TESTS += fate-deluxepaint-anm | |||
| fate-deluxepaint-anm: CMD = framecrc -i $(SAMPLES)/deluxepaint-anm/INTRO1.ANM -pix_fmt rgb24 | |||
| FATE_TESTS += fate-duck-dk3 | |||
| fate-duck-dk3: CMD = md5 -i $(SAMPLES)/duck/sop-audio-only.avi -f s16le | |||
| FATE_TESTS += fate-duck-dk4 | |||
| fate-duck-dk4: CMD = md5 -i $(SAMPLES)/duck/salsa-audio-only.avi -f s16le | |||
| FATE_TESTS += fate-duck-tm2 | |||
| fate-duck-tm2: CMD = framecrc -i $(SAMPLES)/duck/tm20.avi | |||
| FATE_TESTS += fate-ea-cdata | |||
| @@ -78,22 +62,14 @@ FATE_TESTS += fate-ea-cmv | |||
| fate-ea-cmv: CMD = framecrc -i $(SAMPLES)/ea-cmv/TITLE.CMV -vsync 0 -pix_fmt rgb24 | |||
| FATE_TESTS += fate-ea-dct | |||
| fate-ea-dct: CMD = framecrc -idct simple -i $(SAMPLES)/ea-dct/NFS2Esprit-partial.dct | |||
| FATE_TESTS += fate-ea-mad-adpcm-ea-r1 | |||
| fate-ea-mad-adpcm-ea-r1: CMD = framecrc -i $(SAMPLES)/ea-mad/NFS6LogoE.mad | |||
| FATE_TESTS += fate-ea-mad-pcm-planar | |||
| fate-ea-mad-pcm-planar: CMD = framecrc -i $(SAMPLES)/ea-mad/xeasport.mad | |||
| FATE_TESTS += fate-ea-tgq | |||
| fate-ea-tgq: CMD = framecrc -i $(SAMPLES)/ea-tgq/v27.tgq -an | |||
| FATE_TESTS += fate-ea-tgv-ima-ea-eacs | |||
| fate-ea-tgv-ima-ea-eacs: CMD = framecrc -i $(SAMPLES)/ea-tgv/INTRO8K-partial.TGV -pix_fmt rgb24 | |||
| FATE_TESTS += fate-ea-tgv-ima-ea-sead | |||
| fate-ea-tgv-ima-ea-sead: CMD = framecrc -i $(SAMPLES)/ea-tgv/INTEL_S.TGV -pix_fmt rgb24 | |||
| FATE_TESTS += fate-ea-tqi-adpcm | |||
| fate-ea-tqi-adpcm: CMD = framecrc -i $(SAMPLES)/ea-wve/networkBackbone-partial.wve -frames:v 26 | |||
| FATE_TESTS += fate-feeble-dxa | |||
| fate-feeble-dxa: CMD = framecrc -i $(SAMPLES)/dxa/meetsquid.dxa -t 2 -pix_fmt rgb24 | |||
| FATE_TESTS += fate-film-cvid-pcm-stereo-8bit | |||
| fate-film-cvid-pcm-stereo-8bit: CMD = framecrc -i $(SAMPLES)/film/logo-capcom.cpk | |||
| FATE_TESTS += fate-flic-af11-palette-change | |||
| fate-flic-af11-palette-change: CMD = framecrc -i $(SAMPLES)/fli/fli-engines.fli -t 3.3 -pix_fmt rgb24 | |||
| FATE_TESTS += fate-flic-af12 | |||
| @@ -110,8 +86,6 @@ FATE_TESTS += fate-g729-1 | |||
| fate-g729-1: CMD = framecrc -i $(SAMPLES)/act/REC05.act -t 10 | |||
| FATE_TESTS += fate-id-cin-video | |||
| fate-id-cin-video: CMD = framecrc -i $(SAMPLES)/idcin/idlog-2MB.cin -pix_fmt rgb24 | |||
| FATE_TESTS += fate-idroq-video-dpcm | |||
| fate-idroq-video-dpcm: CMD = framecrc -i $(SAMPLES)/idroq/idlogo.roq | |||
| FATE_TESTS-$(CONFIG_AVFILTER) += fate-idroq-video-encode | |||
| fate-idroq-video-encode: CMD = md5 -f image2 -vcodec pgmyuv -i $(SAMPLES)/ffmpeg-synthetic/vsynth1/%02d.pgm -sws_flags +bitexact -vf pad=512:512:80:112 -f RoQ -t 0.2 | |||
| FATE_TESTS += fate-iff-byterun1 | |||
| @@ -120,8 +94,6 @@ FATE_TESTS += fate-iff-fibonacci | |||
| fate-iff-fibonacci: CMD = md5 -i $(SAMPLES)/iff/dasboot-in-compressed -f s16le | |||
| FATE_TESTS += fate-iff-ilbm | |||
| fate-iff-ilbm: CMD = framecrc -i $(SAMPLES)/iff/lms-matriks.ilbm -pix_fmt rgb24 | |||
| FATE_TESTS += fate-iff-pcm | |||
| fate-iff-pcm: CMD = md5 -i $(SAMPLES)/iff/Bells -f s16le | |||
| FATE_TESTS += fate-interplay-mve-16bit | |||
| fate-interplay-mve-16bit: CMD = framecrc -i $(SAMPLES)/interplay-mve/descent3-level5-16bit-partial.mve -pix_fmt rgb24 | |||
| FATE_TESTS += fate-interplay-mve-8bit | |||
| @@ -150,14 +122,10 @@ FATE_TESTS += fate-nuv | |||
| fate-nuv: CMD = framecrc -idct simple -i $(SAMPLES)/nuv/Today.nuv -vsync 0 | |||
| FATE_TESTS += fate-oma-demux | |||
| fate-oma-demux: CMD = crc -i $(SAMPLES)/oma/01-Untitled-partial.oma -acodec copy | |||
| FATE_TESTS += fate-pcm_dvd | |||
| fate-pcm_dvd: CMD = framecrc -i $(SAMPLES)/pcm-dvd/coolitnow-partial.vob -vn | |||
| FATE_TESTS += fate-psx-str | |||
| fate-psx-str: CMD = framecrc -i $(SAMPLES)/psx-str/descent-partial.str | |||
| FATE_TESTS += fate-psx-str-v3-mdec | |||
| fate-psx-str-v3-mdec: CMD = framecrc -i $(SAMPLES)/psx-str/abc000_cut.str -an | |||
| FATE_TESTS += fate-psx-str-v3-adpcm_xa | |||
| fate-psx-str-v3-adpcm_xa: CMD = framecrc -i $(SAMPLES)/psx-str/abc000_cut.str -vn | |||
| FATE_TESTS += fate-pva-demux | |||
| fate-pva-demux: CMD = framecrc -idct simple -i $(SAMPLES)/pva/PVA_test-partial.pva -t 0.6 -acodec copy | |||
| FATE_TESTS += fate-qcp-demux | |||
| @@ -180,18 +148,6 @@ FATE_TESTS += fate-qt-mac6-mono | |||
| fate-qt-mac6-mono: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-1-8-MAC6.mov -f s16le | |||
| FATE_TESTS += fate-qt-mac6-stereo | |||
| fate-qt-mac6-stereo: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-2-8-MAC6.mov -f s16le | |||
| FATE_TESTS += fate-qt-msadpcm-stereo | |||
| fate-qt-msadpcm-stereo: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-2-16-L-ms02.mov -f s16le | |||
| FATE_TESTS += fate-qt-msimaadpcm-stereo | |||
| fate-qt-msimaadpcm-stereo: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-2-16-L-ms11.mov -f s16le | |||
| FATE_TESTS += fate-qt-rawpcm-16bit-stereo-signed-be | |||
| fate-qt-rawpcm-16bit-stereo-signed-be: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-2-16-B-twos.mov -f s16le | |||
| FATE_TESTS += fate-qt-rawpcm-16bit-stereo-signed-le | |||
| fate-qt-rawpcm-16bit-stereo-signed-le: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-2-16-L-sowt.mov -f s16le | |||
| FATE_TESTS += fate-qt-rawpcm-8bit-mono-unsigned | |||
| fate-qt-rawpcm-8bit-mono-unsigned: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-1-8-raw.mov -f s16le | |||
| FATE_TESTS += fate-qt-rawpcm-8bit-stereo-unsigned | |||
| fate-qt-rawpcm-8bit-stereo-unsigned: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-2-8-raw.mov -f s16le | |||
| FATE_TESTS += fate-qt-ulaw-mono | |||
| fate-qt-ulaw-mono: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-1-16-B-ulaw.mov -f s16le | |||
| FATE_TESTS += fate-qt-ulaw-stereo | |||
| @@ -222,8 +178,6 @@ FATE_TESTS += fate-svq1 | |||
| fate-svq1: CMD = framecrc -i $(SAMPLES)/svq1/marymary-shackles.mov -an -t 10 | |||
| FATE_TESTS += fate-svq3 | |||
| fate-svq3: CMD = framecrc -i $(SAMPLES)/svq3/Vertical400kbit.sorenson3.mov -t 6 -an | |||
| FATE_TESTS += fate-thp-mjpeg-adpcm | |||
| fate-thp-mjpeg-adpcm: CMD = framecrc -idct simple -i $(SAMPLES)/thp/pikmin2-opening1-partial.thp | |||
| FATE_TESTS += fate-tiertex-seq | |||
| fate-tiertex-seq: CMD = framecrc -i $(SAMPLES)/tiertex-seq/Gameover.seq -pix_fmt rgb24 | |||
| FATE_TESTS += fate-tmv | |||
| @@ -242,13 +196,9 @@ FATE_TESTS += fate-video-xl | |||
| fate-video-xl: CMD = framecrc -i $(SAMPLES)/vixl/pig-vixl.avi | |||
| FATE_TESTS += fate-vqa-cc | |||
| fate-vqa-cc: CMD = framecrc -i $(SAMPLES)/vqa/cc-demo1-partial.vqa -pix_fmt rgb24 | |||
| FATE_TESTS += fate-w64 | |||
| fate-w64: CMD = crc -i $(SAMPLES)/w64/w64-pcm16.w64 | |||
| FATE_TESTS += fate-wc3movie-xan | |||
| fate-wc3movie-xan: CMD = framecrc -i $(SAMPLES)/wc3movie/SC_32-part.MVE -pix_fmt rgb24 | |||
| FATE_TESTS += fate-westwood-aud | |||
| fate-westwood-aud: CMD = md5 -i $(SAMPLES)/westwood-aud/excellent.aud -f s16le | |||
| FATE_TESTS += fate-wnv1 | |||
| fate-wnv1: CMD = framecrc -i $(SAMPLES)/wnv1/wnv1-codec.avi -an | |||
| FATE_TESTS += fate-xan-dpcm | |||
| fate-xan-dpcm: CMD = md5 -i $(SAMPLES)/wc4-xan/wc4_2.avi -vn -f s16le | |||
| @@ -0,0 +1,42 @@ | |||
| FATE_TESTS += fate-adpcm-ea-r2 | |||
| fate-adpcm-ea-r2: CMD = crc -i $(SAMPLES)/ea-mpc/THX_logo.mpc -vn | |||
| FATE_TESTS += fate-adpcm-ea-r3 | |||
| fate-adpcm-ea-r3: CMD = crc -i $(SAMPLES)/ea-vp6/THX_logo.vp6 -vn | |||
| FATE_TESTS += fate-creative-adpcm | |||
| fate-creative-adpcm: CMD = md5 -i $(SAMPLES)/creative/intro-partial.wav -f s16le | |||
| FATE_TESTS += fate-creative-adpcm-8-2bit | |||
| fate-creative-adpcm-8-2bit: CMD = md5 -i $(SAMPLES)/creative/BBC_2BIT.VOC -f s16le | |||
| FATE_TESTS += fate-creative-adpcm-8-2.6bit | |||
| fate-creative-adpcm-8-2.6bit: CMD = md5 -i $(SAMPLES)/creative/BBC_3BIT.VOC -f s16le | |||
| FATE_TESTS += fate-creative-adpcm-8-4bit | |||
| fate-creative-adpcm-8-4bit: CMD = md5 -i $(SAMPLES)/creative/BBC_4BIT.VOC -f s16le | |||
| FATE_TESTS += fate-ea-mad-adpcm-ea-r1 | |||
| fate-ea-mad-adpcm-ea-r1: CMD = framecrc -i $(SAMPLES)/ea-mad/NFS6LogoE.mad | |||
| FATE_TESTS += fate-ea-tqi-adpcm | |||
| fate-ea-tqi-adpcm: CMD = framecrc -i $(SAMPLES)/ea-wve/networkBackbone-partial.wve -frames:v 26 | |||
| FATE_TESTS += fate-idroq-video-dpcm | |||
| fate-idroq-video-dpcm: CMD = framecrc -i $(SAMPLES)/idroq/idlogo.roq | |||
| FATE_TESTS += fate-psx-str-v3-adpcm_xa | |||
| fate-psx-str-v3-adpcm_xa: CMD = framecrc -i $(SAMPLES)/psx-str/abc000_cut.str -vn | |||
| FATE_TESTS += fate-qt-msadpcm-stereo | |||
| fate-qt-msadpcm-stereo: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-2-16-L-ms02.mov -f s16le | |||
| FATE_TESTS += fate-qt-msimaadpcm-stereo | |||
| fate-qt-msimaadpcm-stereo: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-2-16-L-ms11.mov -f s16le | |||
| FATE_TESTS += fate-thp-mjpeg-adpcm | |||
| fate-thp-mjpeg-adpcm: CMD = framecrc -idct simple -i $(SAMPLES)/thp/pikmin2-opening1-partial.thp | |||
| FATE_TESTS += fate-dpcm_xan_audio | |||
| fate-dpcm_xan_audio: CMD = md5 -i $(SAMPLES)/wc4-xan/wc4_2.avi -vn -f s16le | |||
| @@ -16,3 +16,12 @@ fate-wmv8-drm-nodec: CMD = framecrc -cryptokey 137381538c84c068111902a59c5cf6c34 | |||
| FATE_TESTS += fate-vc1 | |||
| fate-vc1: CMD = framecrc -i $(SAMPLES)/vc1/SA00040.vc1 | |||
| FATE_TESTS += fate-vc1_sa00050 | |||
| fate-vc1_sa00050: CMD = framecrc -i $(SAMPLES)/vc1/SA00050.vc1 | |||
| FATE_TESTS += fate-vc1_sa10091 | |||
| fate-vc1_sa10091: CMD = framecrc -i $(SAMPLES)/vc1/SA10091.vc1 | |||
| FATE_TESTS += fate-vc1_sa20021 | |||
| fate-vc1_sa20021: CMD = framecrc -i $(SAMPLES)/vc1/SA20021.vc1 | |||
| @@ -0,0 +1,32 @@ | |||
| FATE_TESTS += fate-duck-dk3 | |||
| fate-duck-dk3: CMD = md5 -i $(SAMPLES)/duck/sop-audio-only.avi -f s16le | |||
| FATE_TESTS += fate-duck-dk4 | |||
| fate-duck-dk4: CMD = md5 -i $(SAMPLES)/duck/salsa-audio-only.avi -f s16le | |||
| FATE_TESTS += fate-ea-mad-pcm-planar | |||
| fate-ea-mad-pcm-planar: CMD = framecrc -i $(SAMPLES)/ea-mad/xeasport.mad | |||
| FATE_TESTS += fate-film-cvid-pcm-stereo-8bit | |||
| fate-film-cvid-pcm-stereo-8bit: CMD = framecrc -i $(SAMPLES)/film/logo-capcom.cpk | |||
| FATE_TESTS += fate-iff-pcm | |||
| fate-iff-pcm: CMD = md5 -i $(SAMPLES)/iff/Bells -f s16le | |||
| FATE_TESTS += fate-pcm_dvd | |||
| fate-pcm_dvd: CMD = framecrc -i $(SAMPLES)/pcm-dvd/coolitnow-partial.vob -vn | |||
| FATE_TESTS += fate-qt-rawpcm-8bit-mono-unsigned | |||
| fate-qt-rawpcm-8bit-mono-unsigned: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-1-8-raw.mov -f s16le | |||
| FATE_TESTS += fate-qt-rawpcm-8bit-stereo-unsigned | |||
| fate-qt-rawpcm-8bit-stereo-unsigned: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-2-8-raw.mov -f s16le | |||
| FATE_TESTS += fate-qt-rawpcm-16bit-stereo-signed-be | |||
| fate-qt-rawpcm-16bit-stereo-signed-be: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-2-16-B-twos.mov -f s16le | |||
| FATE_TESTS += fate-qt-rawpcm-16bit-stereo-signed-le | |||
| fate-qt-rawpcm-16bit-stereo-signed-le: CMD = md5 -i $(SAMPLES)/qt-surge-suite/surge-2-16-L-sowt.mov -f s16le | |||
| FATE_TESTS += fate-w64 | |||
| fate-w64: CMD = crc -i $(SAMPLES)/w64/w64-pcm16.w64 | |||
| @@ -87,3 +87,6 @@ fate-v410enc: CMD = md5 -f image2 -vcodec pgmyuv -i $(TARGET_PATH)/tests/vsynth1 | |||
| FATE_TESTS += fate-r210 | |||
| fate-r210: CMD = framecrc -i $(SAMPLES)/r210/r210.avi -pix_fmt rgb48le | |||
| FATE_TESTS += fate-xxan_wc4_video | |||
| fate-xxan_wc4_video: CMD = framecrc -i $(SAMPLES)/wc4-xan/wc4_2.avi -an -vframes 10 | |||
| @@ -0,0 +1,30 @@ | |||
| 0, 0, 115200, 0xb8830eef | |||
| 0, 3600, 115200, 0xb8830eef | |||
| 0, 7200, 115200, 0xb8830eef | |||
| 0, 10800, 115200, 0x952ff5e1 | |||
| 0, 14400, 115200, 0xa4362b14 | |||
| 0, 18000, 115200, 0x32bacbe7 | |||
| 0, 21600, 115200, 0x509eb814 | |||
| 0, 25200, 115200, 0x509eb814 | |||
| 0, 28800, 115200, 0x11a76c3e | |||
| 0, 32400, 115200, 0x11a76c3e | |||
| 0, 36000, 115200, 0x00cf734a | |||
| 0, 39600, 115200, 0x00cf734a | |||
| 0, 43200, 115200, 0x00cf734a | |||
| 0, 46800, 115200, 0x00cf734a | |||
| 0, 50400, 115200, 0x00cf734a | |||
| 0, 54000, 115200, 0x00cf734a | |||
| 0, 57600, 115200, 0x00cf734a | |||
| 0, 61200, 115200, 0x00cf734a | |||
| 0, 64800, 115200, 0xfddf48e6 | |||
| 0, 68400, 115200, 0xfddf48e6 | |||
| 0, 72000, 115200, 0x1eccebbf | |||
| 0, 75600, 115200, 0x3da2f77e | |||
| 0, 79200, 115200, 0x7c232572 | |||
| 0, 82800, 115200, 0xedf426e5 | |||
| 0, 86400, 115200, 0x5324ab20 | |||
| 0, 90000, 115200, 0x5324ab20 | |||
| 0, 93600, 115200, 0xa23e66bb | |||
| 0, 97200, 115200, 0x680a50ff | |||
| 0, 100800, 115200, 0x680a50ff | |||
| 0, 104400, 115200, 0x680a50ff | |||
| @@ -0,0 +1,30 @@ | |||
| 0, 0, 518400, 0xae20b4fa | |||
| 0, 3600, 518400, 0x2b4ccdf9 | |||
| 0, 7200, 518400, 0x2b4ccdf9 | |||
| 0, 10800, 518400, 0x2b4ccdf9 | |||
| 0, 14400, 518400, 0x2b4ccdf9 | |||
| 0, 18000, 518400, 0x2b4ccdf9 | |||
| 0, 21600, 518400, 0x70d9a891 | |||
| 0, 25200, 518400, 0x70d9a891 | |||
| 0, 28800, 518400, 0x70d9a891 | |||
| 0, 32400, 518400, 0xa461ee86 | |||
| 0, 36000, 518400, 0x722bc6e8 | |||
| 0, 39600, 518400, 0x722bc6e8 | |||
| 0, 43200, 518400, 0x722bc6e8 | |||
| 0, 46800, 518400, 0xf752fd2c | |||
| 0, 50400, 518400, 0xf752fd2c | |||
| 0, 54000, 518400, 0x91abcaca | |||
| 0, 57600, 518400, 0x572727c3 | |||
| 0, 61200, 518400, 0x572727c3 | |||
| 0, 64800, 518400, 0x24c12382 | |||
| 0, 68400, 518400, 0x24c12382 | |||
| 0, 72000, 518400, 0x9aa39fe8 | |||
| 0, 75600, 518400, 0x9aa39fe8 | |||
| 0, 79200, 518400, 0x5cb6bd19 | |||
| 0, 82800, 518400, 0x704d9300 | |||
| 0, 86400, 518400, 0x590fad49 | |||
| 0, 90000, 518400, 0x590fad49 | |||
| 0, 93600, 518400, 0x590fad49 | |||
| 0, 97200, 518400, 0x46bea10b | |||
| 0, 100800, 518400, 0x46bea10b | |||
| 0, 104400, 518400, 0x46bea10b | |||
| @@ -0,0 +1,60 @@ | |||
| 0, 0, 506880, 0x884bc093 | |||
| 0, 3600, 506880, 0x4b09548f | |||
| 0, 7200, 506880, 0x195cbee1 | |||
| 0, 10800, 506880, 0xc8141e28 | |||
| 0, 14400, 506880, 0xb170c49b | |||
| 0, 18000, 506880, 0x2782268a | |||
| 0, 21600, 506880, 0x2782268a | |||
| 0, 25200, 506880, 0x2782268a | |||
| 0, 28800, 506880, 0x2782268a | |||
| 0, 32400, 506880, 0xe6803b32 | |||
| 0, 36000, 506880, 0xe6803b32 | |||
| 0, 39600, 506880, 0xa5ef9baf | |||
| 0, 43200, 506880, 0xa5ef9baf | |||
| 0, 46800, 506880, 0x46e8cbcb | |||
| 0, 50400, 506880, 0x28a2239b | |||
| 0, 54000, 506880, 0x7667af2f | |||
| 0, 57600, 506880, 0x7667af2f | |||
| 0, 61200, 506880, 0x8011bcaf | |||
| 0, 64800, 506880, 0xd422115b | |||
| 0, 68400, 506880, 0xd422115b | |||
| 0, 72000, 506880, 0xd422115b | |||
| 0, 75600, 506880, 0xbcee0b5b | |||
| 0, 79200, 506880, 0x08fe9ec8 | |||
| 0, 82800, 506880, 0xc8fb8b37 | |||
| 0, 86400, 506880, 0xc8fb8b37 | |||
| 0, 90000, 506880, 0x2c698b52 | |||
| 0, 93600, 506880, 0x2c698b52 | |||
| 0, 97200, 506880, 0x2c698b52 | |||
| 0, 100800, 506880, 0x2b4ad9bc | |||
| 0, 104400, 506880, 0x2b4ad9bc | |||
| 0, 108000, 506880, 0x2b4ad9bc | |||
| 0, 111600, 506880, 0x2b4ad9bc | |||
| 0, 115200, 506880, 0x92e84ebb | |||
| 0, 118800, 506880, 0x92e84ebb | |||
| 0, 122400, 506880, 0xdb877da3 | |||
| 0, 126000, 506880, 0xdb877da3 | |||
| 0, 129600, 506880, 0xdb877da3 | |||
| 0, 133200, 506880, 0x44610654 | |||
| 0, 136800, 506880, 0x44610654 | |||
| 0, 140400, 506880, 0xe254ce67 | |||
| 0, 144000, 506880, 0xa6085385 | |||
| 0, 147600, 506880, 0x2d45d744 | |||
| 0, 151200, 506880, 0x2d45d744 | |||
| 0, 154800, 506880, 0x6e684f51 | |||
| 0, 158400, 506880, 0xe96186cf | |||
| 0, 162000, 506880, 0xb535d369 | |||
| 0, 165600, 506880, 0xb535d369 | |||
| 0, 169200, 506880, 0xb535d369 | |||
| 0, 172800, 506880, 0xeed0b7e0 | |||
| 0, 176400, 506880, 0xeed0b7e0 | |||
| 0, 180000, 506880, 0xeed0b7e0 | |||
| 0, 183600, 506880, 0xeed0b7e0 | |||
| 0, 187200, 506880, 0x8789b20b | |||
| 0, 190800, 506880, 0x0a0f42fb | |||
| 0, 194400, 506880, 0x09bbac2d | |||
| 0, 198000, 506880, 0x09bbac2d | |||
| 0, 201600, 506880, 0x09bbac2d | |||
| 0, 205200, 506880, 0x09bbac2d | |||
| 0, 208800, 506880, 0x09bbac2d | |||
| 0, 212400, 506880, 0xda77f0df | |||
| @@ -0,0 +1,10 @@ | |||
| 0, 0, 79360, 0x877eb3ed | |||
| 0, 6000, 79360, 0x9ff8707c | |||
| 0, 12000, 79360, 0x144dec86 | |||
| 0, 18000, 79360, 0x56d59588 | |||
| 0, 24000, 79360, 0x2d20f8ce | |||
| 0, 30000, 79360, 0x1a752c42 | |||
| 0, 36000, 79360, 0x85705730 | |||
| 0, 42000, 79360, 0xddea3741 | |||
| 0, 48000, 79360, 0x46448efd | |||
| 0, 54000, 79360, 0x27186e2b | |||
| @@ -137,17 +137,17 @@ int main(int argc, char *argv[]) | |||
| start_offset = ftello(infile); | |||
| } else { | |||
| /* 64-bit special case */ | |||
| if (atom_size == 1) { | |||
| if (fread(atom_bytes, ATOM_PREAMBLE_SIZE, 1, infile) != 1) { | |||
| break; | |||
| /* 64-bit special case */ | |||
| if (atom_size == 1) { | |||
| if (fread(atom_bytes, ATOM_PREAMBLE_SIZE, 1, infile) != 1) { | |||
| break; | |||
| } | |||
| atom_size = BE_64(&atom_bytes[0]); | |||
| fseeko(infile, atom_size - ATOM_PREAMBLE_SIZE * 2, SEEK_CUR); | |||
| } else { | |||
| fseeko(infile, atom_size - ATOM_PREAMBLE_SIZE, SEEK_CUR); | |||
| } | |||
| atom_size = BE_64(&atom_bytes[0]); | |||
| fseeko(infile, atom_size - ATOM_PREAMBLE_SIZE * 2, SEEK_CUR); | |||
| } else { | |||
| fseeko(infile, atom_size - ATOM_PREAMBLE_SIZE, SEEK_CUR); | |||
| } | |||
| } | |||
| printf("%c%c%c%c %10"PRIu64" %"PRIu64"\n", | |||
| (atom_type >> 24) & 255, | |||
| (atom_type >> 16) & 255, | |||