From c635d5011c37c02246135fe0df404631ec111bd6 Mon Sep 17 00:00:00 2001 From: jacqueline Date: Wed, 16 Aug 2023 11:40:49 +1000 Subject: Put more audio pipeline wiring in control of the audio fsm --- src/audio/audio_task.cpp | 15 ++++++--------- 1 file changed, 6 insertions(+), 9 deletions(-) (limited to 'src/audio/audio_task.cpp') diff --git a/src/audio/audio_task.cpp b/src/audio/audio_task.cpp index 1ebd4e46..99b1c170 100644 --- a/src/audio/audio_task.cpp +++ b/src/audio/audio_task.cpp @@ -76,19 +76,16 @@ auto Timer::AddSamples(std::size_t samples) -> void { } } -auto AudioTask::Start(IAudioSource* source, IAudioSink* sink) -> AudioTask* { +auto AudioTask::Start(std::shared_ptr source, + std::shared_ptr sink) -> AudioTask* { AudioTask* task = new AudioTask(source, sink); tasks::StartPersistent([=]() { task->Main(); }); return task; } -AudioTask::AudioTask(IAudioSource* source, IAudioSink* sink) - : source_(source), - sink_(sink), - codec_(), - mixer_(new SinkMixer(sink)), - timer_(), - current_format_() { +AudioTask::AudioTask(std::shared_ptr source, + std::shared_ptr mixer) + : source_(source), mixer_(mixer), codec_(), timer_(), current_format_() { codec_buffer_ = { reinterpret_cast(heap_caps_calloc( kCodecBufferLength, sizeof(sample::Sample), MALLOC_CAP_SPIRAM)), @@ -133,7 +130,7 @@ auto AudioTask::BeginDecoding(std::shared_ptr stream) -> bool { timer_.reset(); } - current_sink_format_ = IAudioSink::Format{ + current_sink_format_ = IAudioOutput::Format{ .sample_rate = open_res->sample_rate_hz, .num_channels = open_res->num_channels, .bits_per_sample = 16, -- cgit v1.2.3