mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-26 04:32:44 +01:00
[objdump][ARM] Fix evaluating the target address of a Thumb BLX(i)
The instruction can be 16-bit aligned while targeting 32-bit aligned code. To calculate the target address correctly, the address of the instruction has to be adjusted. Differential Revision: https://reviews.llvm.org/D104446
This commit is contained in:
parent
b219ce9cea
commit
ca414c6429
@ -429,6 +429,14 @@ public:
|
||||
// is 4 bytes.
|
||||
uint64_t Offset = ((Desc.TSFlags & ARMII::FormMask) == ARMII::ThumbFrm) ? 4 : 8;
|
||||
|
||||
// A Thumb instruction BLX(i) can be 16-bit aligned while targets Arm code
|
||||
// which is 32-bit aligned. The target address for the case is calculated as
|
||||
// targetAddress = Align(PC,4) + imm32;
|
||||
// where
|
||||
// Align(x, y) = y * (x DIV y);
|
||||
if (Inst.getOpcode() == ARM::tBLXi)
|
||||
Addr &= ~0x3;
|
||||
|
||||
Target = Addr + Imm + Offset;
|
||||
return true;
|
||||
}
|
||||
|
26
test/tools/llvm-objdump/ELF/ARM/tblxi-target.s
Normal file
26
test/tools/llvm-objdump/ELF/ARM/tblxi-target.s
Normal file
@ -0,0 +1,26 @@
|
||||
## Check that the disassembler reports the target address of a Thumb BLX(i)
|
||||
## instruction correctly even if the instruction is not 32-bit aligned.
|
||||
|
||||
# RUN: llvm-mc %s --triple=armv8a -filetype=obj | \
|
||||
# RUN: llvm-objdump -dr - --triple armv8a --no-show-raw-insn | \
|
||||
# RUN: FileCheck %s
|
||||
|
||||
# CHECK: <test>:
|
||||
# CHECK-NEXT: 4: nop
|
||||
# CHECK-NEXT: 6: blx #-8 <foo>
|
||||
# CHECK-NEXT: a: blx #4 <bar>
|
||||
|
||||
.arm
|
||||
foo:
|
||||
nop
|
||||
|
||||
.thumb
|
||||
test:
|
||||
nop
|
||||
blx #-8
|
||||
blx #4
|
||||
|
||||
.arm
|
||||
.p2align 2
|
||||
bar:
|
||||
nop
|
Loading…
Reference in New Issue
Block a user