From e11f950cb5c8e2f34adf34fd5c427f55062d6a2f Mon Sep 17 00:00:00 2001 From: Mark Raasveldt Date: Mon, 28 Oct 2024 16:54:03 +0100 Subject: [PATCH] Fix #87 - actually disable buffering when RequireParallelAccess is set --- src/azure_filesystem.cpp | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/src/azure_filesystem.cpp b/src/azure_filesystem.cpp index c3d2de1..fb4cfd8 100644 --- a/src/azure_filesystem.cpp +++ b/src/azure_filesystem.cpp @@ -28,13 +28,9 @@ AzureFileHandle::AzureFileHandle(AzureStorageFileSystem &fs, string path, FileOp buffer_available(0), buffer_idx(0), file_offset(0), buffer_start(0), buffer_end(0), // Options read_options(read_options) { - if (flags.OpenForReading()) { + if (!flags.RequireParallelAccess() && !flags.DirectIO()) { read_buffer = duckdb::unique_ptr(new data_t[read_options.buffer_size]); } - if (flags.RequireParallelAccess()) { - // use direct i/o if parallel access is required - flags |= FileOpenFlags(FileOpenFlags::FILE_FLAGS_DIRECT_IO); - } } bool AzureFileHandle::PostConstruct() { @@ -102,7 +98,10 @@ void AzureStorageFileSystem::Read(FileHandle &handle, void *buffer, int64_t nr_b idx_t buffer_offset = 0; // Don't buffer when DirectIO is set. - if (hfh.flags.DirectIO() && to_read > 0) { + if (hfh.flags.DirectIO() || hfh.flags.RequireParallelAccess()) { + if (to_read == 0) { + return; + } ReadRange(hfh, location, (char *)buffer, to_read); hfh.buffer_available = 0; hfh.buffer_idx = 0;