From 3eeec1bdb79c6d4815c510cd96f4f83e7bf46b1f Mon Sep 17 00:00:00 2001 From: Gera Shegalov Date: Tue, 28 Nov 2023 14:34:58 -0800 Subject: [PATCH] Make DefaultHostMemoryAllocator settable spark-rapids requires the ability to set DefaultHostMemoryAllocator Contributes to NVIDIA/spark-rapids#9862 Signed-off-by: Gera Shegalov --- .../cudf/DefaultHostMemoryAllocator.java | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/java/src/main/java/ai/rapids/cudf/DefaultHostMemoryAllocator.java b/java/src/main/java/ai/rapids/cudf/DefaultHostMemoryAllocator.java index 98a5b00cf85..469c8d16fe4 100644 --- a/java/src/main/java/ai/rapids/cudf/DefaultHostMemoryAllocator.java +++ b/java/src/main/java/ai/rapids/cudf/DefaultHostMemoryAllocator.java @@ -19,9 +19,23 @@ package ai.rapids.cudf; public class DefaultHostMemoryAllocator implements HostMemoryAllocator { - private static final HostMemoryAllocator INSTANCE = new DefaultHostMemoryAllocator(); + private static volatile HostMemoryAllocator instance = new DefaultHostMemoryAllocator(); + + /** + * Retrieve current host memory allocator used by default if not passed directly to API + * + * @return current default HostMemoryAllocator implementation + */ public static HostMemoryAllocator get() { - return INSTANCE; + return instance; + } + + /** + * Sets a new default host memory allocator implementation by default. + * @param hostMemoryAllocator + */ + public static void set(HostMemoryAllocator hostMemoryAllocator) { + instance = hostMemoryAllocator; } @Override