Skip to content

Instantly share code, notes, and snippets.

@xDShot
Created January 19, 2020 17:13
Show Gist options
  • Save xDShot/1bb257b5eff24036c03d497fa49287cd to your computer and use it in GitHub Desktop.
Save xDShot/1bb257b5eff24036c03d497fa49287cd to your computer and use it in GitHub Desktop.
/*LDFLAGS=-rdynamic*/
#include <execinfo.h>
#include <stdio.h>
#include <stdlib.h>
/* Obtain a backtrace and print it to stdout. */
void
print_trace (void)
{
void *array[10];
size_t size;
char **strings;
size_t i;
size = backtrace (array, 10);
strings = backtrace_symbols (array, size);
printf ("Obtained %zd stack frames.\n", size);
for (i = 0; i < size; i++)
printf ("%s\n", strings[i]);
free (strings);
}
/* A dummy function to make the backtrace more interesting. */
void
dummy_function (void)
{
print_trace ();
}
int
main (void)
{
dummy_function ();
return 0;
}
@xDShot
Copy link
Author

xDShot commented Jan 19, 2020

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment