decoder/dsf: make the "scratch" buffer local

This allows the compiler to discard buffer contents between two
function calls.
This commit is contained in:
Max Kellermann 2014-08-21 13:05:35 +02:00
parent 455fd180b1
commit 57cbcdf2ec

View File

@ -193,8 +193,11 @@ bit_reverse_buffer(uint8_t *p, uint8_t *end)
* order. * order.
*/ */
static void static void
dsf_to_pcm_order(uint8_t *dest, uint8_t *scratch, size_t nrbytes) dsf_to_pcm_order(uint8_t *dest, size_t nrbytes)
{ {
uint8_t scratch[8192];
assert(nrbytes <= sizeof(scratch));
for (unsigned i = 0, j = 0; i < (unsigned)nrbytes; i += 2) { for (unsigned i = 0, j = 0; i < (unsigned)nrbytes; i += 2) {
scratch[i] = *(dest+j); scratch[i] = *(dest+j);
j++; j++;
@ -222,10 +225,6 @@ dsf_decode_chunk(Decoder &decoder, InputStream &is,
{ {
uint8_t buffer[8192]; uint8_t buffer[8192];
/* scratch buffer for DSF samples to convert to the needed
normal left/right regime of samples */
uint8_t dsf_scratch_buffer[8192];
const size_t sample_size = sizeof(buffer[0]); const size_t sample_size = sizeof(buffer[0]);
const size_t frame_size = channels * sample_size; const size_t frame_size = channels * sample_size;
const unsigned buffer_frames = sizeof(buffer) / frame_size; const unsigned buffer_frames = sizeof(buffer) / frame_size;
@ -250,7 +249,7 @@ dsf_decode_chunk(Decoder &decoder, InputStream &is,
if (bitreverse) if (bitreverse)
bit_reverse_buffer(buffer, buffer + nbytes); bit_reverse_buffer(buffer, buffer + nbytes);
dsf_to_pcm_order(buffer, dsf_scratch_buffer, nbytes); dsf_to_pcm_order(buffer, nbytes);
const auto cmd = decoder_data(decoder, is, buffer, nbytes, const auto cmd = decoder_data(decoder, is, buffer, nbytes,
sample_rate / 1000); sample_rate / 1000);