| // Copyright 2023 The IREE Authors |
| // |
| // Licensed under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| |
| #ifndef IREE_EXPERIMENTAL_CUDA2_NCCL_DYNAMIC_SYMBOLS_H_ |
| #define IREE_EXPERIMENTAL_CUDA2_NCCL_DYNAMIC_SYMBOLS_H_ |
| |
| #include "experimental/cuda2/cuda_dynamic_symbols.h" |
| #include "experimental/cuda2/nccl_headers.h" |
| #include "iree/base/api.h" |
| #include "iree/base/internal/dynamic_library.h" |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif // __cplusplus |
| |
| // iree_dynamic_library_t allows dynamically loading a subset of the NCCL API. |
| // We load all the symbols in `nccl_dynamic_symbol_table.h` and fail if any of |
| // the symbol is not available. The functions signatures are matching the |
| // declarations in `nccl.h"`. |
| |
| // NCCL API dynamic symbols. |
| typedef struct iree_hal_cuda2_nccl_dynamic_symbols_t { |
| // The dynamic library handle. |
| iree_dynamic_library_t* dylib; |
| |
| // Concrete NCCL symbols defined by including the `dynamic_symbol_tables.h`. |
| #define IREE_NCCL_PFN_DECL(ncclSymbolName, ...) \ |
| ncclResult_t (*ncclSymbolName)(__VA_ARGS__); |
| #define IREE_NCCL_PFN_DECL_STR_RETURN(ncclSymbolName, ...) \ |
| const char* (*ncclSymbolName)(__VA_ARGS__); |
| #include "experimental/cuda2/nccl_dynamic_symbol_table.h" // IWYU pragma: export |
| #undef IREE_NCCL_PFN_DECL |
| #undef IREE_NCCL_PFN_DECL_STR_RETURN |
| } iree_hal_cuda2_nccl_dynamic_symbols_t; |
| |
| // Initializes |out_syms| in-place with dynamically loaded NCCL symbols. |
| // iree_hal_cuda2_dynamic_symbols_deinitialize must be used to release the |
| // library resources. |
| iree_status_t iree_hal_cuda2_nccl_dynamic_symbols_initialize( |
| iree_allocator_t host_allocator, |
| const iree_hal_cuda2_dynamic_symbols_t* cuda_library, |
| iree_hal_cuda2_nccl_dynamic_symbols_t* out_syms); |
| |
| // Deinitializes |syms| by unloading the backing library. All function pointers |
| // will be invalidated. They _may_ still work if there are other reasons the |
| // library remains loaded so be careful. |
| void iree_hal_cuda2_nccl_dynamic_symbols_deinitialize( |
| iree_hal_cuda2_nccl_dynamic_symbols_t* syms); |
| |
| #ifdef __cplusplus |
| } // extern "C" |
| #endif // __cplusplus |
| |
| #endif // IREE_EXPERIMENTAL_CUDA2_NCCL_DYNAMIC_SYMBOLS_H_ |