mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-17 16:37:06 +00:00

In 96e5ee2, I inadvertently broke the way non-trivial symbol references got updated from non-optimized code. The breakage was a consequence of `getTargetSymbol(MCExpr *)` not returning a symbol when the parameter was a binary expression. Fix `getTargetSymbol()` to cover such cases.
34 lines
921 B
ArmAsm
34 lines
921 B
ArmAsm
## Check that llvm-bolt properly updates references in unoptimized code when
|
|
## such references are non-trivial expressions.
|
|
|
|
# RUN: %clang %cflags %s -o %t.exe -Wl,-q -no-pie
|
|
# RUN: llvm-bolt %t.exe -o %t.bolt --funcs=_start
|
|
# RUN: llvm-objdump -d --disassemble-symbols=_start %t.bolt > %t.out
|
|
# RUN: llvm-objdump -d --disassemble-symbols=cold %t.bolt >> %t.out
|
|
# RUN: FileCheck %s < %t.out
|
|
|
|
## _start() will be optimized and assigned a new address.
|
|
# CHECK: [[#%x,ADDR:]] <_start>:
|
|
|
|
## cold() is not optimized, but references to _start are updated.
|
|
# CHECK-LABEL: <cold>:
|
|
# CHECK-NEXT: movl $0x[[#ADDR - 1]], %ecx
|
|
# CHECK-NEXT: movl $0x[[#ADDR]], %ecx
|
|
# CHECK-NEXT: movl $0x[[#ADDR + 1]], %ecx
|
|
|
|
.text
|
|
.globl cold
|
|
.type cold, %function
|
|
cold:
|
|
movl $_start-1, %ecx
|
|
movl $_start, %ecx
|
|
movl $_start+1, %ecx
|
|
ret
|
|
.size cold, .-cold
|
|
|
|
.globl _start
|
|
.type _start, %function
|
|
_start:
|
|
ret
|
|
.size _start, .-_start
|