blob: af585dd706653346c46a8c949ddef6d1e9b6f4f3 [file] [log] [blame]
Heejin Ahna0fd9c32018-08-14 18:53:27 +00001; RUN: llc < %s -asm-verbose=false -disable-wasm-fallthrough-return-opt -disable-wasm-explicit-locals -wasm-enable-unimplemented-simd -mattr=+simd128,+sign-ext | FileCheck %s --check-prefixes CHECK,SIMD128
2; RUN: llc < %s -asm-verbose=false -disable-wasm-fallthrough-return-opt -disable-wasm-explicit-locals -mattr=+simd128,+sign-ext | FileCheck %s --check-prefixes CHECK,SIMD128-VM
3; RUN: llc < %s -asm-verbose=false -disable-wasm-fallthrough-return-opt -disable-wasm-explicit-locals -mattr=-simd128,+sign-ext | FileCheck %s --check-prefixes CHECK,NO-SIMD128
4
5; Test that basic SIMD128 vector manipulation operations assemble as expected.
6
7target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128"
8target triple = "wasm32-unknown-unknown"
9
10; ==============================================================================
11; 16 x i8
12; ==============================================================================
13; CHECK-LABEL: extract_v16i8_s:{{$}}
14; NO-SIMD128-NOT: i8x16
15; SIMD128: .param v128{{$}}
16; SIMD128: .result i32{{$}}
17; SIMD128: i8x16.extract_lane_s $push0=, $0, 13{{$}}
18; SIMD128: return $pop0{{$}}
19define i32 @extract_v16i8_s(<16 x i8> %v) {
20 %elem = extractelement <16 x i8> %v, i8 13
21 %a = sext i8 %elem to i32
22 ret i32 %a
23}
24
25; CHECK-LABEL: extract_v16i8_u:{{$}}
26; NO-SIMD128-NOT: i8x16
27; SIMD128: .param v128{{$}}
28; SIMD128: .result i32{{$}}
29; SIMD128: i8x16.extract_lane_u $push0=, $0, 13{{$}}
30; SIMD128: return $pop0{{$}}
31define i32 @extract_v16i8_u(<16 x i8> %v) {
32 %elem = extractelement <16 x i8> %v, i8 13
33 %a = zext i8 %elem to i32
34 ret i32 %a
35}
36
37; CHECK-LABEL: extract_v16i8:{{$}}
38; NO-SIMD128-NOT: i8x16
39; SIMD128: .param v128{{$}}
40; SIMD128: .result i32{{$}}
41; SIMD128: i8x16.extract_lane_u $push0=, $0, 13{{$}}
42; SIMD128: return $pop0{{$}}
43define i8 @extract_v16i8(<16 x i8> %v) {
44 %elem = extractelement <16 x i8> %v, i8 13
45 ret i8 %elem
46}
47
48; ==============================================================================
49; 8 x i16
50; ==============================================================================
51; CHECK-LABEL: extract_v8i16_s:{{$}}
52; NO-SIMD128-NOT: i16x8
53; SIMD128: .param v128{{$}}
54; SIMD128: .result i32{{$}}
55; SIMD128: i16x8.extract_lane_s $push0=, $0, 5{{$}}
56; SIMD128: return $pop0{{$}}
57define i32 @extract_v8i16_s(<8 x i16> %v) {
58 %elem = extractelement <8 x i16> %v, i16 5
59 %a = sext i16 %elem to i32
60 ret i32 %a
61}
62
63; CHECK-LABEL: extract_v8i16_u:{{$}}
64; NO-SIMD128-NOT: i16x8
65; SIMD128: .param v128{{$}}
66; SIMD128: .result i32{{$}}
67; SIMD128: i16x8.extract_lane_u $push0=, $0, 5{{$}}
68; SIMD128: return $pop0{{$}}
69define i32 @extract_v8i16_u(<8 x i16> %v) {
70 %elem = extractelement <8 x i16> %v, i16 5
71 %a = zext i16 %elem to i32
72 ret i32 %a
73}
74
75; CHECK-LABEL: extract_v8i16:{{$}}
76; NO-SIMD128-NOT: i16x8
77; SIMD128: .param v128{{$}}
78; SIMD128: .result i32{{$}}
79; SIMD128: i16x8.extract_lane_u $push0=, $0, 5{{$}}
80; SIMD128: return $pop0{{$}}
81define i16 @extract_v8i16(<8 x i16> %v) {
82 %elem = extractelement <8 x i16> %v, i16 5
83 ret i16 %elem
84}
85
86; ==============================================================================
87; 4 x i32
88; ==============================================================================
89; CHECK-LABEL: extract_v4i32:{{$}}
90; NO-SIMD128-NOT: i32x4
91; SIMD128: .param v128{{$}}
92; SIMD128: .result i32{{$}}
93; SIMD128: i32x4.extract_lane $push0=, $0, 3{{$}}
94; SIMD128: return $pop0{{$}}
95define i32 @extract_v4i32(<4 x i32> %v) {
96 %elem = extractelement <4 x i32> %v, i32 3
97 ret i32 %elem
98}
99
100; ==============================================================================
101; 2 x i64
102; ==============================================================================
103; CHECK-LABEL: extract_v2i64:{{$}}
104; NO-SIMD128-NOT: i64x2
105; SIMD128-VM-NOT: i64x2
106; SIMD128: .param v128{{$}}
107; SIMD128: .result i64{{$}}
108; SIMD128: i64x2.extract_lane $push0=, $0, 1{{$}}
109; SIMD128: return $pop0{{$}}
110define i64 @extract_v2i64(<2 x i64> %v) {
111 %elem = extractelement <2 x i64> %v, i64 1
112 ret i64 %elem
113}
114
115; ==============================================================================
116; 4 x f32
117; ==============================================================================
118; CHECK-LABEL: extract_v4f32:{{$}}
119; NO-SIMD128-NOT: f32x4
120; SIMD128: .param v128{{$}}
121; SIMD128: .result f32{{$}}
122; SIMD128: f32x4.extract_lane $push0=, $0, 3{{$}}
123; SIMD128: return $pop0{{$}}
124define float @extract_v4f32(<4 x float> %v) {
125 %elem = extractelement <4 x float> %v, i32 3
126 ret float %elem
127}
128
129; ==============================================================================
130; 2 x f64
131; ==============================================================================
132; CHECK-LABEL: extract_v2f64:{{$}}
133; NO-SIMD128-NOT: f64x2
134; SIMD128-VM-NOT: f64x2
135; SIMD128: .param v128{{$}}
136; SIMD128: .result f64{{$}}
137; SIMD128: f64x2.extract_lane $push0=, $0, 1{{$}}
138; SIMD128: return $pop0{{$}}
139define double @extract_v2f64(<2 x double> %v) {
140 %elem = extractelement <2 x double> %v, i32 1
141 ret double %elem
142}