Commit 4060d584 authored by mru's avatar mru

decode adts aac streams


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@4953 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent fcf54151
......@@ -49,9 +49,8 @@ static const char* libfaadname = "libfaad.so.0";
typedef struct {
void* handle; /* dlopen handle */
void* faac_handle; /* FAAD library handle */
int frame_size;
int sample_size;
int flags;
int init;
/* faad calls */
faacDecHandle FAADAPI (*faacDecOpen)(void);
......@@ -111,17 +110,20 @@ static int faac_init_mp4(AVCodecContext *avctx)
#endif
int r = 0;
if (avctx->extradata)
if (avctx->extradata){
r = s->faacDecInit2(s->faac_handle, (uint8_t*) avctx->extradata,
avctx->extradata_size,
&samplerate, &channels);
// else r = s->faacDecInit(s->faac_handle ... );
if (r < 0)
av_log(avctx, AV_LOG_ERROR, "faacDecInit2 failed r:%d sr:%ld ch:%ld s:%d\n",
r, samplerate, (long)channels, avctx->extradata_size);
avctx->sample_rate = samplerate;
avctx->channels = channels;
if (r < 0){
av_log(avctx, AV_LOG_ERROR,
"faacDecInit2 failed r:%d sr:%ld ch:%ld s:%d\n",
r, samplerate, (long)channels, avctx->extradata_size);
} else {
avctx->sample_rate = samplerate;
avctx->channels = channels;
s->init = 1;
}
}
return r;
}
......@@ -155,6 +157,20 @@ static int faac_decode_frame(AVCodecContext *avctx,
? buf_size : (int)bytesconsumed;
#else
if(!s->init){
unsigned long srate;
unsigned char channels;
int r = faacDecInit(s->faac_handle, buf, buf_size, &srate, &channels);
if(r < 0){
av_log(avctx, AV_LOG_ERROR, "faac: codec init failed: %s\n",
s->faacDecGetErrorMessage(frame_info.error));
return 0;
}
avctx->sample_rate = srate;
avctx->channels = channels;
s->init = 1;
}
out = s->faacDecDecode(s->faac_handle, &frame_info, (unsigned char*)buf, (unsigned long)buf_size);
if (frame_info.error > 0) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment