14#include "lci_config.hpp"
323 return reinterpret_cast<uintptr_t
>(
p_impl) < 3;
436 void*
allocate(
size_t size) {
return malloc(size); }
501 return reinterpret_cast<uintptr_t
>(
p_impl) <= 1;
517 attr.zero_copy_am =
false;
519 attr.user_context =
nullptr;
538using reduce_op_t = void (*)(
const void* left,
const void* right,
void* dst,
634#if __cplusplus >= 201703L
638 auto op =
static_cast<T*
>(value);
639 using result_t = std::invoke_result_t<T>;
641 if constexpr (std::is_same_v<result_t, status_t>) {
644 }
else if constexpr (std::is_same_v<result_t, errorcode_t>) {
655typename std::enable_if<
656 std::is_same<
typename std::result_of<T()>::type,
status_t>::value,
660 auto op =
static_cast<T*
>(value);
667typename std::enable_if<
668 std::is_same<
typename std::result_of<T()>::type,
errorcode_t>::value,
672 auto op =
static_cast<T*
>(value);
679typename std::enable_if<
680 !std::is_same<
typename std::result_of<T()>::type, status_t>::value &&
681 !std::is_same<
typename std::result_of<T()>::type,
errorcode_t>::value,
685 auto op =
static_cast<T*
>(value);
694 auto op =
static_cast<T*
>(value);
713 .
value(
reinterpret_cast<void*
>(fn))
715 fn->user_context(ret);
Completion object implementation base type.
Definition lci.hpp:511
comp_impl_t(const attr_t &attr_)
Definition lci.hpp:521
virtual ~comp_impl_t()=default
comp_impl_t()
Definition lci.hpp:514
comp_attr_t attr
Definition lci.hpp:524
comp_attr_t attr_t
Definition lci.hpp:513
virtual void signal(status_t)=0
The actual implementation for RESOURCE comp.
Definition lci_binding_pre.hpp:490
bool is_empty() const
Definition lci.hpp:499
comp_impl_t * p_impl
Definition lci_binding_pre.hpp:502
The actual implementation for graph_add_node.
Definition lci_binding_post.hpp:2409
graph_add_node_x && free_cb(graph_node_free_cb_t free_cb_in)
Definition lci_binding_post.hpp:2425
graph_add_node_x && value(void *value_in)
Definition lci_binding_post.hpp:2424
The actual implementation for RESOURCE mr.
Definition lci_binding_pre.hpp:417
mr_impl_t * p_impl
Definition lci_binding_pre.hpp:424
bool is_empty() const
Definition lci.hpp:321
graph_node_t graph_add_node_op(comp_t graph, const T &op)
Add a functor as a node to the completion graph.
Definition lci.hpp:707
broadcast_algorithm_t
The type of broadcast algorithm.
Definition lci.hpp:231
errorcode_t
The actual error code for LCI API functions.
Definition lci.hpp:121
void(*)(status_t status, void *src_value, void *dst_value) graph_edge_run_cb_t
The function signature for a edge funciton in the completion graph.
Definition lci.hpp:579
void set_g_default_attr(const global_attr_t &attr)
Set the default global attributes for LCI.
const rmr_t RMR_NULL
The NULL value of rkey_t.
Definition lci.hpp:343
uint64_t matching_entry_key_t
The type of matching engine entry key.
Definition lci.hpp:405
const mr_t MR_DEVICE
A special mr_t value for device memory.
Definition lci.hpp:312
const int ANY_SOURCE
Special rank value for any-source receive.
Definition lci.hpp:372
void global_initialize()
Global initialization for LCI, including rank_me, rank_n, and g_default_attr.
status_t(*)(void *value) graph_node_run_cb_t
The function signature for a node function in the completion graph.
Definition lci.hpp:558
net_opcode_t
The Type of network communication operation codes.
Definition lci.hpp:212
const mr_t MR_HOST
A special mr_t value for host memory.
Definition lci.hpp:306
direction_t
The enum class of comunication direction.
Definition lci.hpp:355
void(*)(void *value) graph_node_free_cb_t
The function signature for a callback that will be triggered when the node was freed.
Definition lci.hpp:573
void(*)(const void *left, const void *right, void *dst, size_t n) reduce_op_t
The user-defined reduction operation.
Definition lci.hpp:538
int get_rank_n()
Get the number of ranks in the current application/job.
matching_policy_t
Enum class for matching policy.
Definition lci.hpp:394
void * graph_node_t
The node type for the completion graph.
Definition lci.hpp:544
const tag_t ANY_TAG
Special tag value for any-tag receive.
Definition lci.hpp:378
const graph_node_run_cb_t GRAPH_NODE_DUMMY_CB
A dummy callback function for a graph node.
Definition lci.hpp:566
allreduce_algorithm_t
The type of allreduce algorithm.
Definition lci.hpp:267
int get_rank_me()
Get the rank of the current process.
reduce_scatter_algorithm_t
The type of reduce scatter algorithm.
Definition lci.hpp:249
const comp_t COMP_NULL_EXPECT_DONE
Deprecated. Same as COMP_NULL.
Definition lci.hpp:483
const mr_t MR_UNKNOWN
A special mr_t value for unknown memory. LCI will detect the memory type automatically.
Definition lci.hpp:319
void * matching_entry_val_t
The type of matching engine entry value.
Definition lci.hpp:410
void global_finalize()
Global finalization for LCI.
matching_entry_type_t
The type of matching entry.
Definition lci.hpp:385
uint32_t rcomp_t
The type of remote completion handler.
Definition lci.hpp:366
void(*)(status_t status) comp_handler_t
Function Signature for completion handler.
Definition lci.hpp:531
const graph_node_t GRAPH_START
The start node of the completion graph.
Definition lci.hpp:550
const comp_t COMP_NULL
Special completion object setting allow_posted and allow_retry to false.
Definition lci.hpp:477
const comp_t COMP_NULL_EXPECT_DONE_OR_RETRY
Deprecated. Same as COMP_NULL_RETRY.
Definition lci.hpp:496
uint64_t tag_t
The type of tag.
Definition lci.hpp:349
global_attr_t get_g_default_attr()
Get the default global attributes for LCI. The default global attributes contain the default attribut...
comp_semantic_t
The enum class of completion semantic.
Definition lci.hpp:420
uint32_t net_imm_data_t
The type of network-layer immediate data field.
Definition lci.hpp:286
const comp_t COMP_NULL_RETRY
Special completion object setting allow_posted to false.
Definition lci.hpp:490
@ ring
Definition lci.hpp:235
@ direct
Definition lci.hpp:233
@ tree
Definition lci.hpp:234
@ retry
Definition lci.hpp:134
@ retry_nopacket
Definition lci.hpp:138
@ done_max
Definition lci.hpp:126
@ posted_backlog
Definition lci.hpp:130
@ done
Definition lci.hpp:123
@ retry_min
Definition lci.hpp:133
@ done_min
Definition lci.hpp:122
@ retry_lock
Definition lci.hpp:137
@ posted_min
Definition lci.hpp:127
@ retry_max
Definition lci.hpp:144
@ posted
Definition lci.hpp:128
@ retry_backlog
Definition lci.hpp:142
@ retry_init
Definition lci.hpp:136
@ done_backlog
Definition lci.hpp:124
@ retry_nomem
Definition lci.hpp:140
@ fatal
Definition lci.hpp:145
@ posted_max
Definition lci.hpp:132
@ READ
Definition lci.hpp:217
@ SEND
Definition lci.hpp:213
@ REMOTE_WRITE
Definition lci.hpp:216
@ RECV
Definition lci.hpp:214
@ WRITE
Definition lci.hpp:215
@ IN
Definition lci.hpp:357
@ OUT
Definition lci.hpp:356
@ max
Definition lci.hpp:399
@ rank_tag
Definition lci.hpp:398
@ tag_only
Definition lci.hpp:397
@ rank_only
Definition lci.hpp:396
@ send
Definition lci.hpp:386
@ recv
Definition lci.hpp:387
@ network
Definition lci.hpp:422
@ memory
Definition lci.hpp:421
All LCI API functions and classes are defined in this namespace.
const char * get_allreduce_algorithm_str(broadcast_algorithm_t algorithm)
Get the string representation of a collective algorithm.
attr_backend_t
Definition lci.hpp:65
@ none
Definition lci.hpp:66
@ ibv
Definition lci.hpp:67
@ ofi
Definition lci.hpp:68
@ ucx
Definition lci.hpp:69
const char * DEFAULT_NAME
const graph_node_t GRAPH_END
Definition lci.hpp:551
const char * get_reduce_scatter_algorithm_str(broadcast_algorithm_t algorithm)
Get the string representation of a collective algorithm.
allocator_default_t g_allocator_default
@ custom
Definition lci_binding_pre.hpp:58
@ graph
Definition lci_binding_pre.hpp:57
const char * get_errorcode_str(errorcode_t errorcode)
Get the string representation of an error code.
void graph_free_op_fn(void *value)
Definition lci.hpp:692
attr_net_lock_mode_t
Definition lci.hpp:72
@ LCI_NET_TRYLOCK_POLL
Definition lci.hpp:75
@ LCI_NET_TRYLOCK_SEND
Definition lci.hpp:73
@ LCI_NET_TRYLOCK_RECV
Definition lci.hpp:74
@ LCI_NET_TRYLOCK_MAX
Definition lci.hpp:76
const char * get_net_opcode_str(net_opcode_t opcode)
Get the string representation of a network operation code.
std::enable_if< std::is_same< typenamestd::result_of< T()>::type, status_t >::value, status_t >::type graph_execute_op_fn(void *value)
Definition lci.hpp:658
const char * get_broadcast_algorithm_str(broadcast_algorithm_t algorithm)
Get the string representation of a collective algorithm.
The user-defined allocator type.
Definition lci.hpp:429
virtual ~allocator_base_t()=default
virtual void deallocate(void *ptr)=0
virtual void * allocate(size_t size)=0
void * allocate(size_t size)
Definition lci.hpp:436
void deallocate(void *ptr)
Definition lci.hpp:437
Definition lci_binding_pre.hpp:133
Wrapper class for error code.
Definition lci.hpp:162
bool is_done() const
Check if the error code is in the done category.
Definition lci.hpp:178
error_t()
Definition lci.hpp:164
bool is_posted() const
Check if the error code is in the posted category.
Definition lci.hpp:187
const char * get_str() const
Get the string representation of the error code.
Definition lci.hpp:205
errorcode_t errorcode
Definition lci.hpp:163
void reset_retry()
Reset the error code to retry.
Definition lci.hpp:173
error_t(errorcode_t errorcode_)
Construct an error_t object with a specific error code.
Definition lci.hpp:169
bool is_retry() const
Check if the error code is in the retry category.
Definition lci.hpp:196
Definition lci_binding_pre.hpp:143
The struct for network status.
Definition lci.hpp:294
net_imm_data_t imm_data
Definition lci.hpp:299
int rank
Definition lci.hpp:296
void * user_context
Definition lci.hpp:297
net_opcode_t opcode
Definition lci.hpp:295
size_t length
Definition lci.hpp:298
bool m_is_set
Definition lci.hpp:102
option_t()
Definition lci.hpp:82
T get_value() const
Definition lci.hpp:98
T get_value_or(T default_value) const
Definition lci.hpp:86
bool get_set_value(T *value) const
Definition lci.hpp:90
T m_value
Definition lci.hpp:101
option_t(T value_, bool is_set_)
Definition lci.hpp:84
bool is_set() const
Definition lci.hpp:99
option_t(T value_)
Definition lci.hpp:83
The type of remote memory region.
Definition lci.hpp:332
uintptr_t base
Definition lci.hpp:333
bool is_empty() const
Definition lci.hpp:336
uint64_t opaque_rkey
Definition lci.hpp:334
rmr_t()
Definition lci.hpp:335
The type of the completion desciptor for a posted communication.
Definition lci.hpp:445
tag_t get_tag() const
Definition lci.hpp:468
status_t(errorcode_t error_)
Definition lci.hpp:453
status_t(void *user_context_)
Definition lci.hpp:454
error_t get_error() const
Definition lci.hpp:464
void set_retry()
Definition lci.hpp:460
void * get_user_context() const
Definition lci.hpp:469
error_t error
Definition lci.hpp:446
void set_done()
Definition lci.hpp:458
tag_t tag
Definition lci.hpp:450
size_t size
Definition lci.hpp:449
void set_posted()
Definition lci.hpp:459
bool is_done() const
Definition lci.hpp:461
void * buffer
Definition lci.hpp:448
void * user_context
Definition lci.hpp:451
bool is_posted() const
Definition lci.hpp:462
bool is_retry() const
Definition lci.hpp:463
int get_rank() const
Definition lci.hpp:465
void * get_buffer() const
Definition lci.hpp:466
int rank
Definition lci.hpp:447
size_t get_size() const
Definition lci.hpp:467