llvm/test/Transforms/BranchFolding/2007-10-19-InlineAsmDirectives.ll
Sanjoy Das 6ea7654870 Address post-commit review from r243378.
This checks that bork_directive occurs exactly twice in the test output.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@244543 91177308-0d34-0410-b5e6-96231b3b80d8
2015-08-11 00:20:24 +00:00

23 lines
759 B
LLVM

; RUN: opt < %s -O3 | llc -no-integrated-as | FileCheck %s
; REQUIRES: X86
;; We don't want branch folding to fold asm directives.
; CHECK: bork_directive
; CHECK: bork_directive
; CHECK-NOT: bork_directive
define void @bork(i32 %param) {
entry:
%tmp = icmp eq i32 %param, 0
br i1 %tmp, label %cond_true, label %cond_false
cond_true:
call void asm sideeffect ".bork_directive /* ${0:c}:${1:c} */", "i,i,~{dirflag},~{fpsr},~{flags}"( i32 37, i32 927 )
ret void
cond_false:
call void asm sideeffect ".foo_directive ${0:c}:${1:c}", "i,i,~{dirflag},~{fpsr},~{flags}"( i32 37, i32 927 )
call void asm sideeffect ".bork_directive /* ${0:c}:${1:c} */", "i,i,~{dirflag},~{fpsr},~{flags}"( i32 37, i32 927 )
ret void
}