X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/9e2e32849ed01a869c9c70e78014e6938f098be5..51c23076e2b42ff07dc167dea1cb0e3a4ab3cf68:/src/instr/instr_smpi.hpp diff --git a/src/instr/instr_smpi.hpp b/src/instr/instr_smpi.hpp index 8d9c3dd3b0..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,47 +10,44 @@ #include "src/instr/instr_private.hpp" #include -XBT_PRIVATE std::string smpi_container(int rank); - -extern "C" { +/* 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 const char* encode_datatype(MPI_Datatype datatype, int* known); +/* 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: - const char* filename; + 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 + ':' + + return previous_filename + ':' + std::to_string(previous_linenumber) + ':' + filename + ':' + std::to_string(linenumber); } }; -} #endif