From d75aa4dbf79e4c780705881908415c2012fc5222 Mon Sep 17 00:00:00 2001 From: zml1206 Date: Thu, 25 Jul 2024 18:37:10 +0800 Subject: [PATCH 1/2] [VL] Fix std::min parameter type mismatch in macOS fix --- cpp/velox/shuffle/VeloxSortShuffleWriter.cc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cpp/velox/shuffle/VeloxSortShuffleWriter.cc b/cpp/velox/shuffle/VeloxSortShuffleWriter.cc index cb81ea5f6c8a..4a7a403484cd 100644 --- a/cpp/velox/shuffle/VeloxSortShuffleWriter.cc +++ b/cpp/velox/shuffle/VeloxSortShuffleWriter.cc @@ -278,7 +278,7 @@ uint32_t VeloxSortShuffleWriter::maxRowsToInsert(uint32_t offset, uint32_t rows) } void VeloxSortShuffleWriter::acquireNewBuffer(int64_t memLimit, uint64_t minSizeRequired) { - auto size = std::max(std::min((uint64_t)memLimit >> 2, 64UL * 1024 * 1024), minSizeRequired); + auto size = std::max(std::min(memLimit >> 2, 64UL * 1024 * 1024), minSizeRequired); // Allocating new buffer can trigger spill. auto newBuffer = facebook::velox::AlignedBuffer::allocate(size, veloxPool_.get(), 0); pages_.emplace_back(std::move(newBuffer)); From 868fa5361a8a009a7761ff17e3f00ad732ebe6e3 Mon Sep 17 00:00:00 2001 From: zml1206 Date: Fri, 26 Jul 2024 08:02:03 +0800 Subject: [PATCH 2/2] update --- cpp/velox/shuffle/VeloxSortShuffleWriter.cc | 4 ++-- cpp/velox/shuffle/VeloxSortShuffleWriter.h | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/cpp/velox/shuffle/VeloxSortShuffleWriter.cc b/cpp/velox/shuffle/VeloxSortShuffleWriter.cc index 4a7a403484cd..7c033fb98bf8 100644 --- a/cpp/velox/shuffle/VeloxSortShuffleWriter.cc +++ b/cpp/velox/shuffle/VeloxSortShuffleWriter.cc @@ -161,7 +161,7 @@ arrow::Status VeloxSortShuffleWriter::insert(const facebook::velox::RowVectorPtr auto rows = maxRowsToInsert(rowOffset, remainingRows); if (rows == 0) { auto minSizeRequired = fixedRowSize_ ? fixedRowSize_.value() : rowSizes_[rowOffset + 1] - rowSizes_[rowOffset]; - acquireNewBuffer(memLimit, minSizeRequired); + acquireNewBuffer((uint64_t)memLimit, minSizeRequired); rows = maxRowsToInsert(rowOffset, remainingRows); ARROW_RETURN_IF( rows == 0, arrow::Status::Invalid("Failed to insert rows. Remaining rows: " + std::to_string(remainingRows))); @@ -277,7 +277,7 @@ uint32_t VeloxSortShuffleWriter::maxRowsToInsert(uint32_t offset, uint32_t rows) return iter - beginIter; } -void VeloxSortShuffleWriter::acquireNewBuffer(int64_t memLimit, uint64_t minSizeRequired) { +void VeloxSortShuffleWriter::acquireNewBuffer(uint64_t memLimit, uint64_t minSizeRequired) { auto size = std::max(std::min(memLimit >> 2, 64UL * 1024 * 1024), minSizeRequired); // Allocating new buffer can trigger spill. auto newBuffer = facebook::velox::AlignedBuffer::allocate(size, veloxPool_.get(), 0); diff --git a/cpp/velox/shuffle/VeloxSortShuffleWriter.h b/cpp/velox/shuffle/VeloxSortShuffleWriter.h index 8f01997b11e1..6ac5308d0bd8 100644 --- a/cpp/velox/shuffle/VeloxSortShuffleWriter.h +++ b/cpp/velox/shuffle/VeloxSortShuffleWriter.h @@ -76,7 +76,7 @@ class VeloxSortShuffleWriter final : public VeloxShuffleWriter { uint32_t maxRowsToInsert(uint32_t offset, uint32_t rows); - void acquireNewBuffer(int64_t memLimit, uint64_t minSizeRequired); + void acquireNewBuffer(uint64_t memLimit, uint64_t minSizeRequired); void growArrayIfNecessary(uint32_t rows);