* 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, | |||