blob: 134f41fad743f0455338b656097199642b65757f [file] [log] [blame]
Heejin Ahnc15a8782018-08-14 19:10:50 +00001; RUN: llc < %s -disable-wasm-fallthrough-return-opt -disable-wasm-explicit-locals -wasm-enable-unimplemented-simd -mattr=+simd128,+sign-ext --show-mc-encoding | FileCheck %s --check-prefixes CHECK,SIMD128
2; RUN: llc < %s -disable-wasm-fallthrough-return-opt -disable-wasm-explicit-locals -mattr=+simd128,+sign-ext --show-mc-encoding | FileCheck %s --check-prefixes CHECK,SIMD128-VM
3; RUN: llc < %s -disable-wasm-fallthrough-return-opt -disable-wasm-explicit-locals -mattr=-simd128,+sign-ext --show-mc-encoding | FileCheck %s --check-prefixes CHECK,NO-SIMD128
Heejin Ahna0fd9c32018-08-14 18:53:27 +00004
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; ==============================================================================
Heejin Ahnc15a8782018-08-14 19:10:50 +000013; CHECK-LABEL: extract_v16i8_s:
Heejin Ahna0fd9c32018-08-14 18:53:27 +000014; NO-SIMD128-NOT: i8x16
15; SIMD128: .param v128{{$}}
16; SIMD128: .result i32{{$}}
Heejin Ahnc15a8782018-08-14 19:10:50 +000017; SIMD128: i8x16.extract_lane_s $push0=, $0, 13 # encoding: [0xfd,0x09,0x0d]{{$}}
18; SIMD128: return $pop0 #
Heejin Ahna0fd9c32018-08-14 18:53:27 +000019define 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
Heejin Ahnc15a8782018-08-14 19:10:50 +000025; CHECK-LABEL: extract_v16i8_u:
Heejin Ahna0fd9c32018-08-14 18:53:27 +000026; NO-SIMD128-NOT: i8x16
27; SIMD128: .param v128{{$}}
28; SIMD128: .result i32{{$}}
Heejin Ahnc15a8782018-08-14 19:10:50 +000029; SIMD128: i8x16.extract_lane_u $push0=, $0, 13 # encoding: [0xfd,0x0a,0x0d]{{$}}
30; SIMD128: return $pop0 #
Heejin Ahna0fd9c32018-08-14 18:53:27 +000031define 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
Heejin Ahnc15a8782018-08-14 19:10:50 +000037; CHECK-LABEL: extract_v16i8:
Heejin Ahna0fd9c32018-08-14 18:53:27 +000038; NO-SIMD128-NOT: i8x16
39; SIMD128: .param v128{{$}}
40; SIMD128: .result i32{{$}}
Heejin Ahnc15a8782018-08-14 19:10:50 +000041; SIMD128: i8x16.extract_lane_u $push0=, $0, 13 # encoding: [0xfd,0x0a,0x0d]{{$}}
42; SIMD128: return $pop0 #
Heejin Ahna0fd9c32018-08-14 18:53:27 +000043define 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; ==============================================================================
Heejin Ahnc15a8782018-08-14 19:10:50 +000051; CHECK-LABEL: extract_v8i16_s:
Heejin Ahna0fd9c32018-08-14 18:53:27 +000052; NO-SIMD128-NOT: i16x8
53; SIMD128: .param v128{{$}}
54; SIMD128: .result i32{{$}}
Heejin Ahnc15a8782018-08-14 19:10:50 +000055; SIMD128: i16x8.extract_lane_s $push0=, $0, 5 # encoding: [0xfd,0x0b,0x05]{{$}}
56; SIMD128: return $pop0 #
Heejin Ahna0fd9c32018-08-14 18:53:27 +000057define 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
Heejin Ahnc15a8782018-08-14 19:10:50 +000063; CHECK-LABEL: extract_v8i16_u:
Heejin Ahna0fd9c32018-08-14 18:53:27 +000064; NO-SIMD128-NOT: i16x8
65; SIMD128: .param v128{{$}}
66; SIMD128: .result i32{{$}}
Heejin Ahnc15a8782018-08-14 19:10:50 +000067; SIMD128: i16x8.extract_lane_u $push0=, $0, 5 # encoding: [0xfd,0x0c,0x05]{{$}}
68; SIMD128: return $pop0 #
Heejin Ahna0fd9c32018-08-14 18:53:27 +000069define 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
Heejin Ahnc15a8782018-08-14 19:10:50 +000075; CHECK-LABEL: extract_v8i16:
Heejin Ahna0fd9c32018-08-14 18:53:27 +000076; NO-SIMD128-NOT: i16x8
77; SIMD128: .param v128{{$}}
78; SIMD128: .result i32{{$}}
Heejin Ahnc15a8782018-08-14 19:10:50 +000079; SIMD128: i16x8.extract_lane_u $push0=, $0, 5 # encoding: [0xfd,0x0c,0x05]{{$}}
80; SIMD128: return $pop0 #
Heejin Ahna0fd9c32018-08-14 18:53:27 +000081define 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; ==============================================================================
Heejin Ahnc15a8782018-08-14 19:10:50 +000089; CHECK-LABEL: extract_v4i32:
Heejin Ahna0fd9c32018-08-14 18:53:27 +000090; NO-SIMD128-NOT: i32x4
91; SIMD128: .param v128{{$}}
92; SIMD128: .result i32{{$}}
Heejin Ahnc15a8782018-08-14 19:10:50 +000093; SIMD128: i32x4.extract_lane $push0=, $0, 3 # encoding: [0xfd,0x0d,0x03]{{$}}
94; SIMD128: return $pop0 #
Heejin Ahna0fd9c32018-08-14 18:53:27 +000095define 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; ==============================================================================
Heejin Ahnc15a8782018-08-14 19:10:50 +0000103; CHECK-LABEL: extract_v2i64:
Heejin Ahna0fd9c32018-08-14 18:53:27 +0000104; NO-SIMD128-NOT: i64x2
105; SIMD128-VM-NOT: i64x2
106; SIMD128: .param v128{{$}}
107; SIMD128: .result i64{{$}}
Heejin Ahnc15a8782018-08-14 19:10:50 +0000108; SIMD128: i64x2.extract_lane $push0=, $0, 1 # encoding: [0xfd,0x0e,0x01]{{$}}
109; SIMD128: return $pop0 #
Heejin Ahna0fd9c32018-08-14 18:53:27 +0000110define 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; ==============================================================================
Heejin Ahnc15a8782018-08-14 19:10:50 +0000118; CHECK-LABEL: extract_v4f32:
Heejin Ahna0fd9c32018-08-14 18:53:27 +0000119; NO-SIMD128-NOT: f32x4
120; SIMD128: .param v128{{$}}
121; SIMD128: .result f32{{$}}
Heejin Ahnc15a8782018-08-14 19:10:50 +0000122; SIMD128: f32x4.extract_lane $push0=, $0, 3 # encoding: [0xfd,0x0f,0x03]{{$}}
123; SIMD128: return $pop0 #
Heejin Ahna0fd9c32018-08-14 18:53:27 +0000124define 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; ==============================================================================
Heejin Ahnc15a8782018-08-14 19:10:50 +0000132; CHECK-LABEL: extract_v2f64:
Heejin Ahna0fd9c32018-08-14 18:53:27 +0000133; NO-SIMD128-NOT: f64x2
134; SIMD128-VM-NOT: f64x2
135; SIMD128: .param v128{{$}}
136; SIMD128: .result f64{{$}}
Heejin Ahnc15a8782018-08-14 19:10:50 +0000137; SIMD128: f64x2.extract_lane $push0=, $0, 1 # encoding: [0xfd,0x10,0x01]{{$}}
138; SIMD128: return $pop0 #
Heejin Ahna0fd9c32018-08-14 18:53:27 +0000139define double @extract_v2f64(<2 x double> %v) {
140 %elem = extractelement <2 x double> %v, i32 1
141 ret double %elem
142}