Skip to main content

core/stdarch/crates/core_arch/src/loongarch64/lsx/
portable.rs

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