summaryrefslogtreecommitdiff
path: root/www/squid3/files/extra-patch-gen-stacktrace
blob: e1631e2398336a98141e0e6712ff0711adc07958 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
--- src/tools.cc.orig	2014-10-31 12:36:43.000000000 +0300
+++ src/tools.cc	2014-11-21 14:11:25.000000000 +0300
@@ -71,6 +71,13 @@
 #include <errno.h>
 #endif
 
+#if PRINT_STACK_TRACE
+#ifdef __FreeBSD__
+#define UNW_LOCAL_ONLY
+#include <libunwind.h>
+#endif
+#endif
+
 #define DEAD_MSG "\
 The Squid Cache (version %s) died.\n\
 \n\
@@ -411,6 +418,45 @@
     }
 
 #endif
+#ifdef __FreeBSD__
+    do {
+	unw_context_t unw_ctx;
+	unw_cursor_t unw_cp;
+	unw_word_t sp, ip, off;
+	int rc = 0;
+	char procname[256];
+	size_t frame;
+
+	bzero((void *)&unw_ctx, sizeof(unw_ctx));
+	bzero((void *)&unw_cp, sizeof(unw_cp));
+
+	if ((rc = unw_getcontext(&unw_ctx))) {
+            fprintf(debug_log, "Failed to trace own stack: "
+		    "unw_context() said '%s'.\n", unw_strerror(rc));
+	    break;
+	}
+	if ((rc = unw_init_local(&unw_cp, &unw_ctx))) {
+            fprintf(debug_log, "Failed to trace own stack: "
+		    "unw_init_local() said '%s'.\n", unw_strerror(rc));
+	    break;
+	}
+	frame = 0;
+	fprintf(debug_log, "Backtrace follows (deepest frame first):\n");
+	while ((rc = unw_step(&unw_cp)) > 0) {
+	    frame++;
+	    ip = 0; sp = 0;
+	    unw_get_reg(&unw_cp, UNW_REG_IP, &ip);
+	    unw_get_reg(&unw_cp, UNW_REG_SP, &sp);
+	    off = 0;
+	    rc = unw_get_proc_name(&unw_cp, procname, sizeof(procname), &off);
+	    if (rc)
+		snprintf (procname, sizeof(procname), "[unknown]");
+	    fprintf(debug_log, "#%zd: %s + 0x%zx, ip = 0x%zx, sp = 0x%zx\n",
+		    frame, procname, (size_t)off, (size_t)ip, (size_t)sp);
+	}
+	fprintf(debug_log, "Use addr2line of similar to translate offsets to line information.\n");
+    } while (0);
+#endif /* __FreeBSD__ */
 #endif /* PRINT_STACK_TRACE */
 
 #if SA_RESETHAND == 0 && !_SQUID_WINDOWS_