From 7523772886ca37cf05d0ad5b24f6d520e314242e Mon Sep 17 00:00:00 2001 From: jacqueline Date: Mon, 16 Oct 2023 13:52:43 +1100 Subject: Decouple play/pause from output on/off I think this was the cause of toggling play/pause making audio go away. Or at least I can't repro that bug anymore, anyway. --- src/drivers/i2s_dac.cpp | 47 ++++++++++++++++++++++------------------------- 1 file changed, 22 insertions(+), 25 deletions(-) (limited to 'src/drivers/i2s_dac.cpp') diff --git a/src/drivers/i2s_dac.cpp b/src/drivers/i2s_dac.cpp index b28a8ee1..9ff6e380 100644 --- a/src/drivers/i2s_dac.cpp +++ b/src/drivers/i2s_dac.cpp @@ -111,38 +111,23 @@ I2SDac::~I2SDac() { auto I2SDac::Start() -> void { std::lock_guard lock(configure_mutex_); - - gpio_.WriteSync(IGpios::Pin::kAmplifierUnmute, false); - - // Ensure the DAC powers up to a muted state. - wm8523::WriteRegister(wm8523::Register::kPsCtrl, 0b10); - - // Enable MCLK; this has the side effect of triggering the DAC's startup - // sequence. - i2s_channel_enable(i2s_handle_); - i2s_active_ = true; - wm8523::WriteRegister(wm8523::Register::kPsCtrl, 0b11); - gpio_.WriteSync(IGpios::Pin::kAmplifierUnmute, true); } auto I2SDac::Stop() -> void { std::lock_guard lock(configure_mutex_); - - // Mute the DAC. - wm8523::WriteRegister(wm8523::Register::kPsCtrl, 0b10); - vTaskDelay(pdMS_TO_TICKS(5)); - // Silence the output. - gpio_.WriteSync(IGpios::Pin::kAmplifierUnmute, false); - - vTaskDelay(pdMS_TO_TICKS(5)); - - // Turn everything off. + set_channel(false); wm8523::WriteRegister(wm8523::Register::kPsCtrl, 0b0); - i2s_channel_disable(i2s_handle_); - i2s_active_ = false; +} - gpio_.WriteSync(IGpios::Pin::kAmplifierEnable, false); +auto I2SDac::SetPaused(bool paused) -> void { + if (paused) { + gpio_.WriteSync(IGpios::Pin::kAmplifierUnmute, false); + set_channel(false); + } else { + set_channel(true); + gpio_.WriteSync(IGpios::Pin::kAmplifierUnmute, true); + } } auto I2SDac::Reconfigure(Channels ch, BitsPerSample bps, SampleRate rate) @@ -261,4 +246,16 @@ auto I2SDac::SetSource(StreamBufferHandle_t buffer) -> void { } } +auto I2SDac::set_channel(bool enabled) -> void { + if (i2s_active_ == enabled) { + return; + } + i2s_active_ = enabled; + if (enabled) { + i2s_channel_enable(i2s_handle_); + } else { + i2s_channel_disable(i2s_handle_); + } +} + } // namespace drivers -- cgit v1.2.3