blob: e15253ffb96bed44ea58de4a498cc4429116e35f [file] [log] [blame]
// 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_