2015-05-08 17:10:15 +08:00
|
|
|
; RUN: llc < %s -march=mips -mcpu=mips32 | FileCheck %s
|
|
|
|
; RUN: llc < %s -march=mips -mcpu=mips32r3 -mattr=+micromips | FileCheck %s
|
|
|
|
; RUN: llc < %s -march=mips -mcpu=mips16 | FileCheck %s
|
|
|
|
|
|
|
|
; Verify that we emit the .insn directive for zero-sized (empty) basic blocks.
|
|
|
|
; This only really matters for microMIPS and MIPS16.
|
|
|
|
|
|
|
|
declare i32 @foo(...)
|
|
|
|
declare void @bar()
|
|
|
|
|
2015-06-18 04:52:32 +08:00
|
|
|
define void @main() personality i8* bitcast (i32 (...)* @foo to i8*) {
|
2015-05-08 17:10:15 +08:00
|
|
|
entry:
|
|
|
|
invoke void @bar() #0
|
|
|
|
to label %unreachable unwind label %return
|
|
|
|
|
|
|
|
unreachable:
|
|
|
|
; CHECK: ${{.*}}: # %unreachable
|
|
|
|
; CHECK-NEXT: .insn
|
|
|
|
unreachable
|
|
|
|
|
|
|
|
return:
|
2015-06-18 04:52:32 +08:00
|
|
|
%0 = landingpad { i8*, i32 }
|
2015-05-08 17:10:15 +08:00
|
|
|
catch i8* null
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
attributes #0 = { noreturn }
|