Thomas Lively | d99af23 | 2019-02-05 00:49:55 +0000 | [diff] [blame] | 1 | ; RUN: llc < %s -asm-verbose=false -verify-machineinstrs -disable-wasm-fallthrough-return-opt -wasm-disable-explicit-locals -wasm-keep-registers -mattr=+bulk-memory | FileCheck %s --check-prefixes CHECK,BULK-MEM |
| 2 | ; RUN: llc < %s -asm-verbose=false -verify-machineinstrs -disable-wasm-fallthrough-return-opt -wasm-disable-explicit-locals -wasm-keep-registers -mattr=-bulk-memory | FileCheck %s --check-prefixes CHECK,NO-BULK-MEM |
Thomas Lively | 88058d4 | 2019-01-31 21:02:19 +0000 | [diff] [blame] | 3 | |
| 4 | ; Test that basic bulk memory codegen works correctly |
Thomas Lively | 88058d4 | 2019-01-31 21:02:19 +0000 | [diff] [blame] | 5 | |
| 6 | target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128" |
| 7 | target triple = "wasm32-unknown-unknown" |
Thomas Lively | d99af23 | 2019-02-05 00:49:55 +0000 | [diff] [blame] | 8 | |
Thomas Lively | de7a0a1 | 2019-02-13 22:11:16 +0000 | [diff] [blame] | 9 | declare void @llvm.memcpy.p0i8.p0i8.i8(i8*, i8*, i8, i1) |
| 10 | declare void @llvm.memcpy.p0i8.p0i8.i32(i8*, i8*, i32, i1) |
| 11 | declare void @llvm.memcpy.p0i32.p0i32.i32(i32*, i32*, i32, i1) |
| 12 | |
| 13 | declare void @llvm.memmove.p0i8.p0i8.i8(i8*, i8*, i8, i1) |
| 14 | declare void @llvm.memmove.p0i8.p0i8.i32(i8*, i8*, i32, i1) |
| 15 | declare void @llvm.memmove.p0i32.p0i32.i32(i32*, i32*, i32, i1) |
| 16 | |
Thomas Lively | bba3f06 | 2019-02-13 22:25:18 +0000 | [diff] [blame^] | 17 | declare void @llvm.memset.p0i8.i8(i8*, i8, i8, i1) |
| 18 | declare void @llvm.memset.p0i8.i32(i8*, i8, i32, i1) |
| 19 | declare void @llvm.memset.p0i32.i32(i32*, i8, i32, i1) |
| 20 | |
Thomas Lively | d99af23 | 2019-02-05 00:49:55 +0000 | [diff] [blame] | 21 | ; CHECK-LABEL: memcpy_i8: |
| 22 | ; NO-BULK-MEM-NOT: memory.copy |
| 23 | ; BULK-MEM-NEXT: .functype memcpy_i8 (i32, i32, i32) -> () |
Thomas Lively | de7a0a1 | 2019-02-13 22:11:16 +0000 | [diff] [blame] | 24 | ; BULK-MEM-NEXT: memory.copy 0, 0, $0, $1, $2 |
Thomas Lively | d99af23 | 2019-02-05 00:49:55 +0000 | [diff] [blame] | 25 | ; BULK-MEM-NEXT: return |
Thomas Lively | de7a0a1 | 2019-02-13 22:11:16 +0000 | [diff] [blame] | 26 | define void @memcpy_i8(i8* %dest, i8* %src, i8 zeroext %len) { |
| 27 | call void @llvm.memcpy.p0i8.p0i8.i8(i8* %dest, i8* %src, i8 %len, i1 0) |
Thomas Lively | d99af23 | 2019-02-05 00:49:55 +0000 | [diff] [blame] | 28 | ret void |
| 29 | } |
| 30 | |
Thomas Lively | 3150566 | 2019-02-05 20:57:40 +0000 | [diff] [blame] | 31 | ; CHECK-LABEL: memmove_i8: |
| 32 | ; NO-BULK-MEM-NOT: memory.copy |
| 33 | ; BULK-MEM-NEXT: .functype memmove_i8 (i32, i32, i32) -> () |
Thomas Lively | de7a0a1 | 2019-02-13 22:11:16 +0000 | [diff] [blame] | 34 | ; BULK-MEM-NEXT: memory.copy 0, 0, $0, $1, $2 |
Thomas Lively | 3150566 | 2019-02-05 20:57:40 +0000 | [diff] [blame] | 35 | ; BULK-MEM-NEXT: return |
Thomas Lively | de7a0a1 | 2019-02-13 22:11:16 +0000 | [diff] [blame] | 36 | define void @memmove_i8(i8* %dest, i8* %src, i8 zeroext %len) { |
| 37 | call void @llvm.memmove.p0i8.p0i8.i8(i8* %dest, i8* %src, i8 %len, i1 0) |
Thomas Lively | 3150566 | 2019-02-05 20:57:40 +0000 | [diff] [blame] | 38 | ret void |
| 39 | } |
| 40 | |
Thomas Lively | bba3f06 | 2019-02-13 22:25:18 +0000 | [diff] [blame^] | 41 | ; CHECK-LABEL: memset_i8: |
| 42 | ; NO-BULK-MEM-NOT: memory.fill |
| 43 | ; BULK-MEM-NEXT: .functype memset_i8 (i32, i32, i32) -> () |
| 44 | ; BULK-MEM-NEXT: memory.fill 0, $0, $1, $2 |
| 45 | ; BULK-MEM-NEXT: return |
| 46 | define void @memset_i8(i8* %dest, i8 %val, i8 zeroext %len) { |
| 47 | call void @llvm.memset.p0i8.i8(i8* %dest, i8 %val, i8 %len, i1 0) |
| 48 | ret void |
| 49 | } |
| 50 | |
Thomas Lively | d99af23 | 2019-02-05 00:49:55 +0000 | [diff] [blame] | 51 | ; CHECK-LABEL: memcpy_i32: |
| 52 | ; NO-BULK-MEM-NOT: memory.copy |
| 53 | ; BULK-MEM-NEXT: .functype memcpy_i32 (i32, i32, i32) -> () |
Thomas Lively | de7a0a1 | 2019-02-13 22:11:16 +0000 | [diff] [blame] | 54 | ; BULK-MEM-NEXT: memory.copy 0, 0, $0, $1, $2 |
Thomas Lively | d99af23 | 2019-02-05 00:49:55 +0000 | [diff] [blame] | 55 | ; BULK-MEM-NEXT: return |
Thomas Lively | d99af23 | 2019-02-05 00:49:55 +0000 | [diff] [blame] | 56 | define void @memcpy_i32(i32* %dest, i32* %src, i32 %len) { |
| 57 | call void @llvm.memcpy.p0i32.p0i32.i32(i32* %dest, i32* %src, i32 %len, i1 0) |
| 58 | ret void |
| 59 | } |
| 60 | |
Thomas Lively | 3150566 | 2019-02-05 20:57:40 +0000 | [diff] [blame] | 61 | ; CHECK-LABEL: memmove_i32: |
| 62 | ; NO-BULK-MEM-NOT: memory.copy |
| 63 | ; BULK-MEM-NEXT: .functype memmove_i32 (i32, i32, i32) -> () |
Thomas Lively | de7a0a1 | 2019-02-13 22:11:16 +0000 | [diff] [blame] | 64 | ; BULK-MEM-NEXT: memory.copy 0, 0, $0, $1, $2 |
Thomas Lively | 3150566 | 2019-02-05 20:57:40 +0000 | [diff] [blame] | 65 | ; BULK-MEM-NEXT: return |
Thomas Lively | 3150566 | 2019-02-05 20:57:40 +0000 | [diff] [blame] | 66 | define void @memmove_i32(i32* %dest, i32* %src, i32 %len) { |
| 67 | call void @llvm.memmove.p0i32.p0i32.i32(i32* %dest, i32* %src, i32 %len, i1 0) |
| 68 | ret void |
| 69 | } |
| 70 | |
Thomas Lively | bba3f06 | 2019-02-13 22:25:18 +0000 | [diff] [blame^] | 71 | ; CHECK-LABEL: memset_i32: |
| 72 | ; NO-BULK-MEM-NOT: memory.fill |
| 73 | ; BULK-MEM-NEXT: .functype memset_i32 (i32, i32, i32) -> () |
| 74 | ; BULK-MEM-NEXT: memory.fill 0, $0, $1, $2 |
| 75 | ; BULK-MEM-NEXT: return |
| 76 | define void @memset_i32(i32* %dest, i8 %val, i32 %len) { |
| 77 | call void @llvm.memset.p0i32.i32(i32* %dest, i8 %val, i32 %len, i1 0) |
| 78 | ret void |
| 79 | } |
| 80 | |
Thomas Lively | d99af23 | 2019-02-05 00:49:55 +0000 | [diff] [blame] | 81 | ; CHECK-LABEL: memcpy_1: |
| 82 | ; CHECK-NEXT: .functype memcpy_1 (i32, i32) -> () |
| 83 | ; CHECK-NEXT: i32.load8_u $push[[L0:[0-9]+]]=, 0($1) |
| 84 | ; CHECK-NEXT: i32.store8 0($0), $pop[[L0]] |
| 85 | ; CHECK-NEXT: return |
| 86 | define void @memcpy_1(i8* %dest, i8* %src) { |
| 87 | call void @llvm.memcpy.p0i8.p0i8.i32(i8* %dest, i8* %src, i32 1, i1 0) |
| 88 | ret void |
| 89 | } |
| 90 | |
Thomas Lively | 3150566 | 2019-02-05 20:57:40 +0000 | [diff] [blame] | 91 | ; CHECK-LABEL: memmove_1: |
| 92 | ; CHECK-NEXT: .functype memmove_1 (i32, i32) -> () |
| 93 | ; CHECK-NEXT: i32.load8_u $push[[L0:[0-9]+]]=, 0($1) |
| 94 | ; CHECK-NEXT: i32.store8 0($0), $pop[[L0]] |
| 95 | ; CHECK-NEXT: return |
| 96 | define void @memmove_1(i8* %dest, i8* %src) { |
| 97 | call void @llvm.memmove.p0i8.p0i8.i32(i8* %dest, i8* %src, i32 1, i1 0) |
| 98 | ret void |
| 99 | } |
| 100 | |
Thomas Lively | bba3f06 | 2019-02-13 22:25:18 +0000 | [diff] [blame^] | 101 | ; CHECK-LABEL: memset_1: |
| 102 | ; NO-BULK-MEM-NOT: memory.fill |
| 103 | ; BULK-MEM-NEXT: .functype memset_1 (i32, i32) -> () |
| 104 | ; BULK-MEM-NEXT: i32.store8 0($0), $1 |
| 105 | ; BULK-MEM-NEXT: return |
| 106 | define void @memset_1(i8* %dest, i8 %val) { |
| 107 | call void @llvm.memset.p0i8.i32(i8* %dest, i8 %val, i32 1, i1 0) |
| 108 | ret void |
| 109 | } |
| 110 | |
Thomas Lively | d99af23 | 2019-02-05 00:49:55 +0000 | [diff] [blame] | 111 | ; CHECK-LABEL: memcpy_1024: |
| 112 | ; NO-BULK-MEM-NOT: memory.copy |
| 113 | ; BULK-MEM-NEXT: .functype memcpy_1024 (i32, i32) -> () |
| 114 | ; BULK-MEM-NEXT: i32.const $push[[L0:[0-9]+]]=, 1024 |
Thomas Lively | de7a0a1 | 2019-02-13 22:11:16 +0000 | [diff] [blame] | 115 | ; BULK-MEM-NEXT: memory.copy 0, 0, $0, $1, $pop[[L0]] |
Thomas Lively | d99af23 | 2019-02-05 00:49:55 +0000 | [diff] [blame] | 116 | ; BULK-MEM-NEXT: return |
| 117 | define void @memcpy_1024(i8* %dest, i8* %src) { |
| 118 | call void @llvm.memcpy.p0i8.p0i8.i32(i8* %dest, i8* %src, i32 1024, i1 0) |
| 119 | ret void |
| 120 | } |
Thomas Lively | 3150566 | 2019-02-05 20:57:40 +0000 | [diff] [blame] | 121 | |
| 122 | ; CHECK-LABEL: memmove_1024: |
| 123 | ; NO-BULK-MEM-NOT: memory.copy |
| 124 | ; BULK-MEM-NEXT: .functype memmove_1024 (i32, i32) -> () |
| 125 | ; BULK-MEM-NEXT: i32.const $push[[L0:[0-9]+]]=, 1024 |
Thomas Lively | de7a0a1 | 2019-02-13 22:11:16 +0000 | [diff] [blame] | 126 | ; BULK-MEM-NEXT: memory.copy 0, 0, $0, $1, $pop[[L0]] |
Thomas Lively | 3150566 | 2019-02-05 20:57:40 +0000 | [diff] [blame] | 127 | ; BULK-MEM-NEXT: return |
| 128 | define void @memmove_1024(i8* %dest, i8* %src) { |
| 129 | call void @llvm.memmove.p0i8.p0i8.i32(i8* %dest, i8* %src, i32 1024, i1 0) |
| 130 | ret void |
| 131 | } |
Thomas Lively | bba3f06 | 2019-02-13 22:25:18 +0000 | [diff] [blame^] | 132 | |
| 133 | ; CHECK-LABEL: memset_1024: |
| 134 | ; NO-BULK-MEM-NOT: memory.fill |
| 135 | ; BULK-MEM-NEXT: .functype memset_1024 (i32, i32) -> () |
| 136 | ; BULK-MEM-NEXT: i32.const $push[[L0:[0-9]+]]=, 1024 |
| 137 | ; BULK-MEM-NEXT: memory.fill 0, $0, $1, $pop[[L0]] |
| 138 | ; BULK-MEM-NEXT: return |
| 139 | define void @memset_1024(i8* %dest, i8 %val) { |
| 140 | call void @llvm.memset.p0i8.i32(i8* %dest, i8 %val, i32 1024, i1 0) |
| 141 | ret void |
| 142 | } |