blob: 3852b6e420ca6bf7ccae34c349db17e1ed87bf15 [file] [log] [blame]
Dan Gohmanb7c24002016-05-21 00:21:56 +00001; RUN: llc < %s -asm-verbose=false -disable-wasm-fallthrough-return-opt | FileCheck %s
2; RUN: llc < %s -asm-verbose=false -disable-wasm-fallthrough-return-opt -fast-isel -fast-isel-abort=1 | FileCheck %s
JF Bastien73ff6af2015-08-31 22:24:11 +00003
4; Test that basic stores are assembled properly.
5
Dan Gohman0c6f5ac2016-01-07 03:19:23 +00006target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128"
JF Bastien73ff6af2015-08-31 22:24:11 +00007target triple = "wasm32-unknown-unknown"
8
Dan Gohmane51c0582015-10-06 00:27:55 +00009; CHECK-LABEL: sti32:
Dan Gohman53828fd2015-11-23 16:50:18 +000010; CHECK-NEXT: .param i32, i32{{$}}
Dan Gohman7f1bdb22016-10-06 22:08:28 +000011; CHECK-NEXT: i32.store 0($0), $1{{$}}
Dan Gohmane51c0582015-10-06 00:27:55 +000012; CHECK-NEXT: return{{$}}
JF Bastien73ff6af2015-08-31 22:24:11 +000013define void @sti32(i32 *%p, i32 %v) {
14 store i32 %v, i32* %p
15 ret void
16}
17
Dan Gohmane51c0582015-10-06 00:27:55 +000018; CHECK-LABEL: sti64:
Dan Gohman53828fd2015-11-23 16:50:18 +000019; CHECK-NEXT: .param i32, i64{{$}}
Dan Gohman7f1bdb22016-10-06 22:08:28 +000020; CHECK-NEXT: i64.store 0($0), $1{{$}}
Dan Gohmane51c0582015-10-06 00:27:55 +000021; CHECK-NEXT: return{{$}}
JF Bastien73ff6af2015-08-31 22:24:11 +000022define void @sti64(i64 *%p, i64 %v) {
23 store i64 %v, i64* %p
24 ret void
25}
26
Dan Gohmane51c0582015-10-06 00:27:55 +000027; CHECK-LABEL: stf32:
Dan Gohman53828fd2015-11-23 16:50:18 +000028; CHECK-NEXT: .param i32, f32{{$}}
Dan Gohman7f1bdb22016-10-06 22:08:28 +000029; CHECK-NEXT: f32.store 0($0), $1{{$}}
Dan Gohmane51c0582015-10-06 00:27:55 +000030; CHECK-NEXT: return{{$}}
JF Bastien73ff6af2015-08-31 22:24:11 +000031define void @stf32(float *%p, float %v) {
32 store float %v, float* %p
33 ret void
34}
35
Dan Gohmane51c0582015-10-06 00:27:55 +000036; CHECK-LABEL: stf64:
Dan Gohman53828fd2015-11-23 16:50:18 +000037; CHECK-NEXT: .param i32, f64{{$}}
Dan Gohman7f1bdb22016-10-06 22:08:28 +000038; CHECK-NEXT: f64.store 0($0), $1{{$}}
Dan Gohmane51c0582015-10-06 00:27:55 +000039; CHECK-NEXT: return{{$}}
JF Bastien73ff6af2015-08-31 22:24:11 +000040define void @stf64(double *%p, double %v) {
41 store double %v, double* %p
42 ret void
43}