[WebAssembly] Enable register coloring and register stackifying.
[oota-llvm.git] / test / CodeGen / WebAssembly / func.ll
1 ; RUN: llc < %s -asm-verbose=false | FileCheck %s
2
3 ; Test that basic functions assemble as expected.
4
5 target datalayout = "e-p:32:32-i64:64-n32:64-S128"
6 target triple = "wasm32-unknown-unknown"
7
8 ; CHECK-LABEL: f0:
9 ; CHECK: return{{$}}
10 ; CHECK: .size f0,
11 define void @f0() {
12   ret void
13 }
14
15 ; CHECK-LABEL: f1:
16 ; CHECK-NEXT: .result i32{{$}}
17 ; CHECK-NEXT: i32.const $push[[NUM:[0-9]+]], 0{{$}}
18 ; CHECK-NEXT: return $pop[[NUM]]{{$}}
19 ; CHECK: .size f1,
20 define i32 @f1() {
21   ret i32 0
22 }
23
24 ; CHECK-LABEL: f2:
25 ; CHECK-NEXT: .param i32{{$}}
26 ; CHECK-NEXT: .param f32{{$}}
27 ; CHECK-NEXT: .result i32{{$}}
28 ; CHECK-NEXT: i32.const $push[[NUM:[0-9]+]], 0{{$}}
29 ; CHECK-NEXT: return $pop[[NUM]]{{$}}
30 ; CHECK: .size f2,
31 define i32 @f2(i32 %p1, float %p2) {
32   ret i32 0
33 }
34
35 ; CHECK-LABEL: f3:
36 ; CHECK-NEXT: .param i32{{$}}
37 ; CHECK-NEXT: .param f32{{$}}
38 ; CHECK-NOT: .local
39 ; CHECK-NEXT: return{{$}}
40 ; CHECK: .size f3,
41 define void @f3(i32 %p1, float %p2) {
42   ret void
43 }
44
45 ; CHECK-LABEL: f4:
46 ; CHECK-NEXT: .param i32{{$}}
47 ; CHECK-NEXT: .result i32{{$}}
48 ; CHECK-NEXT: .local
49 define i32 @f4(i32 %x) {
50 entry:
51    %c = trunc i32 %x to i1
52    br i1 %c, label %true, label %false
53 true:
54    ret i32 0
55 false:
56    ret i32 1
57 }
58
59 ; CHECK-LABEL: f5:
60 ; CHECK-NEXT: .result f32{{$}}
61 ; CHECK-NEXT: unreachable
62 define float @f5()  {
63  unreachable
64 }