diff options
| author | jacqueline <me@jacqueline.id.au> | 2022-12-07 15:36:47 +1100 |
|---|---|---|
| committer | jacqueline <me@jacqueline.id.au> | 2022-12-07 15:36:47 +1100 |
| commit | 01be69eca1fa89c047fc29f5cb0ea8ba0898dad1 (patch) | |
| tree | d40f749b3ebf6327f13d51d585f7c315a6d864c3 /src/audio/include/i2s_audio_output.hpp | |
| parent | f35bb64c2b8dbb72fd15f1880e4d01d263660910 (diff) | |
| download | tangara-fw-01be69eca1fa89c047fc29f5cb0ea8ba0898dad1.tar.gz | |
better handling of chunk buffer
Diffstat (limited to 'src/audio/include/i2s_audio_output.hpp')
| -rw-r--r-- | src/audio/include/i2s_audio_output.hpp | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/src/audio/include/i2s_audio_output.hpp b/src/audio/include/i2s_audio_output.hpp index 4b4a458d..9e59f8fd 100644 --- a/src/audio/include/i2s_audio_output.hpp +++ b/src/audio/include/i2s_audio_output.hpp @@ -16,13 +16,17 @@ class I2SAudioOutput : public IAudioElement { public: enum Error { DAC_CONFIG, I2S_CONFIG, STREAM_INIT }; static auto create(drivers::GpioExpander* expander) - -> cpp::result<std::unique_ptr<I2SAudioOutput>, Error>; + -> cpp::result<std::shared_ptr<I2SAudioOutput>, Error>; I2SAudioOutput(drivers::GpioExpander* expander, std::unique_ptr<drivers::AudioDac> dac); ~I2SAudioOutput(); - auto SetInputBuffer(MessageBufferHandle_t* in) -> void { input_buffer_ = in; } + auto InputMinChunkSize() const -> std::size_t override { + // TODO(jacqueline): work out a good value here. Maybe similar to the total + // DMA buffer size? + return 128; + } auto IdleTimeout() const -> TickType_t override; auto ProcessStreamInfo(const StreamInfo& info) |
