diff options
Diffstat (limited to '')
-rw-r--r-- | config.mk | 2 | ||||
-rw-r--r-- | internal.h | 3 | ||||
-rw-r--r-- | save_backtrace.c | 12 |
3 files changed, 13 insertions, 4 deletions
@@ -2,5 +2,5 @@ PREFIX = /usr MANPREFIX = $(PREFIX)/share/man CPPFLAGS = -D_DEFAULT_SOURCE -D_BSD_SOURCE -D_XOPEN_SOURCE=700 -CFLAGS = -std=c99 -Wall -pedantic +CFLAGS = -std=c11 -Wall -pedantic LDFLAGS = -s -lunwind -ldw -lerror @@ -21,5 +21,8 @@ struct liberror_backtrace { }; +extern _Thread_local struct liberror_backtrace *liberror_saved_backtrace; + + void liberror_print_backtrace(struct liberror_error *, FILE *, const char *); int liberror_save_backtrace(struct liberror_error *); diff --git a/save_backtrace.c b/save_backtrace.c index e366abf..7214fa4 100644 --- a/save_backtrace.c +++ b/save_backtrace.c @@ -53,9 +53,15 @@ liberror_save_backtrace(struct liberror_error *error) ret = 0; out: - if (error->backtrace && !--error->backtrace->refcount) - free(error->backtrace); - error->backtrace = backtrace; + if (error) { + if (error->backtrace && !--error->backtrace->refcount) + free(error->backtrace); + error->backtrace = backtrace; + } else { + if (liberror_saved_backtrace && !--liberror_saved_backtrace->refcount) + free(liberror_saved_backtrace); + liberror_saved_backtrace = backtrace; + } errno = saved_errno; return ret; } |