File: insn-zero-size-bb.ll

package info (click to toggle)
llvm-toolchain-4.0 1%3A4.0.1-10~deb9u2
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 493,332 kB
  • sloc: cpp: 2,698,100; ansic: 552,773; asm: 128,821; python: 121,589; objc: 105,054; sh: 21,174; lisp: 6,758; ml: 5,532; perl: 5,311; pascal: 5,245; makefile: 2,083; cs: 1,868; xml: 686; php: 212; csh: 117
file content (27 lines) | stat: -rw-r--r-- 726 bytes parent folder | download | duplicates (19)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
; 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 -mattr=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()

define void @main() personality i8* bitcast (i32 (...)* @foo to i8*) {
entry:
  invoke void @bar() #0
          to label %unreachable unwind label %return

unreachable:
; CHECK:          {{.*}}: # %unreachable
; CHECK-NEXT:         .insn
  unreachable

return:
  %0 = landingpad { i8*, i32 }
          catch i8* null
  ret void
}

attributes #0 = { noreturn }