From: Dan Gohman Date: Fri, 2 Oct 2015 20:20:01 +0000 (+0000) Subject: [WebAssembly] Add a __builtin_wasm_resize_memory() intrinsic. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e9c854387a9d993adf64bae0e0fdda074009cc4f;p=clang [WebAssembly] Add a __builtin_wasm_resize_memory() intrinsic. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@249179 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/Basic/BuiltinsWebAssembly.def b/include/clang/Basic/BuiltinsWebAssembly.def index 060d5548e4..2f48d5d2b1 100644 --- a/include/clang/Basic/BuiltinsWebAssembly.def +++ b/include/clang/Basic/BuiltinsWebAssembly.def @@ -18,5 +18,6 @@ BUILTIN(__builtin_wasm_page_size, "z", "nc") BUILTIN(__builtin_wasm_memory_size, "z", "nc") +BUILTIN(__builtin_wasm_resize_memory, "vz", "n") #undef BUILTIN diff --git a/lib/CodeGen/CGBuiltin.cpp b/lib/CodeGen/CGBuiltin.cpp index ff2cef9b02..1de59d568d 100644 --- a/lib/CodeGen/CGBuiltin.cpp +++ b/lib/CodeGen/CGBuiltin.cpp @@ -7053,6 +7053,11 @@ Value *CodeGenFunction::EmitWebAssemblyBuiltinExpr(unsigned BuiltinID, Value *Callee = CGM.getIntrinsic(Intrinsic::wasm_memory_size, ResultType); return Builder.CreateCall(Callee); } + case WebAssembly::BI__builtin_wasm_resize_memory: { + Value *X = EmitScalarExpr(E->getArg(0)); + Value *Callee = CGM.getIntrinsic(Intrinsic::wasm_resize_memory, X->getType()); + return Builder.CreateCall(Callee, X); + } default: return nullptr; diff --git a/test/CodeGen/builtins-wasm.c b/test/CodeGen/builtins-wasm.c index d8da8d73a2..2de08c71c8 100644 --- a/test/CodeGen/builtins-wasm.c +++ b/test/CodeGen/builtins-wasm.c @@ -14,3 +14,9 @@ __SIZE_TYPE__ f1(void) { // WEBASSEMBLY32: call {{i.*}} @llvm.wasm.memory.size.i32() // WEBASSEMBLY64: call {{i.*}} @llvm.wasm.memory.size.i64() } + +void f2(long delta) { + __builtin_wasm_resize_memory(delta); +// WEBASSEMBLY32: call void @llvm.wasm.resize.memory.i32(i32 %{{.*}}) +// WEBASSEMBLY64: call void @llvm.wasm.resize.memory.i64(i64 %{{.*}}) +}