diff options
author | Victor Kamensky <victor.kamensky@linaro.org> | 2014-12-03 17:35:44 -0800 |
---|---|---|
committer | Arun Sharma <arun@sharma-home.net> | 2014-12-03 23:28:07 -0800 |
commit | 16e98c8cf37b006c3879ee57acc23c9af13c40d5 (patch) | |
tree | be7e228fd3d641f40e139c658c58b1168c9c1812 /src/aarch64 | |
parent | 743668f66916b6bb03c92b04be5216400951ace6 (diff) | |
download | libunwind-16e98c8cf37b006c3879ee57acc23c9af13c40d5.tar.gz |
aarch64: fix wrong big_endian flag in aarch64_be case
Set local_addr_space.big_endian flag according to current target
endianness. Before it was set by memset to 0, which corresponds
to little endian and it worked perfectly fine for aarch64.
But it breaks aarch64_be because dwarf_readu16, dwarf_readu32,
etc functions do not read values correctly since they operate
with wrong idea about current target endianness.
Signed-off-by: Victor Kamensky <victor.kamensky@linaro.org>
Diffstat (limited to 'src/aarch64')
-rw-r--r-- | src/aarch64/Ginit.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/src/aarch64/Ginit.c b/src/aarch64/Ginit.c index 0bc89971..b9181ef0 100644 --- a/src/aarch64/Ginit.c +++ b/src/aarch64/Ginit.c @@ -181,6 +181,7 @@ aarch64_local_addr_space_init (void) local_addr_space.acc.access_fpreg = access_fpreg; local_addr_space.acc.resume = aarch64_local_resume; local_addr_space.acc.get_proc_name = get_static_proc_name; + local_addr_space.big_endian = (__BYTE_ORDER == __BIG_ENDIAN); unw_flush_cache (&local_addr_space, 0, 0); } |