mpc: make the buffer large enough for one mpc frame

Don't split the buffer conversion loop.  When libmpcdec returns a
chunk, convert and send the whole chunk at a time.  This moves several
checks out of the loop, and greatly improves performance.
This commit is contained in:
Max Kellermann 2008-11-12 07:03:44 +01:00
parent 865757835e
commit 975d5cd77e

View File

@ -108,8 +108,7 @@ mpc_decode(struct decoder *mpd_decoder, struct input_stream *inStream)
MPC_SAMPLE_FORMAT sample_buffer[MPC_DECODER_BUFFER_LENGTH]; MPC_SAMPLE_FORMAT sample_buffer[MPC_DECODER_BUFFER_LENGTH];
long ret; long ret;
#define MPC_CHUNK_SIZE 4096 int32_t chunk[G_N_ELEMENTS(sample_buffer)];
int32_t chunk[MPC_CHUNK_SIZE / sizeof(int32_t)];
int chunkpos = 0; int chunkpos = 0;
long bitRate = 0; long bitRate = 0;
int32_t *dest = chunk; int32_t *dest = chunk;
@ -188,38 +187,22 @@ mpc_decode(struct decoder *mpd_decoder, struct input_stream *inStream)
for (i = 0; i < ret; i++) { for (i = 0; i < ret; i++) {
*dest++ = convertSample(sample_buffer[i]); *dest++ = convertSample(sample_buffer[i]);
chunkpos += sizeof(*dest); chunkpos += sizeof(*dest);
}
if (chunkpos >= MPC_CHUNK_SIZE) { total_time = ((float)samplePos) / audio_format.sample_rate;
total_time = ((float)samplePos) / bitRate = vbrUpdateBits * audio_format.sample_rate
audio_format.sample_rate; / 1152 / 1000;
bitRate = vbrUpdateBits *
audio_format.sample_rate / 1152 / 1000;
decoder_data(mpd_decoder, inStream, decoder_data(mpd_decoder, inStream,
chunk, chunkpos, chunk, chunkpos,
total_time, total_time,
bitRate, replayGainInfo); bitRate, replayGainInfo);
chunkpos = 0;
dest = chunk; dest = chunk;
if (decoder_get_command(mpd_decoder) == DECODE_COMMAND_STOP) if (decoder_get_command(mpd_decoder) == DECODE_COMMAND_STOP)
break; break;
} }
}
}
if (decoder_get_command(mpd_decoder) != DECODE_COMMAND_STOP &&
chunkpos > 0) {
total_time = ((float)samplePos) / audio_format.sample_rate;
bitRate =
vbrUpdateBits * audio_format.sample_rate / 1152 / 1000;
decoder_data(mpd_decoder, NULL,
chunk, chunkpos, total_time, bitRate,
replayGainInfo);
}
replay_gain_info_free(replayGainInfo); replay_gain_info_free(replayGainInfo);
} }