Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
8bced802cdef312fb1ca7fcafc089b040b8f3085
[simgrid.git] / src / instr / instr_smpi.hpp
1 /* Copyright (c) 2010-2018. The SimGrid Team. All rights reserved.          */
2
3 /* This program is free software; you can redistribute it and/or modify it
4  * under the terms of the license (GNU LGPL) which comes with this package. */
5
6 #ifndef INSTR_SMPI_HPP
7 #define INSTR_SMPI_HPP
8
9 #include "smpi/smpi.h"
10 #include "src/instr/instr_private.hpp"
11 #include <string>
12
13 /* Helper functions */
14 XBT_PRIVATE container_t smpi_container(int rank);
15 XBT_PRIVATE void TRACE_smpi_setup_container(int rank, sg_host_t host);
16
17 XBT_PRIVATE void TRACE_internal_smpi_set_category(std::string category);
18 XBT_PRIVATE std::string TRACE_internal_smpi_get_category();
19 XBT_PRIVATE void TRACE_smpi_computing_init(int rank);
20 XBT_PRIVATE void TRACE_smpi_computing_out(int rank);
21 XBT_PRIVATE void TRACE_smpi_computing_in(int rank, double amount);
22 XBT_PRIVATE void TRACE_smpi_sleeping_init(int rank);
23 XBT_PRIVATE void TRACE_smpi_sleeping_out(int rank);
24 XBT_PRIVATE void TRACE_smpi_sleeping_in(int rank, double duration);
25 XBT_PRIVATE void TRACE_smpi_comm_in(int rank, const char* operation, simgrid::instr::TIData* extra);
26 XBT_PRIVATE void TRACE_smpi_comm_out(int rank);
27 XBT_PRIVATE void TRACE_smpi_send(int rank, int src, int dst, int tag, int size);
28 XBT_PRIVATE void TRACE_smpi_recv(int src, int dst, int tag);
29 XBT_PRIVATE void TRACE_smpi_init(int rank);
30 XBT_PRIVATE void TRACE_smpi_finalize(int rank);
31 /* SMPI + LB (load balancer) */
32 XBT_PRIVATE void TRACE_smpi_send_process_data_in(int rank);
33 XBT_PRIVATE void TRACE_smpi_send_process_data_out(int rank);
34 XBT_PRIVATE void TRACE_smpi_process_change_host(int rank, sg_host_t new_host);
35 XBT_PRIVATE void TRACE_Iteration_in(int rank, simgrid::instr::TIData* extra);
36 XBT_PRIVATE void TRACE_Iteration_out(int rank, simgrid::instr::TIData* extra);
37 XBT_PRIVATE void TRACE_migration_call(int rank, simgrid::instr::TIData* extra);
38
39 class smpi_trace_call_location_t {
40 public:
41   std::string filename;
42   int linenumber;
43
44   std::string previous_filename;
45   int previous_linenumber;
46
47   std::string get_composed_key()
48   {
49     return previous_filename + ':' + std::to_string(previous_linenumber) + ':' + filename + ':' +
50            std::to_string(linenumber);
51   }
52 };
53
54 #endif