1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=wasm32-- -mattr=+simd128 | FileCheck --check-prefix=CHECK-32 %s
3 ; RUN: llc < %s -mtriple=wasm64-- -mattr=+simd128 | FileCheck --check-prefix=CHECK-64 %s
5 define i8 @f(ptr %0, ptr %1) {
7 ; CHECK-32: .functype f (i32, i32) -> (i32)
8 ; CHECK-32-NEXT: # %bb.0: # %BB
9 ; CHECK-32-NEXT: local.get 0
10 ; CHECK-32-NEXT: i32.const 0
11 ; CHECK-32-NEXT: i32.store8 2
12 ; CHECK-32-NEXT: local.get 0
13 ; CHECK-32-NEXT: i32.const 0
14 ; CHECK-32-NEXT: i32.store16 0
15 ; CHECK-32-NEXT: local.get 1
16 ; CHECK-32-NEXT: i32.const 0
17 ; CHECK-32-NEXT: i32.store8 2
18 ; CHECK-32-NEXT: local.get 1
19 ; CHECK-32-NEXT: i32.const 0
20 ; CHECK-32-NEXT: i32.store16 0
21 ; CHECK-32-NEXT: i32.const 0
22 ; CHECK-32-NEXT: # fallthrough-return
25 ; CHECK-64: .functype f (i64, i64) -> (i32)
26 ; CHECK-64-NEXT: # %bb.0: # %BB
27 ; CHECK-64-NEXT: local.get 0
28 ; CHECK-64-NEXT: i32.const 0
29 ; CHECK-64-NEXT: i32.store8 2
30 ; CHECK-64-NEXT: local.get 0
31 ; CHECK-64-NEXT: i32.const 0
32 ; CHECK-64-NEXT: i32.store16 0
33 ; CHECK-64-NEXT: local.get 1
34 ; CHECK-64-NEXT: i32.const 0
35 ; CHECK-64-NEXT: i32.store16 0
36 ; CHECK-64-NEXT: i32.const 0
37 ; CHECK-64-NEXT: # fallthrough-return
39 store <3 x i8> zeroinitializer, ptr %0
40 %S = shufflevector <3 x i128> zeroinitializer, <3 x i128> <i128 0, i128 1, i128 2>, <3 x i32> undef
41 %C = icmp ule <3 x i128> %S, zeroinitializer
42 %C1 = zext <3 x i1> %C to <3 x i8>
43 %E = extractelement <3 x i8> %C1, i32 0
44 %B = sdiv <3 x i8> <i8 1, i8 3, i8 5>, %C1
45 store <3 x i8> %B, ptr %1