Realm
A distributed, event-based tasking library
Loading...
Searching...
No Matches
gasnet1_module.h
Go to the documentation of this file.
1/*
2 * Copyright 2025 Stanford University, NVIDIA Corporation
3 * SPDX-License-Identifier: Apache-2.0
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18// GASNet-1 network module implementation for Realm
19
20// NOTE: this should work with GASNet-EX's backward-compatibility interfaces,
21// but it is not recommended - there are known performance regressions compared
22// to using an actual GASNet-1 implementation
23
24#ifndef GASNET1_MODULE_H
25#define GASNET1_MODULE_H
26
27#include "realm/network.h"
28
29namespace Realm {
30
32 protected:
34
35 public:
36 // all subclasses should define this (static) method - its responsibilities
37 // are:
38 // 1) determine if the network module should even be loaded
39 // 2) fix the command line if the spawning system hijacked it
40 static NetworkModule *create_network_module(RuntimeImpl *runtime, int *argc,
41 const char ***argv);
42
43 // Enumerates all the peers that the current node could potentially share memory with
44 virtual void get_shared_peers(NodeSet &shared_peers);
45
46 // actual parsing of the command line should wait until here if at all
47 // possible
48 virtual void parse_command_line(RuntimeImpl *runtime,
49 std::vector<std::string> &cmdline);
50
51 // "attaches" to the network, if that is meaningful - attempts to
52 // bind/register/(pick your network-specific verb) the requested memory
53 // segments with the network
54 virtual void attach(RuntimeImpl *runtime, std::vector<NetworkSegment *> &segments);
55
56 virtual void create_memories(RuntimeImpl *runtime);
57
58 // detaches from the network
59 virtual void detach(RuntimeImpl *runtime, std::vector<NetworkSegment *> &segments);
60
61 // collective communication within this network
62 virtual void barrier(void);
63 virtual void broadcast(NodeID root, const void *val_in, void *val_out, size_t bytes);
64 virtual void gather(NodeID root, const void *val_in, void *vals_out, size_t bytes);
65 virtual void allgatherv(const char *val_in, size_t bytes, std::vector<char> &vals_out,
66 std::vector<size_t> &lengths);
67
68 virtual size_t sample_messages_received_count(void);
69 virtual bool check_for_quiescence(size_t sampled_receive_count);
70
71 // used to create a remote proxy for a memory
72 virtual MemoryImpl *create_remote_memory(RuntimeImpl *runtime, Memory m, size_t size,
73 Memory::Kind kind,
74 const ByteArray &rdma_info);
75 virtual IBMemory *create_remote_ib_memory(RuntimeImpl *runtime, Memory m, size_t size,
76 Memory::Kind kind,
77 const ByteArray &rdma_info);
78
79 virtual ActiveMessageImpl *
80 create_active_message_impl(NodeID target, unsigned short msgid, size_t header_size,
81 size_t max_payload_size, const void *src_payload_addr,
82 size_t src_payload_lines, size_t src_payload_line_stride,
83 void *storage_base, size_t storage_size);
84
86 NodeID target, unsigned short msgid, size_t header_size, size_t max_payload_size,
87 const LocalAddress &src_payload_addr, size_t src_payload_lines,
88 size_t src_payload_line_stride, const RemoteAddress &dest_payload_addr,
89 void *storage_base, size_t storage_size);
90
92 NodeID target, unsigned short msgid, size_t header_size, size_t max_payload_size,
93 const RemoteAddress &dest_payload_addr, void *storage_base, size_t storage_size);
94
96 const NodeSet &targets, unsigned short msgid, size_t header_size,
97 size_t max_payload_size, const void *src_payload_addr, size_t src_payload_lines,
98 size_t src_payload_line_stride, void *storage_base, size_t storage_size);
99
100 virtual size_t recommended_max_payload(NodeID target, bool with_congestion,
101 size_t header_size);
102 virtual size_t recommended_max_payload(const NodeSet &targets, bool with_congestion,
103 size_t header_size);
104 virtual size_t recommended_max_payload(NodeID target,
105 const RemoteAddress &dest_payload_addr,
106 bool with_congestion, size_t header_size);
107 virtual size_t recommended_max_payload(NodeID target, const void *data,
108 size_t bytes_per_line, size_t lines,
109 size_t line_stride, bool with_congestion,
110 size_t header_size);
111 virtual size_t recommended_max_payload(const NodeSet &targets, const void *data,
112 size_t bytes_per_line, size_t lines,
113 size_t line_stride, bool with_congestion,
114 size_t header_size);
115 virtual size_t recommended_max_payload(NodeID target,
116 const LocalAddress &src_payload_addr,
117 size_t bytes_per_line, size_t lines,
118 size_t line_stride,
119 const RemoteAddress &dest_payload_addr,
120 bool with_congestion, size_t header_size);
121
122 protected:
126 };
127
128}; // namespace Realm
129
130#endif
Definition activemsg.h:205
Definition bytearray.h:53
Definition gasnet1_module.h:31
virtual size_t recommended_max_payload(NodeID target, const void *data, size_t bytes_per_line, size_t lines, size_t line_stride, bool with_congestion, size_t header_size)
virtual void detach(RuntimeImpl *runtime, std::vector< NetworkSegment * > &segments)
virtual IBMemory * create_remote_ib_memory(RuntimeImpl *runtime, Memory m, size_t size, Memory::Kind kind, const ByteArray &rdma_info)
bool active_msg_worker_bgwork
Definition gasnet1_module.h:123
virtual void gather(NodeID root, const void *val_in, void *vals_out, size_t bytes)
virtual size_t recommended_max_payload(NodeID target, bool with_congestion, size_t header_size)
virtual void create_memories(RuntimeImpl *runtime)
virtual void broadcast(NodeID root, const void *val_in, void *val_out, size_t bytes)
virtual void attach(RuntimeImpl *runtime, std::vector< NetworkSegment * > &segments)
static NetworkModule * create_network_module(RuntimeImpl *runtime, int *argc, const char ***argv)
virtual size_t sample_messages_received_count(void)
virtual ActiveMessageImpl * create_active_message_impl(NodeID target, unsigned short msgid, size_t header_size, size_t max_payload_size, const void *src_payload_addr, size_t src_payload_lines, size_t src_payload_line_stride, void *storage_base, size_t storage_size)
int active_msg_worker_threads
Definition gasnet1_module.h:124
virtual ActiveMessageImpl * create_active_message_impl(const NodeSet &targets, unsigned short msgid, size_t header_size, size_t max_payload_size, const void *src_payload_addr, size_t src_payload_lines, size_t src_payload_line_stride, void *storage_base, size_t storage_size)
size_t amsg_stack_size
Definition gasnet1_module.h:125
virtual bool check_for_quiescence(size_t sampled_receive_count)
virtual void barrier(void)
virtual void parse_command_line(RuntimeImpl *runtime, std::vector< std::string > &cmdline)
virtual size_t recommended_max_payload(const NodeSet &targets, bool with_congestion, size_t header_size)
virtual MemoryImpl * create_remote_memory(RuntimeImpl *runtime, Memory m, size_t size, Memory::Kind kind, const ByteArray &rdma_info)
virtual void get_shared_peers(NodeSet &shared_peers)
virtual void allgatherv(const char *val_in, size_t bytes, std::vector< char > &vals_out, std::vector< size_t > &lengths)
virtual size_t recommended_max_payload(const NodeSet &targets, const void *data, size_t bytes_per_line, size_t lines, size_t line_stride, bool with_congestion, size_t header_size)
virtual ActiveMessageImpl * create_active_message_impl(NodeID target, unsigned short msgid, size_t header_size, size_t max_payload_size, const LocalAddress &src_payload_addr, size_t src_payload_lines, size_t src_payload_line_stride, const RemoteAddress &dest_payload_addr, void *storage_base, size_t storage_size)
size_t gasnet_mem_size
Definition gasnet1_module.h:125
virtual size_t recommended_max_payload(NodeID target, const RemoteAddress &dest_payload_addr, bool with_congestion, size_t header_size)
virtual ActiveMessageImpl * create_active_message_impl(NodeID target, unsigned short msgid, size_t header_size, size_t max_payload_size, const RemoteAddress &dest_payload_addr, void *storage_base, size_t storage_size)
virtual size_t recommended_max_payload(NodeID target, const LocalAddress &src_payload_addr, size_t bytes_per_line, size_t lines, size_t line_stride, const RemoteAddress &dest_payload_addr, bool with_congestion, size_t header_size)
Definition ib_memory.h:30
Definition mem_impl.h:50
Definition memory.h:33
Kind
Definition memory.h:59
Definition network.h:144
Definition nodeset.h:117
Definition runtime_impl.h:264
Definition activemsg.h:38
int NodeID
Definition nodeset.h:40
Definition network.h:58
Definition network.h:46
unsigned short msgid
Definition ucp_internal.h:2