1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2025-01-31 20:51:52 +01:00
llvm-mirror/test/CodeGen/X86/inline-asm-stack-realign3.ll
Matthias Braun f7935a3f63 X86: Do not use llc -march in tests.
`llc -march` is problematic because it only switches the target
architecture, but leaves the operating system unchanged. This
occasionally leads to indeterministic tests because the OS from
LLVM_DEFAULT_TARGET_TRIPLE is used.

However we can simply always use `llc -mtriple` instead. This changes
all the tests to do this to avoid people using -march when they copy and
paste parts of tests.

See also the discussion in https://reviews.llvm.org/D35287

llvm-svn: 309774
2017-08-02 00:28:10 +00:00

30 lines
643 B
LLVM

; RUN: llc -mtriple=i686-- -no-integrated-as < %s | FileCheck %s
declare void @bar(i32* %junk)
define i32 @foo(i1 %cond) {
entry:
%r = alloca i32, align 128
store i32 -1, i32* %r, align 128
br i1 %cond, label %doit, label %skip
doit:
call void asm sideeffect "xor %ecx, %ecx\0A\09mov %ecx, $0", "=*m,~{ecx},~{flags}"(i32* %r)
%junk = alloca i32
call void @bar(i32* %junk)
br label %skip
skip:
%0 = load i32, i32* %r, align 128
ret i32 %0
}
; CHECK-LABEL: foo:
; CHECK: pushl %ebp
; CHECK: andl $-128, %esp
; CHECK: xor %ecx, %ecx
; CHECK-NEXT: mov %ecx, (%esi)
; CHECK: movl (%esi), %eax
; CHECK: popl %ebp
; CHECK: ret