libunwind: patch to fix build on non-glibc

This commit is contained in:
Will Dietz 2018-01-11 14:27:52 -06:00
parent 41026550e2
commit bc2ad5a968
2 changed files with 46 additions and 0 deletions

View File

@ -0,0 +1,45 @@
From 04437142399662b576bd55a85485c6dcc14d0812 Mon Sep 17 00:00:00 2001
From: Khem Raj <raj.khem at gmail.com>
Date: Thu, 31 Dec 2015 06:44:07 +0000
Subject: [PATCH] backtrace: Use only with glibc and uclibc
backtrace API is glibc specific not linux specific
so make it behave so.
Signed-off-by: Khem Raj <raj.khem at gmail.com>
---
Upstream-Status: Pending
tests/test-coredump-unwind.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/tests/test-coredump-unwind.c b/tests/test-coredump-unwind.c
index 5254708..8767b42 100644
--- a/tests/test-coredump-unwind.c
+++ b/tests/test-coredump-unwind.c
@@ -57,7 +57,9 @@
#include <grp.h>
/* For SIGSEGV handler code */
+#ifdef __GLIBC__
#include <execinfo.h>
+#endif
#include <sys/ucontext.h>
#include <libunwind-coredump.h>
@@ -238,11 +240,11 @@ void handle_sigsegv(int sig, siginfo_t *info, void *ucontext)
ip);
{
+#ifdef __GLIBC__
/* glibc extension */
void *array[50];
int size;
size = backtrace(array, 50);
-#ifdef __linux__
backtrace_symbols_fd(array, size, 2);
#endif
}
--
2.6.4

View File

@ -11,6 +11,7 @@ stdenv.mkDerivation rec {
patches = [ patches = [
./version-1.2.1.patch ./version-1.2.1.patch
./backtrace-only-with-glibc.patch
]; ];
nativeBuildInputs = [ autoreconfHook ]; nativeBuildInputs = [ autoreconfHook ];