cuda::experimental::stf::context
Defined in include/cuda/experimental/stf.cuh
-
class context
A context is an environment for executing cudastf tasks.
Public Functions
-
context() = default
Default constructor for the context class.
-
inline context(cudaStream_t stream, async_resources_handle handle = async_resources_handle(nullptr))
Constructs a stream context with a CUDA stream and an optional asynchronous resource handle.
- Parameters
stream – The CUDA stream to be used in the context.
handle – Optional asynchronous resource handle.
-
inline context(async_resources_handle handle)
Constructs a stream context with an asynchronous resource handle.
- Parameters
handle – The asynchronous resource handle.
-
inline context(stream_ctx ctx)
Constructs a context from a stream context.
- Parameters
ctx – The context to be assigned.
-
inline context(graph_ctx ctx)
Constructs a context from a graph context.
- Parameters
ctx – The context to be assigned.
-
template<typename Ctx>
inline context &operator=(Ctx ctx) Assigns a specific context type to the context.
- Template Parameters
Ctx – The type of the context to be assigned.
- Parameters
ctx – The context to be assigned.
- Returns
Reference to the updated context.
-
inline ::std::string to_string() const
Converts the context to a string representation.
- Returns
A string representation of the context.
-
template<typename T, typename ...Sizes>
inline auto logical_data(size_t elements, Sizes... othersizes) Creates logical data with specified sizes.
- Template Parameters
T – The type of the logical data.
Sizes – The sizes of the logical data dimensions.
- Parameters
elements – The number of elements.
othersizes – The sizes of other dimensions.
-
template<typename P0, typename ...Ps>
inline auto logical_data(P0 &&p0, Ps&&... ps) Creates logical data with specified parameters.
- Template Parameters
P0 – The type of the first parameter.
Ps – The types of the other parameters.
- Parameters
p0 – The first parameter.
ps – The other parameters.
-
inline auto logical_token()
-
template<typename T>
inline frozen_logical_data<T> freeze(::cuda::experimental::stf::logical_data<T> d, access_mode m = access_mode::read, data_place where = data_place::invalid)
-
template<typename T>
inline auto logical_data(T *p, size_t n, data_place dplace = data_place::host) Creates logical data from a pointer and size.
- Template Parameters
T – The type of the logical data.
- Parameters
p – The pointer to the data.
n – The number of elements.
dplace – The data place of the logical data (default is host).
- Returns
The created logical data.
-
template<typename ...Deps>
inline unified_task<Deps...> task(exec_place e_place, task_dep<Deps>... deps)
-
template<typename ...Deps>
inline auto cuda_kernel(exec_place e_place, task_dep<Deps>... deps)
-
template<typename ...Deps>
inline auto cuda_kernel_chain(exec_place e_place, task_dep<Deps>... deps)
-
inline auto repeat(size_t count)
-
inline auto repeat(::std::function<bool()> condition)
-
inline cudaStream_t task_fence()
-
inline void finalize()
-
inline void submit()
-
inline void set_allocator(block_allocator_untyped custom_allocator)
-
inline void attach_allocator(block_allocator_untyped custom_allocator)
-
inline void update_uncached_allocator(block_allocator_untyped custom)
-
inline void change_epoch()
-
inline ::std::shared_ptr<reserved::per_ctx_dot> get_dot()
-
template<typename T>
inline auto wait(::cuda::experimental::stf::logical_data<T> &ldata)
-
template<typename parent_ctx_t>
inline void set_parent_ctx(parent_ctx_t &parent_ctx)
-
inline void dot_push_section(::std::string symbol) const
Start a new section in the DOT file identified by its symbol.
-
inline void dot_pop_section() const
Ends current dot section.
-
inline auto dot_section(::std::string symbol) const
RAII-style description of a new section in the DOT file identified by its symbol.
-
inline bool is_graph_ctx() const
-
inline async_resources_handle &async_resources() const
-
inline void pop_affinity() const
-
inline const ::std::vector<::std::shared_ptr<exec_place>> ¤t_affinity() const
-
inline const exec_place ¤t_exec_place() const
-
inline bool has_affinity() const
-
inline exec_place default_exec_place() const
Determines the default execution place for a given context, which corresponds to the execution place when no place is provided.
By default, we select the current device, unless an affinity was set in the context, in which case we take the first execution place in the current places.
- Returns
execution place used by constructs where the place is implicit.
Public Members
-
::std::variant<stream_ctx, graph_ctx> payload
-
context() = default