mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 19:23:23 +01:00
d163afe84b
D63847 added `MCInstrAnalysis::evaluateMemoryOperandAddress()`. This patch leverages the feature to print the target addresses for evaluable instructions. ``` -400a: movl 4080(%rip), %eax +400a: movl 4080(%rip), %eax # 5000 <data1> ``` This patch also deletes `MIA->isCall(Inst) || MIA->isUnconditionalBranch(Inst) || MIA->isConditionalBranch(Inst)` which is used to guard `MCInstrAnalysis::evaluateBranch()` Reviewed By: jhenderson, skan Differential Revision: https://reviews.llvm.org/D78776
20 lines
676 B
ArmAsm
20 lines
676 B
ArmAsm
# RUN: llvm-mc -triple x86_64-pc-linux-musl %s | FileCheck --check-prefix=PRINT %s
|
|
|
|
# RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-musl %s -o %t
|
|
# RUN: llvm-readelf -s %t | FileCheck --check-prefix=SYM %s
|
|
# RUN: llvm-objdump -d -r --no-show-raw-insn %t | FileCheck --match-full-lines %s
|
|
|
|
# PRINT: leaq a@tlsdesc(%rip), %rax
|
|
# PRINT-NEXT: callq *a@tlscall(%rax)
|
|
|
|
# SYM: TLS GLOBAL DEFAULT UND a
|
|
|
|
# CHECK: 0: leaq (%rip), %rax # 7 <{{.*}}>
|
|
# CHECK-NEXT: 0000000000000003: R_X86_64_GOTPC32_TLSDESC a-0x4
|
|
# CHECK-NEXT: 7: callq *(%rax)
|
|
# CHECK-NEXT: 0000000000000007: R_X86_64_TLSDESC_CALL a
|
|
|
|
leaq a@tlsdesc(%rip), %rax
|
|
call *a@tlscall(%rax)
|
|
addq %fs:0, %rax
|