24 lines
749 B
Diff
24 lines
749 B
Diff
It looks like fregs.vregs[] is an array of double?
|
|
Casting to Dwarf_Word instead of & 0xFFFFFFF should do.
|
|
|
|
--- backends/aarch64_initreg.c 2015-11-27 14:36:29.000000000 +0100
|
|
+++ backends/aarch64_initreg.c 2016-08-09 03:47:25.428560159 +0200
|
|
@@ -33,7 +33,7 @@
|
|
#include "system.h"
|
|
#include <assert.h>
|
|
#ifdef __aarch64__
|
|
-# include <linux/uio.h>
|
|
+# include <sys/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 +83,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;
|