Realm
A distributed, event-based tasking library
Loading...
Searching...
No Matches
mpi_module.h
Go to the documentation of this file.
1/*
2 * Copyright 2025 Stanford University, NVIDIA Corporation, Argonne National Laboratory
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// MPI network module implementation for Realm
19
20#ifndef MPI_MODULE_H
21#define MPI_MODULE_H
22
23#include "realm/network.h"
24#include <mpi.h>
25
26namespace Realm {
27
28 class MPIModule : public NetworkModule {
29 protected:
30 MPIModule(void);
31
32 public:
33 // all subclasses should define this (static) method - its responsibilities
34 // are:
35 // 1) determine if the network module should even be loaded
36 // 2) fix the command line if the spawning system hijacked it
37 static NetworkModule *create_network_module(RuntimeImpl *runtime, int *argc,
38 const char ***argv);
39
40 // Enumerates all the peers that the current node could potentially share memory with
41 virtual void get_shared_peers(NodeSet &shared_peers);
42
43 // actual parsing of the command line should wait until here if at all
44 // possible
45 virtual void parse_command_line(RuntimeImpl *runtime,
46 std::vector<std::string> &cmdline);
47
48 // "attaches" to the network, if that is meaningful - attempts to
49 // bind/register/(pick your network-specific verb) the requested memory
50 // segments with the network
51 virtual void attach(RuntimeImpl *runtime, std::vector<NetworkSegment *> &segments);
52
53 virtual void create_memories(RuntimeImpl *runtime);
54
55 // detaches from the network
56 virtual void detach(RuntimeImpl *runtime, std::vector<NetworkSegment *> &segments);
57
58 // collective communication within this network
59 virtual void barrier(void);
60 virtual void broadcast(NodeID root, const void *val_in, void *val_out, size_t bytes);
61 virtual void gather(NodeID root, const void *val_in, void *vals_out, size_t bytes);
62 virtual void allgatherv(const char *val_in, size_t bytes, std::vector<char> &vals_out,
63 std::vector<size_t> &lengths);
64
65 virtual size_t sample_messages_received_count(void);
66 virtual bool check_for_quiescence(size_t sampled_receive_count);
67
68 // used to create a remote proxy for a memory
69 virtual MemoryImpl *create_remote_memory(RuntimeImpl *runtime, Memory m, size_t size,
70 Memory::Kind kind,
71 const ByteArray &rdma_info);
72 virtual IBMemory *create_remote_ib_memory(RuntimeImpl *runtime, Memory m, size_t size,
73 Memory::Kind kind,
74 const ByteArray &rdma_info);
75
76 virtual ActiveMessageImpl *
77 create_active_message_impl(NodeID target, unsigned short msgid, size_t header_size,
78 size_t max_payload_size, const void *src_payload_addr,
79 size_t src_payload_lines, size_t src_payload_line_stride,
80 void *storage_base, size_t storage_size);
81
83 NodeID target, unsigned short msgid, size_t header_size, size_t max_payload_size,
84 const LocalAddress &src_payload_addr, size_t src_payload_lines,
85 size_t src_payload_line_stride, const RemoteAddress &dest_payload_addr,
86 void *storage_base, size_t storage_size);
87
89 NodeID target, unsigned short msgid, size_t header_size, size_t max_payload_size,
90 const RemoteAddress &dest_payload_addr, void *storage_base, size_t storage_size);
91
93 const NodeSet &targets, unsigned short msgid, size_t header_size,
94 size_t max_payload_size, const void *src_payload_addr, size_t src_payload_lines,
95 size_t src_payload_line_stride, void *storage_base, size_t storage_size);
96
97 virtual size_t recommended_max_payload(NodeID target, bool with_congestion,
98 size_t header_size);
99 virtual size_t recommended_max_payload(const NodeSet &targets, bool with_congestion,
100 size_t header_size);
101 virtual size_t recommended_max_payload(NodeID target,
102 const RemoteAddress &dest_payload_addr,
103 bool with_congestion, size_t header_size);
104 virtual size_t recommended_max_payload(NodeID target, const void *data,
105 size_t bytes_per_line, size_t lines,
106 size_t line_stride, bool with_congestion,
107 size_t header_size);
108 virtual size_t recommended_max_payload(const NodeSet &targets, const void *data,
109 size_t bytes_per_line, size_t lines,
110 size_t line_stride, bool with_congestion,
111 size_t header_size);
112 virtual size_t recommended_max_payload(NodeID target,
113 const LocalAddress &src_payload_addr,
114 size_t bytes_per_line, size_t lines,
115 size_t line_stride,
116 const RemoteAddress &dest_payload_addr,
117 bool with_congestion, size_t header_size);
118
119 protected:
120 MPI_Win g_am_win; /* global window for RMA memory */
121 ;
124 };
125
126}; // namespace Realm
127
128#endif
Definition activemsg.h:205
Definition bytearray.h:53
Definition ib_memory.h:30
Definition mpi_module.h:28
virtual bool check_for_quiescence(size_t sampled_receive_count)
virtual size_t sample_messages_received_count(void)
void ** g_am_bases
Definition mpi_module.h:122
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 attach(RuntimeImpl *runtime, std::vector< NetworkSegment * > &segments)
virtual MemoryImpl * create_remote_memory(RuntimeImpl *runtime, Memory m, size_t size, Memory::Kind kind, const ByteArray &rdma_info)
virtual IBMemory * create_remote_ib_memory(RuntimeImpl *runtime, Memory m, size_t size, Memory::Kind kind, const ByteArray &rdma_info)
virtual void allgatherv(const char *val_in, size_t bytes, std::vector< char > &vals_out, std::vector< size_t > &lengths)
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)
MPI_Win g_am_win
Definition mpi_module.h:120
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)
virtual void gather(NodeID root, const void *val_in, void *vals_out, size_t bytes)
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)
virtual size_t recommended_max_payload(const NodeSet &targets, bool with_congestion, size_t header_size)
virtual void create_memories(RuntimeImpl *runtime)
virtual void get_shared_peers(NodeSet &shared_peers)
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)
virtual void broadcast(NodeID root, const void *val_in, void *val_out, size_t bytes)
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)
static NetworkModule * create_network_module(RuntimeImpl *runtime, int *argc, const char ***argv)
virtual size_t recommended_max_payload(NodeID target, bool with_congestion, size_t header_size)
virtual void barrier(void)
size_t global_mem_size
Definition mpi_module.h:123
virtual void parse_command_line(RuntimeImpl *runtime, std::vector< std::string > &cmdline)
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 void detach(RuntimeImpl *runtime, std::vector< NetworkSegment * > &segments)
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