X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/d4dc697d017dc90d064827165eb4f924452aeb0d..406f9bbafee691a1e31084806dc15fb292fd649b:/src/instr/instr_smpi.hpp diff --git a/src/instr/instr_smpi.hpp b/src/instr/instr_smpi.hpp index 77951ef89d..8a97505986 100644 --- a/src/instr/instr_smpi.hpp +++ b/src/instr/instr_smpi.hpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2010-2017. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2010-2018. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ @@ -10,45 +10,44 @@ #include "src/instr/instr_private.hpp" #include -SG_BEGIN_DECL() +/* Helper functions */ +XBT_PRIVATE container_t smpi_container(int rank); +XBT_PRIVATE void TRACE_smpi_setup_container(int rank, sg_host_t host); XBT_PRIVATE void TRACE_internal_smpi_set_category(const char* category); XBT_PRIVATE const char* TRACE_internal_smpi_get_category(); -XBT_PRIVATE void TRACE_smpi_collective_in(int rank, const char* operation, instr_extra_data extra); -XBT_PRIVATE void TRACE_smpi_collective_out(int rank, const char* operation); XBT_PRIVATE void TRACE_smpi_computing_init(int rank); XBT_PRIVATE void TRACE_smpi_computing_out(int rank); -XBT_PRIVATE void TRACE_smpi_computing_in(int rank, instr_extra_data extra); -XBT_PRIVATE void TRACE_smpi_sleeping_init(int rank); +XBT_PRIVATE void TRACE_smpi_computing_in(int rank, double amount); XBT_PRIVATE void TRACE_smpi_sleeping_out(int rank); -XBT_PRIVATE void TRACE_smpi_sleeping_in(int rank, instr_extra_data extra); +XBT_PRIVATE void TRACE_smpi_sleeping_in(int rank, double duration); XBT_PRIVATE void TRACE_smpi_testing_out(int rank); -XBT_PRIVATE void TRACE_smpi_testing_in(int rank, instr_extra_data extra); -XBT_PRIVATE void TRACE_smpi_alloc(); +XBT_PRIVATE void TRACE_smpi_testing_in(int rank); XBT_PRIVATE void TRACE_smpi_release(); -XBT_PRIVATE void TRACE_smpi_ptp_in(int rank, const char* operation, instr_extra_data extra); -XBT_PRIVATE void TRACE_smpi_ptp_out(int rank, int dst, const char* operation); +XBT_PRIVATE void TRACE_smpi_comm_in(int rank, const char* operation, simgrid::instr::TIData* extra); +XBT_PRIVATE void TRACE_smpi_comm_out(int rank); XBT_PRIVATE void TRACE_smpi_send(int rank, int src, int dst, int tag, int size); XBT_PRIVATE void TRACE_smpi_recv(int src, int dst, int tag); XBT_PRIVATE void TRACE_smpi_init(int rank); XBT_PRIVATE void TRACE_smpi_finalize(int rank); -XBT_PRIVATE char* smpi_container(int rank, char* container, int n); - -XBT_PRIVATE const char* encode_datatype(MPI_Datatype datatype, int* known); - -typedef struct smpi_trace_call_location { - const char* filename; +/* SMPI + LB (load balancer) */ +XBT_PRIVATE void TRACE_smpi_send_process_data_in(int rank); +XBT_PRIVATE void TRACE_smpi_send_process_data_out(int rank); +XBT_PRIVATE void TRACE_smpi_process_change_host(int rank, sg_host_t new_host); + +class smpi_trace_call_location_t { +public: + std::string filename; int linenumber; - const char* previous_filename; + std::string previous_filename; int previous_linenumber; - std::string get_composed_key() { - return std::string(previous_filename) + ':' + std::to_string(previous_linenumber) + ':' + filename + ':' + std::to_string(linenumber); + std::string get_composed_key() + { + return previous_filename + ':' + std::to_string(previous_linenumber) + ':' + filename + ':' + + std::to_string(linenumber); } - -} smpi_trace_call_location_t; - -SG_END_DECL() +}; #endif