[libcxx-commits] [PATCH] D64996: [libunwind][ARM] Fix loading FP registers on big-endian targets
Mikhail Maltsev via Phabricator via libcxx-commits
libcxx-commits at lists.llvm.org
Fri Jul 19 07:40:26 PDT 2019
miyuki created this revision.
miyuki added reviewers: ostannard, john.brawn, dmgreen.
Herald added subscribers: christof, kristof.beyls.
Herald added a project: libc++.
The function Unwind-EHABI.cpp:_Unwind_VRS_Pop loads the saved values of
64-bit FP registers as two 32-bit words because they might not be
8-byte aligned. Combining these words into a 64-bit value has to be
done differently on big-endian platforms.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D64996
Files:
libunwind/src/Unwind-EHABI.cpp
Index: libunwind/src/Unwind-EHABI.cpp
===================================================================
--- libunwind/src/Unwind-EHABI.cpp
+++ libunwind/src/Unwind-EHABI.cpp
@@ -941,8 +941,13 @@
// format 1", which is equivalent to FSTMD + a padding word.
for (uint32_t i = first; i < end; ++i) {
// SP is only 32-bit aligned so don't copy 64-bit at a time.
- uint64_t value = *sp++;
- value |= ((uint64_t)(*sp++)) << 32;
+ uint32_t w0 = *sp++;
+ uint32_t w1 = *sp++;
+#ifdef __LITTLE_ENDIAN__
+ uint64_t value = (w1 << 32) | w0;
+#else
+ uint64_t value = (w0 << 32) | w1;
+#endif
if (_Unwind_VRS_Set(context, regclass, i, representation, &value) !=
_UVRSR_OK)
return _UVRSR_FAILED;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D64996.210836.patch
Type: text/x-patch
Size: 783 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/libcxx-commits/attachments/20190719/89f2ec17/attachment.bin>
More information about the libcxx-commits
mailing list