diff options
author | David Spickett <david.spickett@linaro.org> | 2025-08-06 08:44:01 +0000 |
---|---|---|
committer | David Spickett <david.spickett@linaro.org> | 2025-08-06 09:25:48 +0000 |
commit | 49d5dd37f8bdd961d11cdf4df95d26982b253e97 (patch) | |
tree | 0efe030f8ac2e8adb0c576621cc257b19509ace2 /lldb/source/Plugins/ScriptInterpreter/Python/SWIGPythonBridge.h | |
parent | b24ad98caa7cdc48ed9034310c8876811d6e52aa (diff) | |
download | llvm-49d5dd37f8bdd961d11cdf4df95d26982b253e97.zip llvm-49d5dd37f8bdd961d11cdf4df95d26982b253e97.tar.gz llvm-49d5dd37f8bdd961d11cdf4df95d26982b253e97.tar.bz2 |
Reland "[lldb] Fix auto advance PC in `EmulateInstructionARM64` if PC >= 4G (#151460)"
This reverts commit 600976f4bfb06526c283dcc4efc4801792f08ca5.
The test was crashing trying to access any element of the GPR struct.
(gdb) disas
Dump of assembler code for function _ZN7testing8internal11CmpHelperEQIyyEENS_15AssertionResultEPKcS4_RKT_RKT0_:
0x00450afc <+0>: push {r4, r5, r6, r7, r8, r9, r10, r11, lr}
0x00450b00 <+4>: sub sp, sp, #60 ; 0x3c
0x00450b04 <+8>: ldr r5, [sp, #96] ; 0x60
=> 0x00450b08 <+12>: ldm r3, {r4, r7}
0x00450b0c <+16>: ldm r5, {r6, r9}
0x00450b10 <+20>: eor r7, r7, r9
0x00450b14 <+24>: eor r6, r4, r6
0x00450b18 <+28>: orrs r7, r6, r7
(gdb) p/x r3
$3 = 0x3e300f6e
"However, load and store multiple instructions (LDM and STM) and load and store double-word (LDRD or STRD) must be aligned to at least a word boundary."
https://developer.arm.com/documentation/den0013/d/Porting/Alignment
>>> 0x3e300f6e % 4
2
Program received signal SIGBUS, Bus error.
0x00450b08 in testing::AssertionResult testing::internal::CmpHelperEQ<unsigned long long, unsigned long long>(char const*, char const*, unsigned long long const&, unsigned long long const&) ()
The struct is packed with 1 byte alignment, but it needs to start at an aligned address for us
to ldm from it. So I've done that with alignas.
Also fixed some compiler warnings in the test itself.
Diffstat (limited to 'lldb/source/Plugins/ScriptInterpreter/Python/SWIGPythonBridge.h')
0 files changed, 0 insertions, 0 deletions