blob: ad599b1b3f17da9c1698445a8660279ff416f4d0 [file] [log] [blame]
Dan Gohman7d7409e2017-02-28 23:37:04 +00001; RUN: llc < %s -asm-verbose=false -disable-wasm-fallthrough-return-opt -disable-wasm-explicit-locals | FileCheck %s
Dan Gohman69c4c762015-08-24 21:03:24 +00002
3; Test that basic memory operations assemble as expected with 32-bit addresses.
4
Dan Gohman0c6f5ac2016-01-07 03:19:23 +00005target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128"
Dan Gohman7d7409e2017-02-28 23:37:04 +00006target triple = "wasm32-unknown-unknown-wasm"
Dan Gohman69c4c762015-08-24 21:03:24 +00007
Derek Schuff31680dd2016-05-02 17:25:22 +00008declare i32 @llvm.wasm.current.memory.i32() nounwind readonly
Dan Gohman73e3aaa2017-01-18 01:02:45 +00009declare i32 @llvm.wasm.grow.memory.i32(i32) nounwind
Dan Gohman72f16922015-10-02 19:21:15 +000010
Derek Schuff31680dd2016-05-02 17:25:22 +000011; CHECK-LABEL: current_memory:
Dan Gohmane51c0582015-10-06 00:27:55 +000012; CHECK-NEXT: .result i32{{$}}
Derek Schuff31680dd2016-05-02 17:25:22 +000013; CHECK-NEXT: current_memory $push0={{$}}
Dan Gohman81719f82015-11-25 16:55:01 +000014; CHECK-NEXT: return $pop0{{$}}
Derek Schuff31680dd2016-05-02 17:25:22 +000015define i32 @current_memory() {
16 %a = call i32 @llvm.wasm.current.memory.i32()
Dan Gohman72f16922015-10-02 19:21:15 +000017 ret i32 %a
18}
Dan Gohmanbaba8c62015-10-02 20:10:26 +000019
Dan Gohmand7ffb912015-11-05 20:16:59 +000020; CHECK-LABEL: grow_memory:
Dan Gohman1270b0a2015-11-25 17:33:15 +000021; CHECK-NEXT: .param i32{{$}}
Dan Gohman73e3aaa2017-01-18 01:02:45 +000022; CHECK-NEXT: .result i32{{$}}
23; CHECK: grow_memory $push0=, $0{{$}}
24; CHECK-NEXT: return $pop0{{$}}
25define i32 @grow_memory(i32 %n) {
26 %a = call i32 @llvm.wasm.grow.memory.i32(i32 %n)
27 ret i32 %a
Dan Gohmanbaba8c62015-10-02 20:10:26 +000028}