diff options
author | JF Bastien <jfb@google.com> | 2015-10-16 00:53:49 +0000 |
---|---|---|
committer | JF Bastien <jfb@google.com> | 2015-10-16 00:53:49 +0000 |
commit | 1d20a5e9e8061848c33207da5d02c6fbd706ffc1 (patch) | |
tree | 0e1bfd186c16b0b60563390a311ebdd079349fe4 /llvm/test/CodeGen/WebAssembly/load-store-i1.ll | |
parent | ad5e0cefa15d81cf3688a65b55d7e26d91512150 (diff) | |
download | bcm5719-llvm-1d20a5e9e8061848c33207da5d02c6fbd706ffc1.tar.gz bcm5719-llvm-1d20a5e9e8061848c33207da5d02c6fbd706ffc1.zip |
WebAssembly: update syntax
Summary:
Follow the same syntax as for the spec repo. Both have evolved slightly
independently and need to converge again.
This, along with wasmate changes, allows me to do the following:
echo "int add(int a, int b) { return a + b; }" > add.c
./out/bin/clang -O2 -S --target=wasm32-unknown-unknown add.c -o add.wack
./experimental/prototype-wasmate/wasmate.py add.wack > add.wast
./sexpr-wasm-prototype/out/sexpr-wasm add.wast -o add.wasm
./sexpr-wasm-prototype/third_party/v8-native-prototype/v8/v8/out/Release/d8 -e "print(WASM.instantiateModule(readbuffer('add.wasm'), {print:print}).add(42, 1337));"
As you'd expect, the d8 shell prints out the right value.
Reviewers: sunfish
Subscribers: jfb, llvm-commits, dschuff
Differential Revision: http://reviews.llvm.org/D13712
llvm-svn: 250480
Diffstat (limited to 'llvm/test/CodeGen/WebAssembly/load-store-i1.ll')
-rw-r--r-- | llvm/test/CodeGen/WebAssembly/load-store-i1.ll | 60 |
1 files changed, 30 insertions, 30 deletions
diff --git a/llvm/test/CodeGen/WebAssembly/load-store-i1.ll b/llvm/test/CodeGen/WebAssembly/load-store-i1.ll index 0a6d9db492c..af1a82206ae 100644 --- a/llvm/test/CodeGen/WebAssembly/load-store-i1.ll +++ b/llvm/test/CodeGen/WebAssembly/load-store-i1.ll @@ -6,9 +6,9 @@ target datalayout = "e-p:32:32-i64:64-n32:64-S128" target triple = "wasm32-unknown-unknown" ; CHECK-LABEL: load_u_i1_i32: -; CHECK: load_u_i8_i32 @1{{$}} -; CHECK-NEXT: set_local @2, pop{{$}} -; CHECK-NEXT: return @2{{$}} +; CHECK: load_u_i8_i32 (get_local 1){{$}} +; CHECK-NEXT: set_local 2, pop{{$}} +; CHECK-NEXT: return (get_local 2){{$}} define i32 @load_u_i1_i32(i1* %p) { %v = load i1, i1* %p %e = zext i1 %v to i32 @@ -16,15 +16,15 @@ define i32 @load_u_i1_i32(i1* %p) { } ; CHECK-LABEL: load_s_i1_i32: -; CHECK: load_u_i8_i32 @1{{$}} -; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK: load_u_i8_i32 (get_local 1){{$}} +; CHECK-NEXT: set_local 2, pop{{$}} ; CHECK-NEXT: i32.const 31{{$}} -; CHECK-NEXT: set_local @3, pop{{$}} -; CHECK-NEXT: shl @2, @3{{$}} -; CHECK-NEXT: set_local @4, pop{{$}} -; CHECK-NEXT: shr_s @4, @3{{$}} -; CHECK-NEXT: set_local @5, pop{{$}} -; CHECK-NEXT: return @5{{$}} +; CHECK-NEXT: set_local 3, pop{{$}} +; CHECK-NEXT: shl (get_local 2), (get_local 3){{$}} +; CHECK-NEXT: set_local 4, pop{{$}} +; CHECK-NEXT: shr_s (get_local 4), (get_local 3){{$}} +; CHECK-NEXT: set_local 5, pop{{$}} +; CHECK-NEXT: return (get_local 5){{$}} define i32 @load_s_i1_i32(i1* %p) { %v = load i1, i1* %p %e = sext i1 %v to i32 @@ -32,9 +32,9 @@ define i32 @load_s_i1_i32(i1* %p) { } ; CHECK-LABEL: load_u_i1_i64: -; CHECK: load_u_i8_i64 @1{{$}} -; CHECK-NEXT: set_local @2, pop{{$}} -; CHECK-NEXT: return @2{{$}} +; CHECK: load_u_i8_i64 (get_local 1){{$}} +; CHECK-NEXT: set_local 2, pop{{$}} +; CHECK-NEXT: return (get_local 2){{$}} define i64 @load_u_i1_i64(i1* %p) { %v = load i1, i1* %p %e = zext i1 %v to i64 @@ -42,15 +42,15 @@ define i64 @load_u_i1_i64(i1* %p) { } ; CHECK-LABEL: load_s_i1_i64: -; CHECK: load_u_i8_i64 @1{{$}} -; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK: load_u_i8_i64 (get_local 1){{$}} +; CHECK-NEXT: set_local 2, pop{{$}} ; CHECK-NEXT: i64.const 63{{$}} -; CHECK-NEXT: set_local @3, pop{{$}} -; CHECK-NEXT: shl @2, @3{{$}} -; CHECK-NEXT: set_local @4, pop{{$}} -; CHECK-NEXT: shr_s @4, @3{{$}} -; CHECK-NEXT: set_local @5, pop{{$}} -; CHECK-NEXT: return @5{{$}} +; CHECK-NEXT: set_local 3, pop{{$}} +; CHECK-NEXT: shl (get_local 2), (get_local 3){{$}} +; CHECK-NEXT: set_local 4, pop{{$}} +; CHECK-NEXT: shr_s (get_local 4), (get_local 3){{$}} +; CHECK-NEXT: set_local 5, pop{{$}} +; CHECK-NEXT: return (get_local 5){{$}} define i64 @load_s_i1_i64(i1* %p) { %v = load i1, i1* %p %e = sext i1 %v to i64 @@ -59,10 +59,10 @@ define i64 @load_s_i1_i64(i1* %p) { ; CHECK-LABEL: store_i32_i1: ; CHECK: i32.const 1{{$}} -; CHECK-NEXT: set_local @4, pop{{$}} -; CHECK-NEXT: and @3, @4{{$}} -; CHECK-NEXT: set_local @5, pop{{$}} -; CHECK-NEXT: store_i8 @2, @5{{$}} +; CHECK-NEXT: set_local 4, pop{{$}} +; CHECK-NEXT: and (get_local 3), (get_local 4){{$}} +; CHECK-NEXT: set_local 5, pop{{$}} +; CHECK-NEXT: store_i8 (get_local 2), (get_local 5){{$}} define void @store_i32_i1(i1* %p, i32 %v) { %t = trunc i32 %v to i1 store i1 %t, i1* %p @@ -71,10 +71,10 @@ define void @store_i32_i1(i1* %p, i32 %v) { ; CHECK-LABEL: store_i64_i1: ; CHECK: i64.const 1{{$}} -; CHECK-NEXT: set_local @4, pop{{$}} -; CHECK-NEXT: and @3, @4{{$}} -; CHECK-NEXT: set_local @5, pop{{$}} -; CHECK-NEXT: store_i8 @2, @5{{$}} +; CHECK-NEXT: set_local 4, pop{{$}} +; CHECK-NEXT: and (get_local 3), (get_local 4){{$}} +; CHECK-NEXT: set_local 5, pop{{$}} +; CHECK-NEXT: store_i8 (get_local 2), (get_local 5){{$}} define void @store_i64_i1(i1* %p, i64 %v) { %t = trunc i64 %v to i1 store i1 %t, i1* %p |