diff options
author | Dan Gohman <dan433584@gmail.com> | 2015-11-06 19:45:01 +0000 |
---|---|---|
committer | Dan Gohman <dan433584@gmail.com> | 2015-11-06 19:45:01 +0000 |
commit | 4b96d8d1ff42e5e9427d5f46efab889cfebda279 (patch) | |
tree | 2876e47368d26cf46f1e4a5d360e107d80a1a7a8 /llvm/test/CodeGen/WebAssembly/load-store-i1.ll | |
parent | 55ea67cea7f9fa45fe066c8670804582ad028faa (diff) | |
download | bcm5719-llvm-4b96d8d1ff42e5e9427d5f46efab889cfebda279.tar.gz bcm5719-llvm-4b96d8d1ff42e5e9427d5f46efab889cfebda279.zip |
[WebAssembly] Make expression-stack pushing explicit
Modelling of the expression stack is evolving. This patch takes another
step by making pushes explicit.
Differential Revision: http://reviews.llvm.org/D14338
llvm-svn: 252334
Diffstat (limited to 'llvm/test/CodeGen/WebAssembly/load-store-i1.ll')
-rw-r--r-- | llvm/test/CodeGen/WebAssembly/load-store-i1.ll | 20 |
1 files changed, 10 insertions, 10 deletions
diff --git a/llvm/test/CodeGen/WebAssembly/load-store-i1.ll b/llvm/test/CodeGen/WebAssembly/load-store-i1.ll index 8436af82f2e..18b8c7d42c7 100644 --- a/llvm/test/CodeGen/WebAssembly/load-store-i1.ll +++ b/llvm/test/CodeGen/WebAssembly/load-store-i1.ll @@ -6,7 +6,7 @@ target datalayout = "e-p:32:32-i64:64-n32:64-S128" target triple = "wasm32-unknown-unknown" ; CHECK-LABEL: load_u_i1_i32: -; CHECK: i32.load8_u (get_local 1){{$}} +; CHECK: i32.load8_u push, (get_local 1){{$}} ; CHECK-NEXT: set_local 2, pop{{$}} ; CHECK-NEXT: return (get_local 2){{$}} define i32 @load_u_i1_i32(i1* %p) { @@ -16,13 +16,13 @@ define i32 @load_u_i1_i32(i1* %p) { } ; CHECK-LABEL: load_s_i1_i32: -; CHECK: i32.load8_u (get_local 1){{$}} +; CHECK: i32.load8_u push, (get_local 1){{$}} ; CHECK-NEXT: set_local 2, pop{{$}} ; CHECK-NEXT: i32.const 31{{$}} ; CHECK-NEXT: set_local 3, pop{{$}} -; CHECK-NEXT: shl (get_local 2), (get_local 3){{$}} +; CHECK-NEXT: shl push, (get_local 2), (get_local 3){{$}} ; CHECK-NEXT: set_local 4, pop{{$}} -; CHECK-NEXT: shr_s (get_local 4), (get_local 3){{$}} +; CHECK-NEXT: shr_s push, (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) { @@ -32,7 +32,7 @@ define i32 @load_s_i1_i32(i1* %p) { } ; CHECK-LABEL: load_u_i1_i64: -; CHECK: i64.load8_u (get_local 1){{$}} +; CHECK: i64.load8_u push, (get_local 1){{$}} ; CHECK-NEXT: set_local 2, pop{{$}} ; CHECK-NEXT: return (get_local 2){{$}} define i64 @load_u_i1_i64(i1* %p) { @@ -42,13 +42,13 @@ define i64 @load_u_i1_i64(i1* %p) { } ; CHECK-LABEL: load_s_i1_i64: -; CHECK: i64.load8_u (get_local 1){{$}} +; CHECK: i64.load8_u push, (get_local 1){{$}} ; CHECK-NEXT: set_local 2, pop{{$}} ; CHECK-NEXT: i64.const 63{{$}} ; CHECK-NEXT: set_local 3, pop{{$}} -; CHECK-NEXT: shl (get_local 2), (get_local 3){{$}} +; CHECK-NEXT: shl push, (get_local 2), (get_local 3){{$}} ; CHECK-NEXT: set_local 4, pop{{$}} -; CHECK-NEXT: shr_s (get_local 4), (get_local 3){{$}} +; CHECK-NEXT: shr_s push, (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) { @@ -60,7 +60,7 @@ 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 (get_local 3), (get_local 4){{$}} +; CHECK-NEXT: and push, (get_local 3), (get_local 4){{$}} ; CHECK-NEXT: set_local 5, pop{{$}} ; CHECK-NEXT: i32.store8 (get_local 2), (get_local 5){{$}} define void @store_i32_i1(i1* %p, i32 %v) { @@ -72,7 +72,7 @@ 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 (get_local 3), (get_local 4){{$}} +; CHECK-NEXT: and push, (get_local 3), (get_local 4){{$}} ; CHECK-NEXT: set_local 5, pop{{$}} ; CHECK-NEXT: i64.store8 (get_local 2), (get_local 5){{$}} define void @store_i64_i1(i1* %p, i64 %v) { |