1use super::super::{simd as ls, simd::*, *};
4use crate::core_arch::simd::{self as cs, *};
5use crate::intrinsics::simd as is;
6use crate::mem::transmute;
7
8#[inline(always)]
9#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
10const unsafe fn simd_pickev_b<T: Copy>(a: T, b: T) -> T {
11 simd_shuffle!(b, a, [0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30])
12}
13
14#[inline(always)]
15#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
16const unsafe fn simd_pickev_h<T: Copy>(a: T, b: T) -> T {
17 simd_shuffle!(b, a, [0, 2, 4, 6, 8, 10, 12, 14])
18}
19
20#[inline(always)]
21#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
22const unsafe fn simd_pickev_w<T: Copy>(a: T, b: T) -> T {
23 simd_shuffle!(b, a, [0, 2, 4, 6])
24}
25
26#[inline(always)]
27#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
28const unsafe fn simd_pickev_d<T: Copy>(a: T, b: T) -> T {
29 simd_shuffle!(b, a, [0, 2])
30}
31
32#[inline(always)]
33#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
34const unsafe fn simd_pickod_b<T: Copy>(a: T, b: T) -> T {
35 simd_shuffle!(b, a, [1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23, 25, 27, 29, 31])
36}
37
38#[inline(always)]
39#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
40const unsafe fn simd_pickod_h<T: Copy>(a: T, b: T) -> T {
41 simd_shuffle!(b, a, [1, 3, 5, 7, 9, 11, 13, 15])
42}
43
44#[inline(always)]
45#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
46const unsafe fn simd_pickod_w<T: Copy>(a: T, b: T) -> T {
47 simd_shuffle!(b, a, [1, 3, 5, 7])
48}
49
50#[inline(always)]
51#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
52const unsafe fn simd_pickod_d<T: Copy>(a: T, b: T) -> T {
53 simd_shuffle!(b, a, [1, 3])
54}
55
56#[inline(always)]
57#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
58pub(crate) const unsafe fn simd_ilvh_b<T: Copy>(a: T, b: T) -> T {
59 simd_shuffle!(b, a, [8, 24, 9, 25, 10, 26, 11, 27, 12, 28, 13, 29, 14, 30, 15, 31])
60}
61
62#[inline(always)]
63#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
64pub(crate) const unsafe fn simd_ilvh_h<T: Copy>(a: T, b: T) -> T {
65 simd_shuffle!(b, a, [4, 12, 5, 13, 6, 14, 7, 15])
66}
67
68#[inline(always)]
69#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
70pub(crate) const unsafe fn simd_ilvh_w<T: Copy>(a: T, b: T) -> T {
71 simd_shuffle!(b, a, [2, 6, 3, 7])
72}
73
74#[inline(always)]
75#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
76pub(crate) const unsafe fn simd_ilvh_d<T: Copy>(a: T, b: T) -> T {
77 simd_shuffle!(b, a, [1, 3])
78}
79
80#[inline(always)]
81#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
82pub(crate) const unsafe fn simd_ilvl_b<T: Copy>(a: T, b: T) -> T {
83 simd_shuffle!(b, a, [0, 16, 1, 17, 2, 18, 3, 19, 4, 20, 5, 21, 6, 22, 7, 23])
84}
85
86#[inline(always)]
87#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
88pub(crate) const unsafe fn simd_ilvl_h<T: Copy>(a: T, b: T) -> T {
89 simd_shuffle!(b, a, [0, 8, 1, 9, 2, 10, 3, 11])
90}
91
92#[inline(always)]
93#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
94pub(crate) const unsafe fn simd_ilvl_w<T: Copy>(a: T, b: T) -> T {
95 simd_shuffle!(b, a, [0, 4, 1, 5])
96}
97
98#[inline(always)]
99#[rustc_const_unstable(feature = "stdarch_const_helpers", issue = "none")]
100pub(crate) const unsafe fn simd_ilvl_d<T: Copy>(a: T, b: T) -> T {
101 simd_shuffle!(b, a, [0, 2])
102}
103
104impl_vv!("lsx", lsx_vpcnt_b, is::simd_ctpop, m128i, i8x16);
105impl_vv!("lsx", lsx_vpcnt_h, is::simd_ctpop, m128i, i16x8);
106impl_vv!("lsx", lsx_vpcnt_w, is::simd_ctpop, m128i, i32x4);
107impl_vv!("lsx", lsx_vpcnt_d, is::simd_ctpop, m128i, i64x2);
108impl_vv!("lsx", lsx_vclz_b, is::simd_ctlz, m128i, i8x16);
109impl_vv!("lsx", lsx_vclz_h, is::simd_ctlz, m128i, i16x8);
110impl_vv!("lsx", lsx_vclz_w, is::simd_ctlz, m128i, i32x4);
111impl_vv!("lsx", lsx_vclz_d, is::simd_ctlz, m128i, i64x2);
112impl_vv!("lsx", lsx_vneg_b, is::simd_neg, m128i, i8x16);
113impl_vv!("lsx", lsx_vneg_h, is::simd_neg, m128i, i16x8);
114impl_vv!("lsx", lsx_vneg_w, is::simd_neg, m128i, i32x4);
115impl_vv!("lsx", lsx_vneg_d, is::simd_neg, m128i, i64x2);
116impl_vv!("lsx", lsx_vfsqrt_s, is::simd_fsqrt, m128, f32x4);
117impl_vv!("lsx", lsx_vfsqrt_d, is::simd_fsqrt, m128d, f64x2);
118
119impl_gv!("lsx", lsx_vreplgr2vr_b, ls::simd_splat, m128i, i8x16, i32);
120impl_gv!("lsx", lsx_vreplgr2vr_h, ls::simd_splat, m128i, i16x8, i32);
121impl_gv!("lsx", lsx_vreplgr2vr_w, ls::simd_splat, m128i, i32x4, i32);
122impl_gv!("lsx", lsx_vreplgr2vr_d, ls::simd_splat, m128i, i64x2, i64);
123
124impl_sv!("lsx", lsx_vrepli_b, ls::simd_splat, m128i, i8x16, 10);
125impl_sv!("lsx", lsx_vrepli_h, ls::simd_splat, m128i, i16x8, 10);
126impl_sv!("lsx", lsx_vrepli_w, ls::simd_splat, m128i, i32x4, 10);
127impl_sv!("lsx", lsx_vrepli_d, ls::simd_splat, m128i, i64x2, 10);
128
129impl_vvv!("lsx", lsx_vadd_b, is::simd_add, m128i, i8x16);
130impl_vvv!("lsx", lsx_vadd_h, is::simd_add, m128i, i16x8);
131impl_vvv!("lsx", lsx_vadd_w, is::simd_add, m128i, i32x4);
132impl_vvv!("lsx", lsx_vadd_d, is::simd_add, m128i, i64x2);
133impl_vvv!("lsx", lsx_vsub_b, is::simd_sub, m128i, i8x16);
134impl_vvv!("lsx", lsx_vsub_h, is::simd_sub, m128i, i16x8);
135impl_vvv!("lsx", lsx_vsub_w, is::simd_sub, m128i, i32x4);
136impl_vvv!("lsx", lsx_vsub_d, is::simd_sub, m128i, i64x2);
137impl_vvv!("lsx", lsx_vmax_b, cs::simd_imax, m128i, i8x16);
138impl_vvv!("lsx", lsx_vmax_h, cs::simd_imax, m128i, i16x8);
139impl_vvv!("lsx", lsx_vmax_w, cs::simd_imax, m128i, i32x4);
140impl_vvv!("lsx", lsx_vmax_d, cs::simd_imax, m128i, i64x2);
141impl_vvv!("lsx", lsx_vmax_bu, cs::simd_imax, m128i, u8x16);
142impl_vvv!("lsx", lsx_vmax_hu, cs::simd_imax, m128i, u16x8);
143impl_vvv!("lsx", lsx_vmax_wu, cs::simd_imax, m128i, u32x4);
144impl_vvv!("lsx", lsx_vmax_du, cs::simd_imax, m128i, u64x2);
145impl_vvv!("lsx", lsx_vmin_b, cs::simd_imin, m128i, i8x16);
146impl_vvv!("lsx", lsx_vmin_h, cs::simd_imin, m128i, i16x8);
147impl_vvv!("lsx", lsx_vmin_w, cs::simd_imin, m128i, i32x4);
148impl_vvv!("lsx", lsx_vmin_d, cs::simd_imin, m128i, i64x2);
149impl_vvv!("lsx", lsx_vmin_bu, cs::simd_imin, m128i, u8x16);
150impl_vvv!("lsx", lsx_vmin_hu, cs::simd_imin, m128i, u16x8);
151impl_vvv!("lsx", lsx_vmin_wu, cs::simd_imin, m128i, u32x4);
152impl_vvv!("lsx", lsx_vmin_du, cs::simd_imin, m128i, u64x2);
153impl_vvv!("lsx", lsx_vseq_b, is::simd_eq, m128i, i8x16);
154impl_vvv!("lsx", lsx_vseq_h, is::simd_eq, m128i, i16x8);
155impl_vvv!("lsx", lsx_vseq_w, is::simd_eq, m128i, i32x4);
156impl_vvv!("lsx", lsx_vseq_d, is::simd_eq, m128i, i64x2);
157impl_vvv!("lsx", lsx_vslt_b, is::simd_lt, m128i, i8x16);
158impl_vvv!("lsx", lsx_vslt_h, is::simd_lt, m128i, i16x8);
159impl_vvv!("lsx", lsx_vslt_w, is::simd_lt, m128i, i32x4);
160impl_vvv!("lsx", lsx_vslt_d, is::simd_lt, m128i, i64x2);
161impl_vvv!("lsx", lsx_vslt_bu, is::simd_lt, m128i, u8x16);
162impl_vvv!("lsx", lsx_vslt_hu, is::simd_lt, m128i, u16x8);
163impl_vvv!("lsx", lsx_vslt_wu, is::simd_lt, m128i, u32x4);
164impl_vvv!("lsx", lsx_vslt_du, is::simd_lt, m128i, u64x2);
165impl_vvv!("lsx", lsx_vsle_b, is::simd_le, m128i, i8x16);
166impl_vvv!("lsx", lsx_vsle_h, is::simd_le, m128i, i16x8);
167impl_vvv!("lsx", lsx_vsle_w, is::simd_le, m128i, i32x4);
168impl_vvv!("lsx", lsx_vsle_d, is::simd_le, m128i, i64x2);
169impl_vvv!("lsx", lsx_vsle_bu, is::simd_le, m128i, u8x16);
170impl_vvv!("lsx", lsx_vsle_hu, is::simd_le, m128i, u16x8);
171impl_vvv!("lsx", lsx_vsle_wu, is::simd_le, m128i, u32x4);
172impl_vvv!("lsx", lsx_vsle_du, is::simd_le, m128i, u64x2);
173impl_vvv!("lsx", lsx_vmul_b, is::simd_mul, m128i, i8x16);
174impl_vvv!("lsx", lsx_vmul_h, is::simd_mul, m128i, i16x8);
175impl_vvv!("lsx", lsx_vmul_w, is::simd_mul, m128i, i32x4);
176impl_vvv!("lsx", lsx_vmul_d, is::simd_mul, m128i, i64x2);
177impl_vvv!("lsx", lsx_vdiv_b, is::simd_div, m128i, i8x16);
178impl_vvv!("lsx", lsx_vdiv_h, is::simd_div, m128i, i16x8);
179impl_vvv!("lsx", lsx_vdiv_w, is::simd_div, m128i, i32x4);
180impl_vvv!("lsx", lsx_vdiv_d, is::simd_div, m128i, i64x2);
181impl_vvv!("lsx", lsx_vdiv_bu, is::simd_div, m128i, u8x16);
182impl_vvv!("lsx", lsx_vdiv_hu, is::simd_div, m128i, u16x8);
183impl_vvv!("lsx", lsx_vdiv_wu, is::simd_div, m128i, u32x4);
184impl_vvv!("lsx", lsx_vdiv_du, is::simd_div, m128i, u64x2);
185impl_vvv!("lsx", lsx_vmod_b, is::simd_rem, m128i, i8x16);
186impl_vvv!("lsx", lsx_vmod_h, is::simd_rem, m128i, i16x8);
187impl_vvv!("lsx", lsx_vmod_w, is::simd_rem, m128i, i32x4);
188impl_vvv!("lsx", lsx_vmod_d, is::simd_rem, m128i, i64x2);
189impl_vvv!("lsx", lsx_vmod_bu, is::simd_rem, m128i, u8x16);
190impl_vvv!("lsx", lsx_vmod_hu, is::simd_rem, m128i, u16x8);
191impl_vvv!("lsx", lsx_vmod_wu, is::simd_rem, m128i, u32x4);
192impl_vvv!("lsx", lsx_vmod_du, is::simd_rem, m128i, u64x2);
193impl_vvv!("lsx", lsx_vand_v, is::simd_and, m128i, u8x16);
194impl_vvv!("lsx", lsx_vandn_v, ls::simd_andn, m128i, u8x16);
195impl_vvv!("lsx", lsx_vor_v, is::simd_or, m128i, u8x16);
196impl_vvv!("lsx", lsx_vorn_v, ls::simd_orn, m128i, u8x16);
197impl_vvv!("lsx", lsx_vnor_v, ls::simd_nor, m128i, u8x16);
198impl_vvv!("lsx", lsx_vxor_v, is::simd_xor, m128i, u8x16);
199impl_vvv!("lsx", lsx_vfadd_s, is::simd_add, m128, f32x4);
200impl_vvv!("lsx", lsx_vfadd_d, is::simd_add, m128d, f64x2);
201impl_vvv!("lsx", lsx_vfsub_s, is::simd_sub, m128, f32x4);
202impl_vvv!("lsx", lsx_vfsub_d, is::simd_sub, m128d, f64x2);
203impl_vvv!("lsx", lsx_vfmul_s, is::simd_mul, m128, f32x4);
204impl_vvv!("lsx", lsx_vfmul_d, is::simd_mul, m128d, f64x2);
205impl_vvv!("lsx", lsx_vfdiv_s, is::simd_div, m128, f32x4);
206impl_vvv!("lsx", lsx_vfdiv_d, is::simd_div, m128d, f64x2);
207impl_vvv!("lsx", lsx_vsll_b, ls::simd_shl, m128i, i8x16);
208impl_vvv!("lsx", lsx_vsll_h, ls::simd_shl, m128i, i16x8);
209impl_vvv!("lsx", lsx_vsll_w, ls::simd_shl, m128i, i32x4);
210impl_vvv!("lsx", lsx_vsll_d, ls::simd_shl, m128i, i64x2);
211impl_vvv!("lsx", lsx_vsra_b, ls::simd_shr, m128i, i8x16);
212impl_vvv!("lsx", lsx_vsra_h, ls::simd_shr, m128i, i16x8);
213impl_vvv!("lsx", lsx_vsra_w, ls::simd_shr, m128i, i32x4);
214impl_vvv!("lsx", lsx_vsra_d, ls::simd_shr, m128i, i64x2);
215impl_vvv!("lsx", lsx_vsrl_b, ls::simd_shr, m128i, u8x16);
216impl_vvv!("lsx", lsx_vsrl_h, ls::simd_shr, m128i, u16x8);
217impl_vvv!("lsx", lsx_vsrl_w, ls::simd_shr, m128i, u32x4);
218impl_vvv!("lsx", lsx_vsrl_d, ls::simd_shr, m128i, u64x2);
219impl_vvv!("lsx", lsx_vbitclr_b, ls::simd_bitclr, m128i, u8x16);
220impl_vvv!("lsx", lsx_vbitclr_h, ls::simd_bitclr, m128i, u16x8);
221impl_vvv!("lsx", lsx_vbitclr_w, ls::simd_bitclr, m128i, u32x4);
222impl_vvv!("lsx", lsx_vbitclr_d, ls::simd_bitclr, m128i, u64x2);
223impl_vvv!("lsx", lsx_vbitset_b, ls::simd_bitset, m128i, u8x16);
224impl_vvv!("lsx", lsx_vbitset_h, ls::simd_bitset, m128i, u16x8);
225impl_vvv!("lsx", lsx_vbitset_w, ls::simd_bitset, m128i, u32x4);
226impl_vvv!("lsx", lsx_vbitset_d, ls::simd_bitset, m128i, u64x2);
227impl_vvv!("lsx", lsx_vbitrev_b, ls::simd_bitrev, m128i, u8x16);
228impl_vvv!("lsx", lsx_vbitrev_h, ls::simd_bitrev, m128i, u16x8);
229impl_vvv!("lsx", lsx_vbitrev_w, ls::simd_bitrev, m128i, u32x4);
230impl_vvv!("lsx", lsx_vbitrev_d, ls::simd_bitrev, m128i, u64x2);
231impl_vvv!("lsx", lsx_vsadd_b, is::simd_saturating_add, m128i, i8x16);
232impl_vvv!("lsx", lsx_vsadd_h, is::simd_saturating_add, m128i, i16x8);
233impl_vvv!("lsx", lsx_vsadd_w, is::simd_saturating_add, m128i, i32x4);
234impl_vvv!("lsx", lsx_vsadd_d, is::simd_saturating_add, m128i, i64x2);
235impl_vvv!("lsx", lsx_vsadd_bu, is::simd_saturating_add, m128i, u8x16);
236impl_vvv!("lsx", lsx_vsadd_hu, is::simd_saturating_add, m128i, u16x8);
237impl_vvv!("lsx", lsx_vsadd_wu, is::simd_saturating_add, m128i, u32x4);
238impl_vvv!("lsx", lsx_vsadd_du, is::simd_saturating_add, m128i, u64x2);
239impl_vvv!("lsx", lsx_vssub_b, is::simd_saturating_sub, m128i, i8x16);
240impl_vvv!("lsx", lsx_vssub_h, is::simd_saturating_sub, m128i, i16x8);
241impl_vvv!("lsx", lsx_vssub_w, is::simd_saturating_sub, m128i, i32x4);
242impl_vvv!("lsx", lsx_vssub_d, is::simd_saturating_sub, m128i, i64x2);
243impl_vvv!("lsx", lsx_vssub_bu, is::simd_saturating_sub, m128i, u8x16);
244impl_vvv!("lsx", lsx_vssub_hu, is::simd_saturating_sub, m128i, u16x8);
245impl_vvv!("lsx", lsx_vssub_wu, is::simd_saturating_sub, m128i, u32x4);
246impl_vvv!("lsx", lsx_vssub_du, is::simd_saturating_sub, m128i, u64x2);
247impl_vvv!("lsx", lsx_vadda_b, ls::simd_adda, m128i, i8x16);
248impl_vvv!("lsx", lsx_vadda_h, ls::simd_adda, m128i, i16x8);
249impl_vvv!("lsx", lsx_vadda_w, ls::simd_adda, m128i, i32x4);
250impl_vvv!("lsx", lsx_vadda_d, ls::simd_adda, m128i, i64x2);
251impl_vvv!("lsx", lsx_vabsd_b, ls::simd_absd, m128i, i8x16);
252impl_vvv!("lsx", lsx_vabsd_h, ls::simd_absd, m128i, i16x8);
253impl_vvv!("lsx", lsx_vabsd_w, ls::simd_absd, m128i, i32x4);
254impl_vvv!("lsx", lsx_vabsd_d, ls::simd_absd, m128i, i64x2);
255impl_vvv!("lsx", lsx_vabsd_bu, ls::simd_absd, m128i, u8x16);
256impl_vvv!("lsx", lsx_vabsd_hu, ls::simd_absd, m128i, u16x8);
257impl_vvv!("lsx", lsx_vabsd_wu, ls::simd_absd, m128i, u32x4);
258impl_vvv!("lsx", lsx_vabsd_du, ls::simd_absd, m128i, u64x2);
259impl_vvv!("lsx", lsx_vpickev_b, simd_pickev_b, m128i, i8x16);
260impl_vvv!("lsx", lsx_vpickev_h, simd_pickev_h, m128i, i16x8);
261impl_vvv!("lsx", lsx_vpickev_w, simd_pickev_w, m128i, i32x4);
262impl_vvv!("lsx", lsx_vpickev_d, simd_pickev_d, m128i, i64x2);
263impl_vvv!("lsx", lsx_vpickod_b, simd_pickod_b, m128i, i8x16);
264impl_vvv!("lsx", lsx_vpickod_h, simd_pickod_h, m128i, i16x8);
265impl_vvv!("lsx", lsx_vpickod_w, simd_pickod_w, m128i, i32x4);
266impl_vvv!("lsx", lsx_vpickod_d, simd_pickod_d, m128i, i64x2);
267impl_vvv!("lsx", lsx_vilvh_b, simd_ilvh_b, m128i, i8x16);
268impl_vvv!("lsx", lsx_vilvh_h, simd_ilvh_h, m128i, i16x8);
269impl_vvv!("lsx", lsx_vilvh_w, simd_ilvh_w, m128i, i32x4);
270impl_vvv!("lsx", lsx_vilvh_d, simd_ilvh_d, m128i, i64x2);
271impl_vvv!("lsx", lsx_vilvl_b, simd_ilvl_b, m128i, i8x16);
272impl_vvv!("lsx", lsx_vilvl_h, simd_ilvl_h, m128i, i16x8);
273impl_vvv!("lsx", lsx_vilvl_w, simd_ilvl_w, m128i, i32x4);
274impl_vvv!("lsx", lsx_vilvl_d, simd_ilvl_d, m128i, i64x2);
275
276impl_vuv!("lsx", lsx_vslli_b, is::simd_shl, m128i, i8x16);
277impl_vuv!("lsx", lsx_vslli_h, is::simd_shl, m128i, i16x8);
278impl_vuv!("lsx", lsx_vslli_w, is::simd_shl, m128i, i32x4);
279impl_vuv!("lsx", lsx_vslli_d, is::simd_shl, m128i, i64x2);
280impl_vuv!("lsx", lsx_vsrai_b, is::simd_shr, m128i, i8x16);
281impl_vuv!("lsx", lsx_vsrai_h, is::simd_shr, m128i, i16x8);
282impl_vuv!("lsx", lsx_vsrai_w, is::simd_shr, m128i, i32x4);
283impl_vuv!("lsx", lsx_vsrai_d, is::simd_shr, m128i, i64x2);
284impl_vuv!("lsx", lsx_vsrli_b, is::simd_shr, m128i, u8x16);
285impl_vuv!("lsx", lsx_vsrli_h, is::simd_shr, m128i, u16x8);
286impl_vuv!("lsx", lsx_vsrli_w, is::simd_shr, m128i, u32x4);
287impl_vuv!("lsx", lsx_vsrli_d, is::simd_shr, m128i, u64x2);
288impl_vuv!("lsx", lsx_vaddi_bu, is::simd_add, m128i, u8x16, 5);
289impl_vuv!("lsx", lsx_vaddi_hu, is::simd_add, m128i, u16x8, 5);
290impl_vuv!("lsx", lsx_vaddi_wu, is::simd_add, m128i, u32x4, 5);
291impl_vuv!("lsx", lsx_vaddi_du, is::simd_add, m128i, u64x2, 5);
292impl_vuv!("lsx", lsx_vslti_bu, is::simd_lt, m128i, u8x16, 5);
293impl_vuv!("lsx", lsx_vslti_hu, is::simd_lt, m128i, u16x8, 5);
294impl_vuv!("lsx", lsx_vslti_wu, is::simd_lt, m128i, u32x4, 5);
295impl_vuv!("lsx", lsx_vslti_du, is::simd_lt, m128i, u64x2, 5);
296impl_vuv!("lsx", lsx_vslei_bu, is::simd_le, m128i, u8x16, 5);
297impl_vuv!("lsx", lsx_vslei_hu, is::simd_le, m128i, u16x8, 5);
298impl_vuv!("lsx", lsx_vslei_wu, is::simd_le, m128i, u32x4, 5);
299impl_vuv!("lsx", lsx_vslei_du, is::simd_le, m128i, u64x2, 5);
300impl_vuv!("lsx", lsx_vmaxi_bu, cs::simd_imax, m128i, u8x16, 5);
301impl_vuv!("lsx", lsx_vmaxi_hu, cs::simd_imax, m128i, u16x8, 5);
302impl_vuv!("lsx", lsx_vmaxi_wu, cs::simd_imax, m128i, u32x4, 5);
303impl_vuv!("lsx", lsx_vmaxi_du, cs::simd_imax, m128i, u64x2, 5);
304impl_vuv!("lsx", lsx_vmini_bu, cs::simd_imin, m128i, u8x16, 5);
305impl_vuv!("lsx", lsx_vmini_hu, cs::simd_imin, m128i, u16x8, 5);
306impl_vuv!("lsx", lsx_vmini_wu, cs::simd_imin, m128i, u32x4, 5);
307impl_vuv!("lsx", lsx_vmini_du, cs::simd_imin, m128i, u64x2, 5);
308
309impl_vug!("lsx", lsx_vpickve2gr_b, is::simd_extract, m128i, i8x16, i32, 4);
310impl_vug!("lsx", lsx_vpickve2gr_h, is::simd_extract, m128i, i16x8, i32, 3);
311impl_vug!("lsx", lsx_vpickve2gr_w, is::simd_extract, m128i, i32x4, i32, 2);
312impl_vug!("lsx", lsx_vpickve2gr_d, is::simd_extract, m128i, i64x2, i64, 1);
313impl_vug!("lsx", lsx_vpickve2gr_bu, is::simd_extract, m128i, u8x16, u32, 4);
314impl_vug!("lsx", lsx_vpickve2gr_hu, is::simd_extract, m128i, u16x8, u32, 3);
315impl_vug!("lsx", lsx_vpickve2gr_wu, is::simd_extract, m128i, u32x4, u32, 2);
316impl_vug!("lsx", lsx_vpickve2gr_du, is::simd_extract, m128i, u64x2, u64, 1);
317
318impl_vsv!("lsx", lsx_vseqi_b, is::simd_eq, m128i, i8x16, 5);
319impl_vsv!("lsx", lsx_vseqi_h, is::simd_eq, m128i, i16x8, 5);
320impl_vsv!("lsx", lsx_vseqi_w, is::simd_eq, m128i, i32x4, 5);
321impl_vsv!("lsx", lsx_vseqi_d, is::simd_eq, m128i, i64x2, 5);
322impl_vsv!("lsx", lsx_vslti_b, is::simd_lt, m128i, i8x16, 5);
323impl_vsv!("lsx", lsx_vslti_h, is::simd_lt, m128i, i16x8, 5);
324impl_vsv!("lsx", lsx_vslti_w, is::simd_lt, m128i, i32x4, 5);
325impl_vsv!("lsx", lsx_vslti_d, is::simd_lt, m128i, i64x2, 5);
326impl_vsv!("lsx", lsx_vslei_b, is::simd_le, m128i, i8x16, 5);
327impl_vsv!("lsx", lsx_vslei_h, is::simd_le, m128i, i16x8, 5);
328impl_vsv!("lsx", lsx_vslei_w, is::simd_le, m128i, i32x4, 5);
329impl_vsv!("lsx", lsx_vslei_d, is::simd_le, m128i, i64x2, 5);
330impl_vsv!("lsx", lsx_vmaxi_b, cs::simd_imax, m128i, i8x16, 5);
331impl_vsv!("lsx", lsx_vmaxi_h, cs::simd_imax, m128i, i16x8, 5);
332impl_vsv!("lsx", lsx_vmaxi_w, cs::simd_imax, m128i, i32x4, 5);
333impl_vsv!("lsx", lsx_vmaxi_d, cs::simd_imax, m128i, i64x2, 5);
334impl_vsv!("lsx", lsx_vmini_b, cs::simd_imin, m128i, i8x16, 5);
335impl_vsv!("lsx", lsx_vmini_h, cs::simd_imin, m128i, i16x8, 5);
336impl_vsv!("lsx", lsx_vmini_w, cs::simd_imin, m128i, i32x4, 5);
337impl_vsv!("lsx", lsx_vmini_d, cs::simd_imin, m128i, i64x2, 5);
338
339impl_vvvv!("lsx", lsx_vmadd_b, ls::simd_madd, m128i, i8x16);
340impl_vvvv!("lsx", lsx_vmadd_h, ls::simd_madd, m128i, i16x8);
341impl_vvvv!("lsx", lsx_vmadd_w, ls::simd_madd, m128i, i32x4);
342impl_vvvv!("lsx", lsx_vmadd_d, ls::simd_madd, m128i, i64x2);
343impl_vvvv!("lsx", lsx_vmsub_b, ls::simd_msub, m128i, i8x16);
344impl_vvvv!("lsx", lsx_vmsub_h, ls::simd_msub, m128i, i16x8);
345impl_vvvv!("lsx", lsx_vmsub_w, ls::simd_msub, m128i, i32x4);
346impl_vvvv!("lsx", lsx_vmsub_d, ls::simd_msub, m128i, i64x2);
347impl_vvvv!("lsx", lsx_vfmadd_s, is::simd_fma, m128, f32x4);
348impl_vvvv!("lsx", lsx_vfmadd_d, is::simd_fma, m128d, f64x2);
349impl_vvvv!("lsx", lsx_vfmsub_s, ls::simd_fmsub, m128, f32x4);
350impl_vvvv!("lsx", lsx_vfmsub_d, ls::simd_fmsub, m128d, f64x2);
351impl_vvvv!("lsx", lsx_vfnmadd_s, ls::simd_fnmadd, m128, f32x4);
352impl_vvvv!("lsx", lsx_vfnmadd_d, ls::simd_fnmadd, m128d, f64x2);
353impl_vvvv!("lsx", lsx_vfnmsub_s, ls::simd_fnmsub, m128, f32x4);
354impl_vvvv!("lsx", lsx_vfnmsub_d, ls::simd_fnmsub, m128d, f64x2);
355
356impl_vugv!("lsx", lsx_vinsgr2vr_b, is::simd_insert, m128i, i8x16, i32, 4);
357impl_vugv!("lsx", lsx_vinsgr2vr_h, is::simd_insert, m128i, i16x8, i32, 3);
358impl_vugv!("lsx", lsx_vinsgr2vr_w, is::simd_insert, m128i, i32x4, i32, 2);
359impl_vugv!("lsx", lsx_vinsgr2vr_d, is::simd_insert, m128i, i64x2, i64, 1);