forked from OSchip/llvm-project
65 lines
2.1 KiB
ArmAsm
Executable File
65 lines
2.1 KiB
ArmAsm
Executable File
# This reproduces a bug with shrink wrapping when moving
|
|
# load instructions in-between the lock prefix and another
|
|
# instruction (where the lock prefix applies).
|
|
|
|
# REQUIRES: system-linux
|
|
|
|
# RUN: llvm-mc -filetype=obj -triple x86_64-unknown-unknown \
|
|
# RUN: %s -o %t.o
|
|
# RUN: link_fdata %s %t.o %t.fdata
|
|
# Delete our BB symbols so BOLT doesn't mark them as entry points
|
|
# RUN: llvm-strip --strip-unneeded %t.o
|
|
# RUN: %clang %cflags %t.o -o %t.exe -Wl,-q
|
|
|
|
# RUN: llvm-bolt %t.exe -relocs=1 -frame-opt=all -print-fop \
|
|
# RUN: -print-only=main -data %t.fdata -o %t.out | FileCheck %s
|
|
|
|
# RUN: %t.out 1
|
|
|
|
# CHECK: BOLT-INFO: Shrink wrapping moved 1 spills inserting load/stores and 0 spills inserting push/pops
|
|
|
|
.text
|
|
.globl main
|
|
.type main, %function
|
|
.p2align 4
|
|
main:
|
|
# FDATA: 0 [unknown] 0 1 main 0 0 510
|
|
pushq %rbp
|
|
movq %rsp, %rbp
|
|
pushq %rbx # We save rbx here, but there is an
|
|
# opportunity to move it to .LBB2
|
|
subq $0x18, %rsp
|
|
cmpl $0x2, %edi
|
|
.J1:
|
|
jb .BBend
|
|
# FDATA: 1 main #.J1# 1 main #.BB2# 0 10
|
|
# FDATA: 1 main #.J1# 1 main #.BBend# 0 500
|
|
.BB2:
|
|
movq $2, %rbx # Use rbx in a cold block. Save rbx will be moved
|
|
# just before this instruction.
|
|
xorq %rax, %rax
|
|
movb mystring, %al
|
|
addq %rbx, %rax
|
|
movb %al, mystring
|
|
leaq mystring, %rdi
|
|
callq puts
|
|
lock add %r12,0x0(%rsp) # Put a lock in an unrelated instruction at the
|
|
# dom. frontier where the restore will be moved to
|
|
# We should not put the restore in-between the
|
|
# lock and add! We typically avoid putting a
|
|
# restore in the last BB instruction, but since
|
|
# lock in llvm MC lib is considered a
|
|
# separate instruction, we may mistakenly
|
|
# put the restore just between these two.
|
|
|
|
.BBend:
|
|
addq $0x18, %rsp
|
|
pop %rbx # Restore should be moved
|
|
xorq %rax, %rax
|
|
leaveq
|
|
retq
|
|
.size main, .-main
|
|
|
|
.data
|
|
mystring: .asciz "0 is rbx mod 10 contents in decimal\n"
|