aboutsummaryrefslogtreecommitdiffstats
path: root/main/elfutils/fix-aarch64_fregs.patch
diff options
context:
space:
mode:
authorNatanael Copa <ncopa@alpinelinux.org>2017-02-13 18:57:00 +0000
committerNatanael Copa <ncopa@alpinelinux.org>2017-02-14 18:50:07 +0000
commite8fa24936ac303abe0978950898625fca30b17ec (patch)
tree192ac8fcc535b189065ca35fce455c67519d4a1e /main/elfutils/fix-aarch64_fregs.patch
parent69a9add8425a3ac8a4ce5294354a543c63d35e39 (diff)
downloadaports-e8fa24936ac303abe0978950898625fca30b17ec.tar.bz2
aports-e8fa24936ac303abe0978950898625fca30b17ec.tar.xz
main/elfutils: move from testing
Diffstat (limited to 'main/elfutils/fix-aarch64_fregs.patch')
-rw-r--r--main/elfutils/fix-aarch64_fregs.patch22
1 files changed, 22 insertions, 0 deletions
diff --git a/main/elfutils/fix-aarch64_fregs.patch b/main/elfutils/fix-aarch64_fregs.patch
new file mode 100644
index 0000000000..bafa8012cf
--- /dev/null
+++ b/main/elfutils/fix-aarch64_fregs.patch
@@ -0,0 +1,22 @@
+It looks like fregs.vregs[] is an array of double?
+Casting to Dwarf_Word instead of & 0xFFFFFFF should do.
+
+--- a/backends/aarch64_initreg.c 2015-11-27 14:36:29.000000000 +0100
++++ b/backends/aarch64_initreg.c 2016-08-09 03:47:25.428560159 +0200
+@@ -33,7 +33,6 @@
+ #include "system.h"
+ #include <assert.h>
+ #ifdef __aarch64__
+-# include <linux/uio.h>
+ # include <sys/user.h>
+ # include <sys/ptrace.h>
+ /* Deal with old glibc defining user_pt_regs instead of user_regs_struct. */
+@@ -82,7 +82,7 @@
+
+ Dwarf_Word dwarf_fregs[32];
+ for (int r = 0; r < 32; r++)
+- dwarf_fregs[r] = fregs.vregs[r] & 0xFFFFFFFF;
++ dwarf_fregs[r] = (Dwarf_Word)fregs.vregs[r];
+
+ if (! setfunc (64, 32, dwarf_fregs, arg))
+ return false;