| // Copyright 2024 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_HIP_TIMEPOINT_POOL_H_ |
| #define IREE_EXPERIMENTAL_HIP_TIMEPOINT_POOL_H_ |
| |
| #include "experimental/hip/event_pool.h" |
| #include "iree/base/api.h" |
| #include "iree/base/internal/event_pool.h" |
| #include "iree/hal/utils/semaphore_base.h" |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif // __cplusplus |
| |
| //===----------------------------------------------------------------------===// |
| // iree_hal_hip_timepoint_t |
| //===----------------------------------------------------------------------===// |
| |
| // Forward declaration of the timepoint pool. |
| typedef struct iree_hal_hip_timepoint_pool_t iree_hal_hip_timepoint_pool_t; |
| |
| // An enum to identify the timepoint kind in iree_hal_hip_timepoint_t objects. |
| typedef enum iree_hal_hip_timepoint_kind_e { |
| // None; for uninitialized timepoint objects. |
| IREE_HAL_HIP_TIMEPOINT_KIND_NONE = 0, |
| // A timepoint waited by the host. |
| IREE_HAL_HIP_TIMEPOINT_KIND_HOST_WAIT, |
| // A timepoint signaled by the device. |
| IREE_HAL_HIP_TIMEPOINT_KIND_DEVICE_SIGNAL, |
| // A timepoint waited by the device. |
| IREE_HAL_HIP_TIMEPOINT_KIND_DEVICE_WAIT, |
| } iree_hal_hip_timepoint_kind_t; |
| |
| // An object that wraps a host iree_event_t or device iree_hal_hip_event_t to |
| // represent wait/signal of a timepoint on a timeline. |
| // |
| // iree_hal_hip_timepoint_t objects cannot be directly created; it should be |
| // acquired from the timeline pool and released back to the pool once done. |
| // |
| // Thread-compatible; a timepoint is typically only accessed by one thread. |
| typedef struct iree_hal_hip_timepoint_t { |
| // Base timepoint structure providing intrusive linked list pointers and |
| // timepoint callback mechanisms. |
| iree_hal_semaphore_timepoint_t base; |
| |
| // The allocator used to create the timepoint. |
| iree_allocator_t host_allocator; |
| |
| // The timepoint pool that owns this timepoint. |
| iree_hal_hip_timepoint_pool_t* pool; |
| |
| iree_hal_hip_timepoint_kind_t kind; |
| union { |
| iree_event_t host_wait; |
| iree_hal_hip_event_t* device_signal; |
| // The device event to wait. NULL means no device event available to wait |
| // for this timepoint at the moment. |
| iree_hal_hip_event_t* device_wait; |
| } timepoint; |
| } iree_hal_hip_timepoint_t; |
| |
| //===----------------------------------------------------------------------===// |
| // iree_hal_hip_timepoint_pool_t |
| //===----------------------------------------------------------------------===// |
| |
| // A simple pool of iree_hal_hip_timepoint_t objects to recycle. |
| // |
| // Thread-safe; multiple threads may acquire and release timepoints from the |
| // pool. |
| typedef struct iree_hal_hip_timepoint_pool_t iree_hal_hip_timepoint_pool_t; |
| |
| // Allocates a new timepoint pool with up to |available_capacity| timepoints. |
| // |
| // Extra timepoint requests beyond the capability are directly created and |
| // destroyed without pooling. |
| iree_status_t iree_hal_hip_timepoint_pool_allocate( |
| iree_event_pool_t* host_event_pool, |
| iree_hal_hip_event_pool_t* device_event_pool, |
| iree_host_size_t available_capacity, iree_allocator_t host_allocator, |
| iree_hal_hip_timepoint_pool_t** out_timepoint_pool); |
| |
| // Deallocates a timepoint pool and destroys all timepoints. |
| // |
| // All timepoints that were acquired from the pool must have already been |
| // released back to it prior to deallocation. |
| void iree_hal_hip_timepoint_pool_free( |
| iree_hal_hip_timepoint_pool_t* timepoint_pool); |
| |
| // Acquires one or more timepoints from the timepoint pool. |
| // |
| // |out_timepoints| are owned by the caller and must be kept live until the |
| // timepoints have been reached, or cancelled by the caller. |
| iree_status_t iree_hal_hip_timepoint_pool_acquire_host_wait( |
| iree_hal_hip_timepoint_pool_t* timepoint_pool, |
| iree_host_size_t timepoint_count, |
| iree_hal_hip_timepoint_t** out_timepoints); |
| iree_status_t iree_hal_hip_timepoint_pool_acquire_device_signal( |
| iree_hal_hip_timepoint_pool_t* timepoint_pool, |
| iree_host_size_t timepoint_count, |
| iree_hal_hip_timepoint_t** out_timepoints); |
| iree_status_t iree_hal_hip_timepoint_pool_acquire_device_wait( |
| iree_hal_hip_timepoint_pool_t* timepoint_pool, |
| iree_host_size_t timepoint_count, |
| iree_hal_hip_timepoint_t** out_timepoints); |
| |
| // Releases one or more timepoints back to the timepoint pool. |
| void iree_hal_hip_timepoint_pool_release( |
| iree_hal_hip_timepoint_pool_t* timepoint_pool, |
| iree_host_size_t timepoint_count, iree_hal_hip_timepoint_t** timepoints); |
| |
| #ifdef __cplusplus |
| } // extern "C" |
| #endif // __cplusplus |
| |
| #endif // IREE_EXPERIMENTAL_HIP_TIMEPOINT_POOL_H_ |