From 578f370c7e7a9f056aefa062b34590b0aa13bce5 Mon Sep 17 00:00:00 2001 From: Hongxu Jia Date: Tue, 15 Aug 2017 17:27:30 +0800 Subject: [PATCH] Fix build on aarch64/musl Errors invalid operands to binary & (have 'long double' and 'unsigned int') error: redefinition of 'struct iovec' struct iovec { void *iov_base; size_t iov_len; }; ^ Upstream-Status: Pending Signed-off-by: Khem Raj Rebase to 0.170 Signed-off-by: Hongxu Jia --- backends/aarch64_initreg.c | 4 ++-- backends/arm_initreg.c | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) --- a/backends/aarch64_initreg.c +++ b/backends/aarch64_initreg.c @@ -33,7 +33,7 @@ #include "system.h" #include #if defined(__aarch64__) && defined(__linux__) -# include +# include # include # include # include @@ -94,7 +94,7 @@ aarch64_set_initial_registers_tid (pid_t Dwarf_Word dwarf_fregs[32]; for (int r = 0; r < 32; r++) - dwarf_fregs[r] = fregs.vregs[r] & 0xFFFFFFFF; + dwarf_fregs[r] = (unsigned int)fregs.vregs[r] & 0xFFFFFFFF; if (! setfunc (64, 32, dwarf_fregs, arg)) return false; --- a/backends/arm_initreg.c +++ b/backends/arm_initreg.c @@ -38,7 +38,7 @@ #endif #ifdef __aarch64__ -# include +# include # include # include /* Deal with old glibc defining user_pt_regs instead of user_regs_struct. */