HPCToolkit
MPICommunication.hpp
Go to the documentation of this file.
1 // -*-Mode: C++;-*-
2 
3 // * BeginRiceCopyright *****************************************************
4 //
5 // $HeadURL: https://hpctoolkit.googlecode.com/svn/branches/hpctoolkit-hpcserver/src/tool/hpcserver/MPICommunication.hpp $
6 // $Id: MPICommunication.hpp 4335 2013-08-01 18:24:05Z felipet1326@gmail.com $
7 //
8 // --------------------------------------------------------------------------
9 // Part of HPCToolkit (hpctoolkit.org)
10 //
11 // Information about sources of support for research and development of
12 // HPCToolkit is at 'hpctoolkit.org' and in 'README.Acknowledgments'.
13 // --------------------------------------------------------------------------
14 //
15 // Copyright ((c)) 2002-2019, Rice University
16 // All rights reserved.
17 //
18 // Redistribution and use in source and binary forms, with or without
19 // modification, are permitted provided that the following conditions are
20 // met:
21 //
22 // * Redistributions of source code must retain the above copyright
23 // notice, this list of conditions and the following disclaimer.
24 //
25 // * Redistributions in binary form must reproduce the above copyright
26 // notice, this list of conditions and the following disclaimer in the
27 // documentation and/or other materials provided with the distribution.
28 //
29 // * Neither the name of Rice University (RICE) nor the names of its
30 // contributors may be used to endorse or promote products derived from
31 // this software without specific prior written permission.
32 //
33 // This software is provided by RICE and contributors "as is" and any
34 // express or implied warranties, including, but not limited to, the
35 // implied warranties of merchantability and fitness for a particular
36 // purpose are disclaimed. In no event shall RICE or contributors be
37 // liable for any direct, indirect, incidental, special, exemplary, or
38 // consequential damages (including, but not limited to, procurement of
39 // substitute goods or services; loss of use, data, or profits; or
40 // business interruption) however caused and on any theory of liability,
41 // whether in contract, strict liability, or tort (including negligence
42 // or otherwise) arising in any way out of the use of this software, even
43 // if advised of the possibility of such damage.
44 //
45 // ******************************************************* EndRiceCopyright *
46 
47 //***************************************************************************
48 //
49 // File:
50 // $HeadURL: https://hpctoolkit.googlecode.com/svn/branches/hpctoolkit-hpcserver/src/tool/hpcserver/MPICommunication.hpp $
51 //
52 // Purpose:
53 // [The purpose of this file]
54 //
55 // Description:
56 // [The set of functions, macros, etc. defined in the file]
57 //
58 //***************************************************************************
59 #ifndef MPICOMMUNICATION_H_
60 #define MPICOMMUNICATION_H_
61 
62 
63 #include "TimeCPID.hpp"
64 
65 #include <mpi.h>
66 #include <stdint.h>
67 
68 namespace TraceviewerServer
69 {
70 //Forward declarations so we don't need to include the class just to have a pointer to it
71  class DataCompressionLayer;
72 
73 
75  {
76  public:
77  static const int SOCKET_SERVER = 0; //The rank of the node that is doing all the socket comm
78 
79  typedef struct
80  {
81  char path[1024];
83  typedef struct
84  {
85  uint32_t processStart;
86  uint32_t processEnd;
92  typedef struct
93  {
98 
99  typedef struct
100  {
101  int count;
104  typedef struct
105  {
106  int command;
107  union
108  {
109 
114  };
115  } CommandMessage;
116 
117 
118  typedef struct
119  {
120  int rankID;
122  } DoneMessage;
123 
124  typedef struct
125  {
126  int rankID;
127 
128  int line;
129  int entries;
132  int compressedSize;//In Bytes
133  } DataHeader;
134 
135  typedef struct
136  {
137  int tag;
138  union
139  {
142  };
143  } ResultMessage;
144 
145  typedef struct
146  {
149  union{
151  unsigned char* message;
152  };
153  MPI::Request headerRequest;
154  MPI::Request bodyRequest;
156  };
157 
158 } /* namespace TraceviewerServer */
159 #endif /* MPICOMMUNICATION_H_ */