esp32s2: i2s: fix accounting for "stretched" frames

This commit is contained in:
Jeff Epler 2021-01-07 16:28:33 -06:00
parent 010a4e7b0f
commit 352226402c

View File

@ -103,9 +103,9 @@ static void i2s_fill_buffer(i2s_t *self) {
} }
} else { } else {
#define STACK_BUFFER_SIZE (64) #define STACK_BUFFER_SIZE (64)
size_t bytes_per_frame = self->channel_count * self->bytes_per_sample; const size_t bytes_per_output_frame = 4;
size_t framecount = MIN(STACK_BUFFER_SIZE / bytes_per_frame, bytecount); size_t bytes_per_input_frame = self->channel_count * self->bytes_per_sample;
int16_t signed_samples[STACK_BUFFER_SIZE / sizeof(int16_t)]; size_t framecount = MIN(STACK_BUFFER_SIZE / bytes_per_output_frame, bytecount / bytes_per_input_frame);
if (self->samples_signed) { if (self->samples_signed) {
assert(self->channel_count == 1); assert(self->channel_count == 1);
if (self->bytes_per_sample == 1) { if (self->bytes_per_sample == 1) {
@ -129,9 +129,9 @@ static void i2s_fill_buffer(i2s_t *self) {
} }
} }
size_t expanded_bytes_written = 0; size_t expanded_bytes_written = 0;
ESP_CALL_RAISE(i2s_write(self->instance, signed_samples, 4*framecount, &expanded_bytes_written, 0)); ESP_CALL_RAISE(i2s_write(self->instance, signed_samples, bytes_per_output_frame*framecount, &expanded_bytes_written, 0));
assert(expanded_bytes_written % 4 == 0); assert(expanded_bytes_written % 4 == 0);
bytes_written = expanded_bytes_written / 4 * bytes_per_frame; bytes_written = expanded_bytes_written / bytes_per_output_frame * bytes_per_input_frame;
} }
self->sample_data += bytes_written; self->sample_data += bytes_written;
// We have filled the DMA buffer // We have filled the DMA buffer
@ -181,6 +181,10 @@ void port_i2s_allocate_init(i2s_t *self, bool left_justified) {
void port_i2s_play(i2s_t *self, mp_obj_t sample, bool loop) { void port_i2s_play(i2s_t *self, mp_obj_t sample, bool loop) {
if (common_hal_audiobusio_i2sout_get_playing(self)) {
common_hal_audiobusio_i2sout_stop(self);
}
self->sample = sample; self->sample = sample;
self->bytes_per_sample = audiosample_bits_per_sample(sample) / 8; self->bytes_per_sample = audiosample_bits_per_sample(sample) / 8;
self->channel_count = audiosample_channel_count(sample); self->channel_count = audiosample_channel_count(sample);