blob: 222f996d1b38e00500ac1dbb5bd2fa9a16195212 [file] [log] [blame]
Derek Schuff9769deb2015-12-11 23:49:46 +00001; RUN: llc < %s -asm-verbose=false | FileCheck %s
2; RUN: llc < %s -asm-verbose=false -fast-isel | FileCheck %s
3
4
Dan Gohman0c6f5ac2016-01-07 03:19:23 +00005target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128"
Derek Schuff9769deb2015-12-11 23:49:46 +00006target triple = "wasm32-unknown-unknown"
7
8; CHECK-LABEL: alloca32:
Derek Schuff45cd5a72015-12-16 20:43:06 +00009; Check that there is an extra local for the stack pointer.
10; CHECK: .local i32, i32, i32, i32{{$}}
Derek Schuff9769deb2015-12-11 23:49:46 +000011define void @alloca32() {
12 ; CHECK: i32.const [[L1:.+]]=, __stack_pointer
13 ; CHECK-NEXT: i32.load [[L1]]=, 0([[L1]])
14 ; CHECK-NEXT: i32.const [[L2:.+]]=, 16
15 ; CHECK-NEXT: i32.sub [[SP:.+]]=, [[L1]], [[L2]]
16 %retval = alloca i32
17 ; CHECK: i32.const $push[[L3:.+]]=, 0
18 ; CHECK: i32.store {{.*}}=, 12([[SP]]), $pop[[L3]]
19 store i32 0, i32* %retval
20 ; CHECK: i32.const [[L4:.+]]=, 16
21 ; CHECK-NEXT: i32.add [[SP]]=, [[SP]], [[L4]]
22 ; CHECK-NEXT: i32.const [[L5:.+]]=, __stack_pointer
23 ; CHECK-NEXT: i32.store [[SP]]=, 0([[L5]]), [[SP]]
24 ret void
25}
26
27; CHECK-LABEL: alloca3264:
Derek Schuff45cd5a72015-12-16 20:43:06 +000028; CHECK: .local i32, i32, i32, i32{{$}}
Derek Schuff9769deb2015-12-11 23:49:46 +000029define void @alloca3264() {
30 ; CHECK: i32.const [[L1:.+]]=, __stack_pointer
31 ; CHECK-NEXT: i32.load [[L1]]=, 0([[L1]])
32 ; CHECK-NEXT: i32.const [[L2:.+]]=, 16
33 ; CHECK-NEXT: i32.sub [[SP:.+]]=, [[L1]], [[L2]]
34 %r1 = alloca i32
35 %r2 = alloca double
36 ; CHECK: i32.const $push[[L3:.+]]=, 0
37 ; CHECK: i32.store {{.*}}=, 12([[SP]]), $pop[[L3]]
38 store i32 0, i32* %r1
39 ; CHECK: i64.const $push[[L4:.+]]=, 0
40 ; CHECK: i64.store {{.*}}=, 0([[SP]]), $pop[[L4]]
41 store double 0.0, double* %r2
42 ; CHECK: i32.const [[L4:.+]]=, 16
43 ; CHECK-NEXT: i32.add [[SP]]=, [[SP]], [[L4]]
44 ; CHECK-NEXT: i32.const [[L5:.+]]=, __stack_pointer
45 ; CHECK-NEXT: i32.store [[SP]]=, 0([[L5]]), [[SP]]
46 ret void
47}
48
Derek Schuff45cd5a72015-12-16 20:43:06 +000049; CHECK-LABEL: allocarray:
Dan Gohman7e649172016-01-20 04:21:16 +000050; CHECK: .local i32, i32, i32, i32, i32{{$}}
Derek Schuff9769deb2015-12-11 23:49:46 +000051define void @allocarray() {
Dan Gohman7e649172016-01-20 04:21:16 +000052 ; CHECK-NEXT: i32.const [[L1:.+]]=, __stack_pointer
Derek Schuff9769deb2015-12-11 23:49:46 +000053 ; CHECK-NEXT: i32.load [[L1]]=, 0([[L1]])
Dan Gohman7e649172016-01-20 04:21:16 +000054 ; CHECK-NEXT: i32.const [[L2:.+]]=, 32{{$}}
Derek Schuff9769deb2015-12-11 23:49:46 +000055 ; CHECK-NEXT: i32.sub [[SP:.+]]=, [[L1]], [[L2]]
Dan Gohman7e649172016-01-20 04:21:16 +000056 ; CHECK-NEXT: i32.const [[L2]]=, __stack_pointer{{$}}
57 ; CHECK-NEXT: i32.store [[SP]]=, 0([[L2]]), [[SP]]
Derek Schuff9769deb2015-12-11 23:49:46 +000058 %r = alloca [5 x i32]
Dan Gohman7e649172016-01-20 04:21:16 +000059
Dan Gohmanbb372242016-01-26 03:39:31 +000060 ; CHECK-NEXT: i32.const $push[[L4:.+]]=, 12
Dan Gohman7e649172016-01-20 04:21:16 +000061 ; CHECK-NEXT: i32.const [[L5:.+]]=, 12
62 ; CHECK-NEXT: i32.add [[L5]]=, [[SP]], [[L5]]
63 ; CHECK-NEXT: i32.add $push[[L6:.+]]=, [[L5]], $pop[[L4]]
64 ; CHECK-NEXT: i32.const $push[[L9:.+]]=, 1{{$}}
65 ; CHECK-NEXT: i32.store $push[[L10:.+]]=, 12([[SP]]), $pop[[L9]]{{$}}
66 ; CHECK-NEXT: i32.store $discard=, 0($pop3), $pop[[L10]]{{$}}
Derek Schuff9769deb2015-12-11 23:49:46 +000067 %p = getelementptr [5 x i32], [5 x i32]* %r, i32 0, i32 0
68 store i32 1, i32* %p
Dan Gohmanbb372242016-01-26 03:39:31 +000069 %p2 = getelementptr [5 x i32], [5 x i32]* %r, i32 0, i32 3
Derek Schuff9769deb2015-12-11 23:49:46 +000070 store i32 1, i32* %p2
Dan Gohman7e649172016-01-20 04:21:16 +000071
72 ; CHECK-NEXT: i32.const [[L7:.+]]=, 32
Derek Schuff9769deb2015-12-11 23:49:46 +000073 ; CHECK-NEXT: i32.add [[SP]]=, [[SP]], [[L7]]
74 ; CHECK-NEXT: i32.const [[L8:.+]]=, __stack_pointer
Dan Gohman7e649172016-01-20 04:21:16 +000075 ; CHECK-NEXT: i32.store [[SP]]=, 0([[L8]]), [[SP]]
Derek Schuff9769deb2015-12-11 23:49:46 +000076 ret void
77}
78
Dan Gohman7e649172016-01-20 04:21:16 +000079; CHECK-LABEL: allocarray_inbounds:
80; CHECK: .local i32, i32, i32, i32{{$}}
Derek Schuff9bfea272016-01-07 18:55:52 +000081define void @allocarray_inbounds() {
82 ; CHECK: i32.const [[L1:.+]]=, __stack_pointer
83 ; CHECK-NEXT: i32.load [[L1]]=, 0([[L1]])
84 ; CHECK-NEXT: i32.const [[L2:.+]]=, 32
85 ; CHECK-NEXT: i32.sub [[SP:.+]]=, [[L1]], [[L2]]
86 %r = alloca [5 x i32]
87 ; CHECK: i32.const $push[[L3:.+]]=, 1
88 ; CHECK: i32.store {{.*}}=, 12([[SP]]), $pop[[L3]]
89 %p = getelementptr inbounds [5 x i32], [5 x i32]* %r, i32 0, i32 0
90 store i32 1, i32* %p
91 ; This store should have both the GEP and the FI folded into it.
Dan Gohmanbb372242016-01-26 03:39:31 +000092 ; CHECK-NEXT: i32.store {{.*}}=, 24([[SP]]), $pop
93 %p2 = getelementptr inbounds [5 x i32], [5 x i32]* %r, i32 0, i32 3
Derek Schuff9bfea272016-01-07 18:55:52 +000094 store i32 1, i32* %p2
95 ; CHECK: i32.const [[L7:.+]]=, 32
96 ; CHECK-NEXT: i32.add [[SP]]=, [[SP]], [[L7]]
97 ; CHECK-NEXT: i32.const [[L8:.+]]=, __stack_pointer
98 ; CHECK-NEXT: i32.store [[SP]]=, 0([[L7]]), [[SP]]
99 ret void
100}
101
Dan Gohman7e649172016-01-20 04:21:16 +0000102; CHECK-LABEL: dynamic_alloca:
Derek Schuff8bb5f292015-12-16 23:21:30 +0000103define void @dynamic_alloca(i32 %alloc) {
104 ; TODO: Support frame pointers
105 ;%r = alloca i32, i32 %alloc
106 ;store i32 0, i32* %r
107 ret void
108}
Derek Schuff9769deb2015-12-11 23:49:46 +0000109; TODO: test aligned alloc