2006-07-27 02:56:02 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The University of Tennessee and The University
|
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
2015-06-23 20:59:57 -07:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
2006-07-27 02:56:02 +00:00
|
|
|
* University of Stuttgart. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2006 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2011-07-10 11:14:19 +00:00
|
|
|
* Copyright (c) 2011 Cisco Systems, Inc. All rights reserved.
|
2017-01-26 11:20:41 -06:00
|
|
|
* Copyright (c) 2017 IBM Corporation. All rights reserved.
|
2006-07-27 02:56:02 +00:00
|
|
|
* $COPYRIGHT$
|
2015-06-23 20:59:57 -07:00
|
|
|
*
|
2006-07-27 02:56:02 +00:00
|
|
|
* Additional copyrights may follow
|
2015-06-23 20:59:57 -07:00
|
|
|
*
|
2006-07-27 02:56:02 +00:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "opal_config.h"
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2013-12-18 17:57:37 +00:00
|
|
|
#include <string.h>
|
|
|
|
#ifdef HAVE_UNISTD_H
|
|
|
|
#include <unistd.h>
|
|
|
|
#endif
|
2011-07-10 11:14:19 +00:00
|
|
|
#ifdef HAVE_EXECINFO_H
|
2006-07-27 02:56:02 +00:00
|
|
|
#include <execinfo.h>
|
2011-07-10 11:14:19 +00:00
|
|
|
#endif
|
2006-07-27 02:56:02 +00:00
|
|
|
|
|
|
|
#include "opal/constants.h"
|
|
|
|
#include "opal/mca/backtrace/backtrace.h"
|
|
|
|
|
2013-12-18 17:57:37 +00:00
|
|
|
int
|
|
|
|
opal_backtrace_print(FILE *file, char *prefix, int strip)
|
2006-07-27 02:56:02 +00:00
|
|
|
{
|
2017-01-26 11:20:41 -06:00
|
|
|
int i, len;
|
2006-07-27 02:56:02 +00:00
|
|
|
int trace_size;
|
|
|
|
void * trace[32];
|
2013-12-18 17:57:37 +00:00
|
|
|
char buf[6];
|
2017-01-26 11:20:41 -06:00
|
|
|
int fd = opal_stacktrace_output_fileno;
|
|
|
|
|
|
|
|
if( NULL != file ) {
|
|
|
|
fd = fileno(file);
|
|
|
|
}
|
2013-12-18 17:57:37 +00:00
|
|
|
|
|
|
|
if (-1 == fd) {
|
|
|
|
return OPAL_ERR_BAD_PARAM;
|
|
|
|
}
|
2006-07-27 02:56:02 +00:00
|
|
|
|
|
|
|
trace_size = backtrace (trace, 32);
|
|
|
|
|
2013-12-18 17:57:37 +00:00
|
|
|
for (i = strip; i < trace_size; i++) {
|
|
|
|
if (NULL != prefix) {
|
|
|
|
write (fd, prefix, strlen (prefix));
|
|
|
|
}
|
|
|
|
len = snprintf (buf, sizeof(buf), "[%2d] ", i - strip);
|
|
|
|
write (fd, buf, len);
|
|
|
|
backtrace_symbols_fd (&trace[i], 1, fd);
|
2006-07-27 02:56:02 +00:00
|
|
|
}
|
|
|
|
|
2013-12-18 17:57:37 +00:00
|
|
|
return OPAL_SUCCESS;
|
2006-07-27 02:56:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int
|
2015-06-23 20:59:57 -07:00
|
|
|
opal_backtrace_buffer(char ***message_out, int *len_out)
|
2006-07-27 02:56:02 +00:00
|
|
|
{
|
|
|
|
int trace_size;
|
|
|
|
void * trace[32];
|
|
|
|
char ** funcs = (char **)NULL;
|
|
|
|
|
|
|
|
trace_size = backtrace (trace, 32);
|
|
|
|
funcs = backtrace_symbols (trace, trace_size);
|
|
|
|
|
|
|
|
*message_out = funcs;
|
|
|
|
*len_out = trace_size;
|
|
|
|
|
|
|
|
return OPAL_SUCCESS;
|
|
|
|
}
|