blob: 413e46ad70f1bc56c6294da2ea9a958035ab60c0 [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 EXPERIMENTAL_CUDA2_GRAPH_COMMAND_BUFFER_H_
#define EXPERIMENTAL_CUDA2_GRAPH_COMMAND_BUFFER_H_
#include "experimental/cuda2/cuda_dynamic_symbols.h"
#include "experimental/cuda2/cuda_headers.h"
#include "iree/base/api.h"
#include "iree/hal/api.h"
#ifdef __cplusplus
extern "C" {
#endif // __cplusplus
typedef struct iree_arena_block_pool_t iree_arena_block_pool_t;
// Creates a command buffer that records into a CUDA graph.
//
// |block_pool| will be used by the graph command buffer to retain copies of
// input data until reset. It must remain live for the lifetime of the command
// buffers that use it.
iree_status_t iree_hal_cuda2_graph_command_buffer_create(
iree_hal_device_t* device,
const iree_hal_cuda2_dynamic_symbols_t* cuda_symbols, CUcontext context,
iree_hal_command_buffer_mode_t mode,
iree_hal_command_category_t command_categories,
iree_hal_queue_affinity_t queue_affinity, iree_host_size_t binding_capacity,
iree_arena_block_pool_t* block_pool, iree_allocator_t host_allocator,
iree_hal_command_buffer_t** out_command_buffer);
// Returns true if |command_buffer| is a CUDA graph-based command buffer.
bool iree_hal_cuda2_graph_command_buffer_isa(
iree_hal_command_buffer_t* command_buffer);
// Returns the native CUDA graph associated to the command buffer.
CUgraphExec iree_hal_cuda2_graph_command_buffer_handle(
iree_hal_command_buffer_t* command_buffer);
#ifdef __cplusplus
} // extern "C"
#endif // __cplusplus
#endif // EXPERIMENTAL_CUDA2_GRAPH_COMMAND_BUFFER_H_