Page cover image

GDS cuFile API

The cuFile APIs are most effective in scenarios where there is a need for high-performance data transfer between GPU memory and storage, particularly in data-intensive applications such as scientific simulations, big data analytics, machine learning, and more.

They enable direct data transfer, bypassing the CPU and system memory, which reduces latency and increases bandwidth.

Check out all the API Functions

Driver Management

  • cuFileDriverOpen: Initializes the driver.

  • cuFileDriverClose: Finalizes the driver.

File Handle Management

  • cuFileHandleRegister: Registers a file handle.

  • cuFileHandleDeregister: Deregisters a file handle.

Buffer Management

  • cuFileBufRegister: Registers a memory buffer.

  • cuFileBufDeregister: Deregisters a memory buffer.

Synchronous I/O Operations

  • cuFileRead: Performs synchronous read operations.

  • cuFileWrite: Performs synchronous write operations.

Asynchronous I/O Operations

  • cuFileReadAsync: Performs read operations using CUDA streams.

  • cuFileWriteAsync: Performs write operations using CUDA streams.

Batch I/O Operations

  • cuFileBatchIOSetUp: Sets up batch I/O operations.

  • cuFileBatchIOSubmit: Submits batch I/O operations.

  • cuFileBatchIOGetStatus: Retrieves the status of batch I/O operations.

  • cuFileBatchIOCancel: Cancels batch I/O operations.

  • cuFileBatchIODestroy: Destroys batch I/O operation setups.

Performance Benefits

  • cuFile APIs enhance data transfer performance by enabling direct memory access (DMA) between GPU memory and storage devices, eliminating the need for data to pass through the CPU and system memory.

  • This direct path reduces latency and increases bandwidth compared to traditional methods that involve data copies through the CPU.

  • NVIDIA provides performance benchmarks and case studies showcasing the efficiency gains achieved using GDS technology.

  • For example, the GPUDirect Storage Benchmarking and Configuration Guide offers guidance on evaluating and testing GDS functionality and performance using sample applications.

Compatibility and Integration

  • To use cuFile APIs, you need a system with a compatible NVIDIA GPU (e.g., NVIDIA A100, V100, or RTX series GPUs) and a GDS-enabled storage device (e.g., NVMe SSDs or NAS).

  • The system should have the necessary device drivers installed, including the NVIDIA GPU driver and the nvidia-fs.ko kernel module for GDS

  • Compatibility issues may arise with certain storage devices or file systems that do not support GDS. It's important to ensure that the storage system and file system are compatible with GDS before integrating cuFile APIs.

Dynamic Interactions and Error Management

  • The cuFile APIs provide error codes and status information to handle dynamic interactions and error states.

  • Each API function returns a CUfileError_t structure that contains an error code indicating the success or failure of the operation. Developers should check the returned error codes and handle them appropriately in their applications.

  • Common errors to be aware of include driver initialisation failures, invalid file handles, invalid buffer pointers, unsupported file systems, and CUDA-specific errors. The API reference guide provides a comprehensive list of error codes and their descriptions to help developers diagnose and handle errors effectively.

Resource Management

  • The cuFile APIs provide functions for registering and deregistering file handles (cuFileHandleRegister, cuFileHandleDeregister) and buffers (cuFileBufRegister, cuFileBufDeregister) to manage resources.

  • It's important to properly deregister file handles and buffers when they are no longer needed to release associated resources and prevent resource leaks.

  • Best practices for resource management include:

    • Explicitly deregistering file handles and buffers using cuFileHandleDeregister and cuFileBufDeregister.

    • Ensuring proper error handling and cleanup in case of failures.

    • Closing the cuFile driver using cuFileDriverClose when it is no longer needed.

Updates and Future Developments

  • NVIDIA regularly updates the cuFile API and provides new features and improvements with each release. It's important to refer to the latest documentation and release notes to stay informed about updates and changes.

  • Deprecated functions or features, if any, will be mentioned in the release notes and API reference guide. Developers should be aware of such deprecations and plan accordingly to update their code.

Technical Support and Documentation

  • NVIDIA provides technical support for developers implementing cuFile APIs through various channels, including the NVIDIA Developer Forums, where developers can ask questions and seek assistance from NVIDIA experts and the community.

  • The cuFile API documentation, including the API reference guide, best practices guide, troubleshooting guide, and benchmarking guide, provides comprehensive information and practical examples to help developers effectively use the APIs. The documentation also includes troubleshooting tips and guidelines for optimising performance.

Security Considerations

  • The cuFile APIs do not provide specific security features beyond the underlying file system and storage device security mechanisms. It's important to ensure that the storage system and file system are properly secured and that appropriate access controls are in place.

  • Developers should follow best practices for secure coding, such as input validation, error handling, and avoiding buffer overflows, to ensure the security of their applications using cuFile APIs.

Technical Details and Code Samples

  • The cuFile API reference guide provides detailed information about each API function, including its parameters, return values, and descriptions. It also includes code samples demonstrating the usage of the APIs in different scenarios.

  • Here's a simple code snippet showing the basic usage of cuFile APIs for reading data from a file into GPU memory:

CUfileError_t status;
CUfileDescr_t cf_descr;
CUfileHandle_t cf_handle;
void* devPtr;
size_t size = 1024;
off_t offset = 0;

// Open the cuFile driver
status = cuFileDriverOpen();

// Register the file handle
cf_descr.handle.fd = open("file.txt", O_RDONLY);
cf_descr.type = CU_FILE_HANDLE_TYPE_OPAQUE_FD;
status = cuFileHandleRegister(&cf_handle, &cf_descr);

// Allocate GPU memory
cudaMalloc(&devPtr, size);

// Register the buffer
status = cuFileBufRegister(devPtr, size, 0);

// Read data from the file into GPU memory
status = cuFileRead(cf_handle, devPtr, size, offset, 0);

// Deregister the buffer
status = cuFileBufDeregister(devPtr);

// Free GPU memory
cudaFree(devPtr);

// Deregister the file handle
cuFileHandleDeregister(cf_handle);

// Close the cuFile driver
cuFileDriverClose();

This code snippet demonstrates the basic steps of opening the cuFile driver, registering a file handle, allocating GPU memory, registering the buffer, reading data from the file into GPU memory, and cleaning up resources.

CuFile Applications

Accelerated Data Loading in Apache Spark

  • Integrate CuFile with Apache Spark to accelerate data loading from storage to GPU memory.

  • Modify Spark's data source API to leverage CuFile for direct data transfer between storage and GPU memory, bypassing the CPU and system memory.

  • This integration would significantly reduce data loading times and improve the performance of Spark jobs that involve GPU processing, such as machine learning and data analytics workloads.

  • CuFile's asynchronous I/O capabilities can be utilised to overlap data loading with computation, further optimizing the overall performance.

GPU-Accelerated Data Lakes with CUDF

  • Combine CUFile with CUDF (CUDA DataFrame) to build a high-performance data lake solution that leverages GPU acceleration.

  • Use CUFile to efficiently load data from various storage systems, such as HDFS, S3, or local storage, directly into GPU memory.

  • Use CUDF to perform in-memory data processing, transformation, and analysis on the loaded data, taking advantage of the GPU's parallel processing capabilities.

  • CUFile's support for different file formats, such as CSV, Parquet, and ORC, enables seamless integration with existing data lake architectures.

Real-time Data Warehousing with GPUs

  • Develop a real-time data warehousing solution that combines CUFile, CUDF, and a GPU-accelerated database like OmniSciDB or BlazingSQL.

  • Use CUFile to rapidly ingest data from various sources, such as streaming platforms or IoT devices, directly into GPU memory.

  • Leverage CUDF for real-time data preprocessing, cleaning, and transformation before loading the data into the GPU-accelerated database.

  • Use the GPU-accelerated database for fast querying, analytics, and visualization of the data, enabling real-time insights and decision-making.

Accelerated Data Pipelines with NVIDIA DALI

  • Integrate CUFile with NVIDIA DALI (Data Loading Library) to create high-performance data pipelines for deep learning workflows.

  • Use CUFile to efficiently load and preprocess large datasets, such as images or videos, directly from storage to GPU memory.

  • Leverage DALI's GPU-accelerated data processing primitives, such as data augmentation, image decoding, and data formatting, to further optimize the data pipeline.

  • CUFile's ability to handle various data formats and its seamless integration with CUDA-based libraries like DALI enables end-to-end GPU acceleration of the data pipeline, reducing data loading bottlenecks and improving training performance.

GPU-Accelerated Feature Engineering with CUDF and XGBoost

  • Combine CUFile, CUDF, and XGBoost to build a GPU-accelerated feature engineering pipeline for machine learning tasks.

  • Use CUFile to efficiently load raw data from storage systems into GPU memory.

  • Use CUDF to perform feature extraction, transformation, and selection operations on the loaded data, leveraging the GPU's parallel processing capabilities.

  • Pass the engineered features to XGBoost, a popular gradient boosting library with GPU acceleration, for model training and prediction.

  • CUFile's seamless integration with CUDF and XGBoost enables end-to-end GPU acceleration of the feature engineering and model training pipeline, significantly reducing the overall processing time and improving the efficiency of the machine learning workflow.

These are just a few examples of how CUFile can be used innovatively in combination with traditional databases, data processing frameworks, and NVIDIA libraries.

CUFile's ability to enable direct data transfer between storage and GPU memory opens up new possibilities for accelerating various data-intensive workloads across different domains, such as data analytics, machine learning, and deep learning.

By leveraging CUFile's high-performance I/O capabilities and seamlessly integrating it with powerful libraries like CUDF, DALI, and XGBoost, developers and data scientists can build end-to-end GPU-accelerated pipelines that overcome data loading bottlenecks and unlock the full potential of GPUs for faster data processing and analytics.

Last updated

Logo

Continuum - Accelerated Artificial Intelligence

Continuum WebsiteAxolotl Platform

Copyright Continuum Labs - 2023