summaryrefslogblamecommitdiff
path: root/system/gdb/arm64.patch
blob: a718a8c6a4e2d898f33a4f61ab1dc3228f4c3a48 (plain) (tree)











































                                                                               
The signal definitions of musl and gdb collide

The kernel defines "struct sigcontext" in asm/sigcontext.h and musl libc 
defines it in signal.h which collides. 
Kernel 4.14 misses the definitions of struct user_sve_header so we still 
have to use the aarch64-sve-linux-sigcontext.h header file which also 
provides that and make sure aarch64-sve-linux-sigcontext.h does not 
provide the same headers as the kernel or musl.

--- a/gdb/nat/aarch64-sve-linux-ptrace.h
+++ b/gdb/nat/aarch64-sve-linux-ptrace.h
@@ -20,12 +20,12 @@
 #ifndef AARCH64_SVE_LINUX_PTRACE_H
 #define AARCH64_SVE_LINUX_PTRACE_H
 
-#include <asm/sigcontext.h>
+#include <signal.h>
 #include <sys/utsname.h>
 #include <sys/ptrace.h>
 #include <asm/ptrace.h>
 
-#ifndef SVE_SIG_ZREGS_SIZE
+#ifndef SVE_PT_REGS_SVE
 #include "aarch64-sve-linux-sigcontext.h"
 #endif
 
--- a/gdb/nat/aarch64-sve-linux-sigcontext.h
+++ b/gdb/nat/aarch64-sve-linux-sigcontext.h
@@ -19,6 +19,7 @@
 #ifndef AARCH64_SVE_LINUX_SIGCONTEXT_H
 #define AARCH64_SVE_LINUX_SIGCONTEXT_H
 
+#ifndef SVE_MAGIC
 #define SVE_MAGIC	0x53564501
 
 struct sve_context {
@@ -128,6 +129,7 @@ struct sve_context {
 	(SVE_SIG_FFR_OFFSET(vq) + SVE_SIG_FFR_SIZE(vq) - SVE_SIG_REGS_OFFSET)
 
 #define SVE_SIG_CONTEXT_SIZE(vq) (SVE_SIG_REGS_OFFSET + SVE_SIG_REGS_SIZE(vq))
+#endif
 
 /* SVE/FP/SIMD state (NT_ARM_SVE) */