struct mad_synth synth;
};
+/* TODO: Convert all input if possible */
+#define FRAME_HEADER_SIZE 4
static ssize_t mp3dec(char *inbuffer, size_t len, struct filter_node *fn)
{
int i, ret;
mad_stream_buffer(&pmd->stream, (unsigned char *) inbuffer, copy);
pmd->stream.error = 0;
next_frame:
+ ret = mad_header_decode(&pmd->frame.header, &pmd->stream);
+ if (ret < 0) {
+ if (!MAD_RECOVERABLE(pmd->stream.error))
+ goto out;
+ return FRAME_HEADER_SIZE;
+ }
+ fn->fci->samplerate = pmd->frame.header.samplerate;
+ fn->fci->channels = MAD_NCHANNELS(&pmd->frame.header);
ret = mad_frame_decode(&pmd->frame, &pmd->stream);
if (ret) {
if (MAD_RECOVERABLE(pmd->stream.error) || pmd->stream.error == MAD_ERROR_BUFLEN)
return -E_MAD_FRAME_DECODE;
}
mad_synth_frame(&pmd->synth, &pmd->frame);
- fn->fci->samplerate = pmd->frame.header.samplerate;
- fn->fci->channels = MAD_NCHANNELS(&pmd->frame.header);
for (i = 0; i < pmd->synth.pcm.length; i++) {
/* output format: unsigned 16 bit little endian */
out:
if (pmd->stream.next_frame) { /* we still have some data */
size_t off = pmd->stream.bufend - pmd->stream.next_frame;
- PARA_DEBUG_LOG("converted %zd, %zd input bytes, %zd output bytes\n",
- len - off, off, fn->loaded);
+ PARA_DEBUG_LOG("converted %zd, rate: %u, returning %zd\n", len - off,
+ fn->fci->samplerate, copy - off);
return copy - off;
}
return copy;