aa5578e31c1e9d16d3325c55985f74be82cb7c44
[oota-llvm.git] / test / CodeGen / WebAssembly / store.ll
1 ; RUN: llc < %s -asm-verbose=false | FileCheck %s
2
3 ; Test that basic stores are assembled properly.
4
5 target datalayout = "e-p:32:32-i64:64-n32:64-S128"
6 target triple = "wasm32-unknown-unknown"
7
8 ; CHECK-LABEL: sti32:
9 ; CHECK-NEXT: .param i32{{$}}
10 ; CHECK-NEXT: .param i32{{$}}
11 ; CHECK-NEXT: @1{{$}}
12 ; CHECK-NEXT: set_local @2, pop{{$}}
13 ; CHECK-NEXT: @0{{$}}
14 ; CHECK-NEXT: set_local @3, pop{{$}}
15 ; CHECK-NEXT: store_i32 @3, @2{{$}}
16 ; CHECK-NEXT: return{{$}}
17 define void @sti32(i32 *%p, i32 %v) {
18   store i32 %v, i32* %p
19   ret void
20 }
21
22 ; CHECK-LABEL: sti64:
23 ; CHECK-NEXT: .param i32{{$}}
24 ; CHECK-NEXT: .param i64{{$}}
25 ; CHECK-NEXT: @1{{$}}
26 ; CHECK-NEXT: set_local @2, pop{{$}}
27 ; CHECK-NEXT: @0{{$}}
28 ; CHECK-NEXT: set_local @3, pop{{$}}
29 ; CHECK-NEXT: store_i64 @3, @2{{$}}
30 ; CHECK-NEXT: return{{$}}
31 define void @sti64(i64 *%p, i64 %v) {
32   store i64 %v, i64* %p
33   ret void
34 }
35
36 ; CHECK-LABEL: stf32:
37 ; CHECK-NEXT: .param i32{{$}}
38 ; CHECK-NEXT: .param f32{{$}}
39 ; CHECK-NEXT: @1{{$}}
40 ; CHECK-NEXT: set_local @2, pop{{$}}
41 ; CHECK-NEXT: @0{{$}}
42 ; CHECK-NEXT: set_local @3, pop{{$}}
43 ; CHECK-NEXT: store_f32 @3, @2{{$}}
44 ; CHECK-NEXT: return{{$}}
45 define void @stf32(float *%p, float %v) {
46   store float %v, float* %p
47   ret void
48 }
49
50 ; CHECK-LABEL: stf64:
51 ; CHECK-NEXT: .param i32{{$}}
52 ; CHECK-NEXT: .param f64{{$}}
53 ; CHECK-NEXT: @1{{$}}
54 ; CHECK-NEXT: set_local @2, pop{{$}}
55 ; CHECK-NEXT: @0{{$}}
56 ; CHECK-NEXT: set_local @3, pop{{$}}
57 ; CHECK-NEXT: store_f64 @3, @2{{$}}
58 ; CHECK-NEXT: return{{$}}
59 define void @stf64(double *%p, double %v) {
60   store double %v, double* %p
61   ret void
62 }