2016-11-23 02:03:20 +03:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2004-2007 The Trustees of the University of Tennessee.
|
|
|
|
* All rights reserved.
|
2017-06-30 04:18:46 +03:00
|
|
|
* Copyright (c) 2017 IBM Corporation. All rights reserved.
|
2016-11-23 02:03:20 +03:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "ompi_config.h"
|
|
|
|
#include "opal/util/output.h"
|
|
|
|
|
|
|
|
|
|
|
|
#include "pml_v_output.h"
|
|
|
|
|
|
|
|
#if defined(HAVE_UNISTD_H)
|
|
|
|
#include <unistd.h>
|
|
|
|
#endif
|
|
|
|
#include <string.h>
|
|
|
|
|
2017-06-30 04:18:46 +03:00
|
|
|
int ompi_pml_v_output_open(char *output, int verbosity) {
|
2016-11-23 02:03:20 +03:00
|
|
|
opal_output_stream_t lds;
|
|
|
|
char hostname[OPAL_MAXHOSTNAMELEN] = "NA";
|
|
|
|
|
|
|
|
OBJ_CONSTRUCT(&lds, opal_output_stream_t);
|
|
|
|
if(!output) {
|
|
|
|
mca_pml_v.output = 0;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if(!strcmp(output, "stdout")) {
|
|
|
|
lds.lds_want_stdout = true;
|
|
|
|
}
|
|
|
|
else if(!strcmp(output, "stderr")) {
|
|
|
|
lds.lds_want_stderr = true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
lds.lds_want_file = true;
|
|
|
|
lds.lds_file_suffix = output;
|
|
|
|
}
|
|
|
|
lds.lds_is_debugging = true;
|
|
|
|
gethostname(hostname, sizeof(hostname));
|
|
|
|
asprintf(&lds.lds_prefix, "[%s:%05d] pml_v: ", hostname, getpid());
|
|
|
|
lds.lds_verbose_level = verbosity;
|
|
|
|
mca_pml_v.output = opal_output_open(&lds);
|
|
|
|
free(lds.lds_prefix);
|
|
|
|
}
|
|
|
|
return mca_pml_v.output;
|
|
|
|
}
|
|
|
|
|
2017-06-30 04:18:46 +03:00
|
|
|
void ompi_pml_v_output_close(void) {
|
2016-11-23 02:03:20 +03:00
|
|
|
opal_output_close(mca_pml_v.output);
|
|
|
|
mca_pml_v.output = -1;
|
|
|
|
}
|