2015-08-27 04:46:49 +08:00
|
|
|
; RUN: llc -O0 -mtriple=x86_64-linux -asm-verbose=false -verify-machineinstrs < %s | FileCheck %s
|
|
|
|
; RUN: llc -O0 -mtriple=x86_64-windows-itanium -asm-verbose=false -verify-machineinstrs < %s | FileCheck %s
|
|
|
|
|
|
|
|
; Fast-isel mustn't add a block to the MBB successor/predecessor list twice.
|
|
|
|
; The machine verifier will catch and complain about this case.
|
|
|
|
; CHECK-LABEL: baz
|
|
|
|
; CHECK: retq
|
|
|
|
define void @baz() {
|
|
|
|
entry:
|
|
|
|
br i1 undef, label %exit, label %exit
|
|
|
|
|
|
|
|
exit:
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2010-08-21 10:32:36 +08:00
|
|
|
; rdar://8337108
|
|
|
|
|
|
|
|
; Fast-isel shouldn't try to look through the compare because it's in a
|
|
|
|
; different basic block, so its operands aren't necessarily exported
|
|
|
|
; for cross-block usage.
|
|
|
|
|
2021-05-11 16:57:18 +08:00
|
|
|
; CHECK: movb %al, [[OFS:[0-9]*]](%rsp)
|
2010-08-21 10:32:36 +08:00
|
|
|
; CHECK: callq {{_?}}bar
|
2011-02-22 15:19:54 +08:00
|
|
|
; CHECK: movb [[OFS]](%rsp), %al
|
2010-08-21 10:32:36 +08:00
|
|
|
|
|
|
|
declare void @bar()
|
|
|
|
|
2015-06-18 04:52:32 +08:00
|
|
|
define void @foo(i32 %a, i32 %b) nounwind personality i32 (...)* @__gxx_personality_v0 {
|
2010-08-21 10:32:36 +08:00
|
|
|
entry:
|
|
|
|
%q = add i32 %a, 7
|
|
|
|
%r = add i32 %b, 9
|
|
|
|
%t = icmp ult i32 %q, %r
|
|
|
|
invoke void @bar() to label %next unwind label %unw
|
|
|
|
next:
|
|
|
|
br i1 %t, label %true, label %return
|
|
|
|
true:
|
|
|
|
call void @bar()
|
|
|
|
br label %return
|
|
|
|
return:
|
|
|
|
ret void
|
|
|
|
unw:
|
2015-06-18 04:52:32 +08:00
|
|
|
%exn = landingpad {i8*, i32}
|
2011-09-01 05:39:05 +08:00
|
|
|
cleanup
|
2010-08-21 10:32:36 +08:00
|
|
|
unreachable
|
|
|
|
}
|
2011-09-01 05:39:05 +08:00
|
|
|
|
|
|
|
declare i32 @__gxx_personality_v0(...)
|