blob: dc6da612171863e8aa522a32284da8587e6ba047 [file] [log] [blame]
Dan Gohmanb7c24002016-05-21 00:21:56 +00001; RUN: llc < %s -asm-verbose=false -disable-wasm-fallthrough-return-opt | FileCheck %s
Dan Gohman69c4c762015-08-24 21:03:24 +00002
3; Test that basic memory operations assemble as expected with 64-bit addresses.
4
Dan Gohman0c6f5ac2016-01-07 03:19:23 +00005target datalayout = "e-m:e-p:64:64-i64:64-n32:64-S128"
Dan Gohman69c4c762015-08-24 21:03:24 +00006target triple = "wasm64-unknown-unknown"
7
Derek Schuff31680dd2016-05-02 17:25:22 +00008declare i64 @llvm.wasm.current.memory.i64() nounwind readonly
Dan Gohmand7ffb912015-11-05 20:16:59 +00009declare void @llvm.wasm.grow.memory.i64(i64) 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 i64{{$}}
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 i64 @current_memory() {
16 %a = call i64 @llvm.wasm.current.memory.i64()
Dan Gohman72f16922015-10-02 19:21:15 +000017 ret i64 %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 i64{{$}}
Dan Gohman4ba48162015-11-18 16:12:01 +000022; CHECK: grow_memory $0{{$}}
23; CHECK-NEXT: return{{$}}
Dan Gohmand7ffb912015-11-05 20:16:59 +000024define void @grow_memory(i64 %n) {
25 call void @llvm.wasm.grow.memory.i64(i64 %n)
Dan Gohmanbaba8c62015-10-02 20:10:26 +000026 ret void
27}