From 786e248cea658856ef647b7ab8d3e8cf7c057918 Mon Sep 17 00:00:00 2001 From: Timothy Pearson Date: Sat, 1 Dec 2012 22:14:28 -0600 Subject: Add backtrace to kdesktop_lock exception handler --- kdesktop/lock/lockprocess.cc | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) (limited to 'kdesktop/lock/lockprocess.cc') diff --git a/kdesktop/lock/lockprocess.cc b/kdesktop/lock/lockprocess.cc index 3c37090a6..70836c26c 100644 --- a/kdesktop/lock/lockprocess.cc +++ b/kdesktop/lock/lockprocess.cc @@ -18,6 +18,8 @@ #include +#include + #include "lockprocess.h" #include "lockdlg.h" #include "infodlg.h" @@ -129,9 +131,29 @@ static Window gVRootData = 0; static Atom gXA_VROOT; static Atom gXA_SCREENSAVER_VERSION; +void print_trace() +{ + void *array[10]; + size_t size; + char **strings; + size_t i; + + size = backtrace (array, 10); + strings = backtrace_symbols (array, size); + + printf ("[kdesktop_lock] Obtained %zd stack frames.\n\r", size); + + for (i = 0; i < size; i++) { + printf ("[kdesktop_lock] %s\n\r", strings[i]); + } + + free (strings); +} + static void segv_handler(int) { printf("[kdesktop_lock] WARNING: A fatal exception was encountered. Trapping and ignoring it so as not to compromise desktop security...\n\r"); + print_trace(); sleep(1); } -- cgit v1.2.1