summaryrefslogtreecommitdiff
path: root/src/audio/fatfs_audio_input.cpp
diff options
context:
space:
mode:
authorjacqueline <me@jacqueline.id.au>2023-01-31 16:35:52 +1100
committerjacqueline <me@jacqueline.id.au>2023-01-31 16:35:52 +1100
commit9eecf78e08e26b488e6a88947611eb89e9870fb0 (patch)
tree7e61e3100f55272a896c085c9f8f4e0cfe30c5cd /src/audio/fatfs_audio_input.cpp
parentaae18719991c29a286d69661264d261004ee7aeb (diff)
downloadtangara-fw-9eecf78e08e26b488e6a88947611eb89e9870fb0.tar.gz
fixing reading past eof
Diffstat (limited to 'src/audio/fatfs_audio_input.cpp')
-rw-r--r--src/audio/fatfs_audio_input.cpp5
1 files changed, 3 insertions, 2 deletions
diff --git a/src/audio/fatfs_audio_input.cpp b/src/audio/fatfs_audio_input.cpp
index 14176eae..08f39347 100644
--- a/src/audio/fatfs_audio_input.cpp
+++ b/src/audio/fatfs_audio_input.cpp
@@ -20,7 +20,7 @@ static const char* kTag = "SRC";
namespace audio {
// 32KiB to match the minimum himen region size.
-static const std::size_t kChunkSize = 32 * 1024;
+static const std::size_t kChunkSize = 24 * 1024;
FatfsAudioInput::FatfsAudioInput(std::shared_ptr<drivers::SdStorage> storage)
: IAudioElement(),
@@ -88,7 +88,8 @@ auto FatfsAudioInput::Process() -> cpp::result<void, AudioProcessingError> {
dest_event->chunk_data.bytes.first(bytes_read);
SendOrBufferEvent(std::move(dest_event));
- if (f_eof(&current_file_)) {
+ if (bytes_read < kChunkSize || f_eof(&current_file_)) {
+ ESP_LOGI(kTag, "closing file");
f_close(&current_file_);
is_file_open_ = false;
}