diff --git a/ci/release/update-version.sh b/ci/release/update-version.sh index 98dcc2ad0..cacfd94c1 100755 --- a/ci/release/update-version.sh +++ b/ci/release/update-version.sh @@ -34,7 +34,7 @@ function sed_runner() { # Bump cudf and dask-cudf testing dependencies sed_runner "s/cudf=.*/cudf=${NEXT_SHORT_TAG}/g" dependencies.yaml sed_runner "s/dask-cudf=.*/dask-cudf=${NEXT_SHORT_TAG}/g" dependencies.yaml -sed_runner "s/cucim=.*/cucim=${NEXT_SHORT_TAG}/g" dependencies.yaml +sed_runner "s/kvikio=.*/kvikio=${NEXT_SHORT_TAG}/g" dependencies.yaml sed_runner "s/ucx-py=.*/ucx-py=${NEXT_UCXPY_VERSION}/g" dependencies.yaml # CI files diff --git a/dask_cuda/disk_io.py b/dask_cuda/disk_io.py index 0427b77f0..d30d81f49 100644 --- a/dask_cuda/disk_io.py +++ b/dask_cuda/disk_io.py @@ -125,11 +125,13 @@ def __init__( if self.gds_enabled: try: - import cucim.clara.filesystem as cucim_fs # noqa F401 + import kvikio # noqa F401 except ImportError: - raise ImportError("GPUDirect Storage requires the cucim Python package") + raise ImportError( + "GPUDirect Storage requires the kvikio Python package" + ) else: - self.gds_enabled = bool(cucim_fs.is_gds_available()) + self.gds_enabled = kvikio.DriverProperties().is_gds_available def gen_file_path(self) -> str: """Generate an unique file path""" @@ -164,11 +166,16 @@ def disk_write(path: str, frames: Iterable, shared_filesystem: bool, gds=False) cuda_frames = tuple(hasattr(f, "__cuda_array_interface__") for f in frames) frame_lengths = tuple(map(nbytes, frames)) if gds and any(cuda_frames): - import cucim.clara.filesystem as cucim_fs + import kvikio - with cucim_fs.open(path, "w") as f: + futs = [] + with kvikio.CuFile(path, "w") as f: for frame, length in zip(frames, frame_lengths): - f.pwrite(buf=frame, count=length, file_offset=0, buf_offset=0) + futs.append( + f.pwrite(buf=frame, count=length, file_offset=0, buf_offset=0) + ) + for each_fut in futs: + futs.get() else: with open(path, "wb") as f: @@ -201,18 +208,25 @@ def disk_read(header: Mapping, gds=False) -> list: """ ret = [] if gds: - import cucim.clara.filesystem as cucim_fs # isort:skip + import kvikio # isort:skip - with cucim_fs.open(header["path"], "rb") as f: + with kvikio.CuFile(header["path"], "rb") as f: file_offset = 0 + futs = [] for length, is_cuda in zip(header["frame-lengths"], header["cuda-frames"]): if is_cuda: buf = get_new_cuda_buffer()(length) else: buf = np.empty((length,), dtype="u1") - f.pread(buf=buf, count=length, file_offset=file_offset, buf_offset=0) + futs.append( + f.pread( + buf=buf, count=length, file_offset=file_offset, buf_offset=0 + ) + ) file_offset += length ret.append(buf) + for each_fut in futs: + futs.get() else: with open(str(header["path"]), "rb") as f: for length in header["frame-lengths"]: diff --git a/dependencies.yaml b/dependencies.yaml index 0517d3bdb..bc22d2d7d 100644 --- a/dependencies.yaml +++ b/dependencies.yaml @@ -105,9 +105,9 @@ dependencies: common: - output_types: [conda] packages: - - cucim=23.08 - cudf=23.08 - dask-cudf=23.08 + - kvikio=23.08 - pytest - pytest-cov - ucx-proc=*=gpu