2579 lines
130 KiB
Diff
2579 lines
130 KiB
Diff
|
|
From dd0b9d05c2e18dc8082931dbfe612bb1acf9e5e9 Mon Sep 17 00:00:00 2001
|
||
|
|
From: Xiaolong Chen <chenxiaolong@loongson.cn>
|
||
|
|
Date: Mon, 11 Sep 2023 18:38:46 +0800
|
||
|
|
Subject: [PATCH 085/124] LoongArch: Add tests for SX vector
|
||
|
|
vmax/vmaxi/vmin/vmini instructions.
|
||
|
|
|
||
|
|
gcc/testsuite/ChangeLog:
|
||
|
|
|
||
|
|
* gcc.target/loongarch/vector/lsx/lsx-vmax-1.c: New test.
|
||
|
|
* gcc.target/loongarch/vector/lsx/lsx-vmax-2.c: New test.
|
||
|
|
* gcc.target/loongarch/vector/lsx/lsx-vmaxi-1.c: New test.
|
||
|
|
* gcc.target/loongarch/vector/lsx/lsx-vmaxi-2.c: New test.
|
||
|
|
* gcc.target/loongarch/vector/lsx/lsx-vmin-1.c: New test.
|
||
|
|
* gcc.target/loongarch/vector/lsx/lsx-vmin-2.c: New test.
|
||
|
|
* gcc.target/loongarch/vector/lsx/lsx-vmini-1.c: New test.
|
||
|
|
* gcc.target/loongarch/vector/lsx/lsx-vmini-2.c: New test.
|
||
|
|
|
||
|
|
Signed-off-by: Peng Fan <fanpeng@loongson.cn>
|
||
|
|
Signed-off-by: ticat_fp <fanpeng@loongson.cn>
|
||
|
|
---
|
||
|
|
.../loongarch/vector/lsx/lsx-vmax-1.c | 317 +++++++++++++
|
||
|
|
.../loongarch/vector/lsx/lsx-vmax-2.c | 362 +++++++++++++++
|
||
|
|
.../loongarch/vector/lsx/lsx-vmaxi-1.c | 279 +++++++++++
|
||
|
|
.../loongarch/vector/lsx/lsx-vmaxi-2.c | 223 +++++++++
|
||
|
|
.../loongarch/vector/lsx/lsx-vmin-1.c | 434 ++++++++++++++++++
|
||
|
|
.../loongarch/vector/lsx/lsx-vmin-2.c | 344 ++++++++++++++
|
||
|
|
.../loongarch/vector/lsx/lsx-vmini-1.c | 314 +++++++++++++
|
||
|
|
.../loongarch/vector/lsx/lsx-vmini-2.c | 216 +++++++++
|
||
|
|
8 files changed, 2489 insertions(+)
|
||
|
|
create mode 100644 gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmax-1.c
|
||
|
|
create mode 100644 gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmax-2.c
|
||
|
|
create mode 100644 gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmaxi-1.c
|
||
|
|
create mode 100644 gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmaxi-2.c
|
||
|
|
create mode 100644 gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmin-1.c
|
||
|
|
create mode 100644 gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmin-2.c
|
||
|
|
create mode 100644 gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmini-1.c
|
||
|
|
create mode 100644 gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmini-2.c
|
||
|
|
|
||
|
|
diff --git a/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmax-1.c b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmax-1.c
|
||
|
|
new file mode 100644
|
||
|
|
index 000000000..b0e22f955
|
||
|
|
--- /dev/null
|
||
|
|
+++ b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmax-1.c
|
||
|
|
@@ -0,0 +1,317 @@
|
||
|
|
+/* { dg-do run } */
|
||
|
|
+/* { dg-options "-mlsx -w -fno-strict-aliasing" } */
|
||
|
|
+#include "../simd_correctness_check.h"
|
||
|
|
+#include <lsxintrin.h>
|
||
|
|
+
|
||
|
|
+int
|
||
|
|
+main ()
|
||
|
|
+{
|
||
|
|
+ __m128i __m128i_op0, __m128i_op1, __m128i_op2, __m128i_out, __m128i_result;
|
||
|
|
+ __m128 __m128_op0, __m128_op1, __m128_op2, __m128_out, __m128_result;
|
||
|
|
+ __m128d __m128d_op0, __m128d_op1, __m128d_op2, __m128d_out, __m128d_result;
|
||
|
|
+
|
||
|
|
+ int int_op0, int_op1, int_op2, int_out, int_result, i = 1, fail;
|
||
|
|
+ long int long_op0, long_op1, long_op2, lont_out, lont_result;
|
||
|
|
+ long int long_int_out, long_int_result;
|
||
|
|
+ unsigned int unsigned_int_out, unsigned_int_result;
|
||
|
|
+ unsigned long int unsigned_long_int_out, unsigned_long_int_result;
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000ffff00000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmax_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x7fff7fff7fff7fff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000000010000003f;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x7f007f007f007f00;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000010000003f;
|
||
|
|
+ __m128i_out = __lsx_vmax_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000001;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xfffff00010000fff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xfffff00010000fff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000010000f00;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000010000f01;
|
||
|
|
+ __m128i_out = __lsx_vmax_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xfffcfffcfffcfffd;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfffcfffdfffcfffd;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffff80df00000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0010100000100000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x1000100000101000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0010100000100000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x1000100000101000;
|
||
|
|
+ __m128i_out = __lsx_vmax_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0040000000ff00ff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0040000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0040000000ff00ff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0040000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000001000001;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0001000100000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000001000001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0001000100000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xb327b9363c992b2e;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xa1e7b475d925730f;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffff3c992b2e;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffff730f;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x4101010141010100;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x00000000000001ff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x4101010141010100;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x00000000000001ff;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00000000003dffc2;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00000000003dffc2;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x00000000003d0000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x00000000003d0000;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0007001400000014;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0004001000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x000000000000053a;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000700140000053a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0004001000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000034;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffff80c400000148;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffff80c1ffffe8de;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000148;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000034;
|
||
|
|
+ __m128i_out = __lsx_vmax_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmax_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0008000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x00ff000000ff0000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0008000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x00ff000000ff0000;
|
||
|
|
+ __m128i_out = __lsx_vmax_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x000a000a000a000a;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000a000a000a000a;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x000a000a000a000a;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x000a000a000a000a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000a000a000a000a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000a000a000a000a;
|
||
|
|
+ __m128i_out = __lsx_vmax_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffff0000ffff0000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000b3a6000067da;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00004e420000c26a;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xd78cfd70b5f65d76;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x5779108fdedda7e4;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000b3a6000067da;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x5779108f0000c26a;
|
||
|
|
+ __m128i_out = __lsx_vmax_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x30eb022002101b20;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x020310edc003023d;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x30eb020302101b03;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x020310d0c0030220;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x30eb022002101b20;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x020310edc003023d;
|
||
|
|
+ __m128i_out = __lsx_vmax_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xfe03fe01fe01fe01;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfe3bfa3ffe3bfb21;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x001d001d001d001d;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x001d001d001d0000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x001d001d001d001d;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x001d001d001d0000;
|
||
|
|
+ __m128i_out = __lsx_vmax_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000100000155;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffff000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000100000155;
|
||
|
|
+ __m128i_out = __lsx_vmax_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00000000051649b6;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xd2f005e44bb43416;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000003e0000003f;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x00000000051649b6;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000003e0000003f;
|
||
|
|
+ __m128i_out = __lsx_vmax_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000ebd20000714f;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x00012c8a0000a58a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000ebd20000714f;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x00012c8a0000a58a;
|
||
|
|
+ __m128i_out = __lsx_vmax_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ return 0;
|
||
|
|
+}
|
||
|
|
diff --git a/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmax-2.c b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmax-2.c
|
||
|
|
new file mode 100644
|
||
|
|
index 000000000..51a9a92e8
|
||
|
|
--- /dev/null
|
||
|
|
+++ b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmax-2.c
|
||
|
|
@@ -0,0 +1,362 @@
|
||
|
|
+/* { dg-do run } */
|
||
|
|
+/* { dg-options "-mlsx -w -fno-strict-aliasing" } */
|
||
|
|
+#include "../simd_correctness_check.h"
|
||
|
|
+#include <lsxintrin.h>
|
||
|
|
+
|
||
|
|
+int
|
||
|
|
+main ()
|
||
|
|
+{
|
||
|
|
+ __m128i __m128i_op0, __m128i_op1, __m128i_op2, __m128i_out, __m128i_result;
|
||
|
|
+ __m128 __m128_op0, __m128_op1, __m128_op2, __m128_out, __m128_result;
|
||
|
|
+ __m128d __m128d_op0, __m128d_op1, __m128d_op2, __m128d_out, __m128d_result;
|
||
|
|
+
|
||
|
|
+ int int_op0, int_op1, int_op2, int_out, int_result, i = 1, fail;
|
||
|
|
+ long int long_op0, long_op1, long_op2, lont_out, lont_result;
|
||
|
|
+ long int long_int_out, long_int_result;
|
||
|
|
+ unsigned int unsigned_int_out, unsigned_int_result;
|
||
|
|
+ unsigned long int unsigned_long_int_out, unsigned_long_int_result;
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffff80000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffff80000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00000000007f0000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x00000000007f0000;
|
||
|
|
+ __m128i_out = __lsx_vmax_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffff0000ffff0000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffff000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffff0000ffff0000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffff000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x77c0404a4000403a;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x77c03fd640003fc6;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000003a0000003a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x77c0404a4000403a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x77c03fd640003fc6;
|
||
|
|
+ __m128i_out = __lsx_vmax_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xbafebb00ffd500fe;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xbafebb00ffd500fe;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xbafebb00ffd500fe;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x52525252adadadad;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x52525252adadadad;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x5b5b5b5aa4a4a4a6;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x5b5b5b5aadadadad;
|
||
|
|
+ __m128i_out = __lsx_vmax_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xfe3bfb01fe3bfe01;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xfe03fe3ffe01fa21;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfe3bfb01fe3bfe01;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfe03fe3ffe01fa21;
|
||
|
|
+ __m128i_out = __lsx_vmax_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000f50000007500;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00007e1600007d98;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000fe00fe;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x00fe00fe00fe00fe;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000f50000fe75fe;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x00fe7efe00fe7dfe;
|
||
|
|
+ __m128i_out = __lsx_vmax_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x9c9c9c9c00000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x2002040404010420;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0101010180800101;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x2002040404010420;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x9c9c9c9c80800101;
|
||
|
|
+ __m128i_out = __lsx_vmax_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xff84fff4ff84fff4;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfffffffffffffff0;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xff84fff4ff84fff4;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xfffffffffffffff0;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xff84fff4ff84fff4;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffffffffffff0;
|
||
|
|
+ __m128i_out = __lsx_vmax_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffff0000ffff0000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffff0000ffff0000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000ffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000ffffffdfffdf;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffdf;
|
||
|
|
+ __m128i_out = __lsx_vmax_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xf001f0010101f002;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmax_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x14ccc6320076a4d2;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x685670d27e00682a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x14ccc6320076a4d2;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x685670d27e00682a;
|
||
|
|
+ __m128i_out = __lsx_vmax_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00000000000000ff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00000000000000ff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xf6548a1747e59090;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x27b169bbb8145f50;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xf6548a1747e59090;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x27b169bbb8145f50;
|
||
|
|
+ __m128i_out = __lsx_vmax_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x8000000080000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffff80ff0010ff06;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x00007f01000eff0a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffff80ff0010ff06;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x8000000080000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00007fff00007fff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000000002bfd9461;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x3ff0000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x3ff0000000007fff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000002bfd9461;
|
||
|
|
+ __m128i_out = __lsx_vmax_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xfffff0000000ad3d;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfffff000fffff000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x1000100010001000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x1000100010001000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffff00010001000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffff000fffff000;
|
||
|
|
+ __m128i_out = __lsx_vmax_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x000000000000001f;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x000000000000001f;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000000000001f;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000000000001f;
|
||
|
|
+ __m128i_out = __lsx_vmax_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000040;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000040;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000040;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000040;
|
||
|
|
+ __m128i_out = __lsx_vmax_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x00000000ffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x00000000ffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000001;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000001;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000001;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x7fffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x7fffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000001;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xa2a2a2a3a2a2a2a3;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xc605c000aedd0000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xc605c000aedd0000;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x09e8e9012fded7fd;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x479f64b03373df61;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x09e8e9012fded7fd;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x479f64b03373df61;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000005;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000005;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x52525252adadadad;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x52525252adadadad;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x52525252adadadad;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x52525252adadadad;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0808080700000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0808080808080808;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x3fff3fff3fff3fff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x3fff3fff3fff3fff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0808080808080808;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000202020200;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000100;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000202020200;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000100;
|
||
|
|
+ __m128i_out = __lsx_vmax_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ return 0;
|
||
|
|
+}
|
||
|
|
diff --git a/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmaxi-1.c b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmaxi-1.c
|
||
|
|
new file mode 100644
|
||
|
|
index 000000000..7cff1d848
|
||
|
|
--- /dev/null
|
||
|
|
+++ b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmaxi-1.c
|
||
|
|
@@ -0,0 +1,279 @@
|
||
|
|
+/* { dg-do run } */
|
||
|
|
+/* { dg-options "-mlsx -w -fno-strict-aliasing" } */
|
||
|
|
+#include "../simd_correctness_check.h"
|
||
|
|
+#include <lsxintrin.h>
|
||
|
|
+
|
||
|
|
+int
|
||
|
|
+main ()
|
||
|
|
+{
|
||
|
|
+ __m128i __m128i_op0, __m128i_op1, __m128i_op2, __m128i_out, __m128i_result;
|
||
|
|
+ __m128 __m128_op0, __m128_op1, __m128_op2, __m128_out, __m128_result;
|
||
|
|
+ __m128d __m128d_op0, __m128d_op1, __m128d_op2, __m128d_out, __m128d_result;
|
||
|
|
+
|
||
|
|
+ int int_op0, int_op1, int_op2, int_out, int_result, i = 1, fail;
|
||
|
|
+ long int long_op0, long_op1, long_op2, lont_out, lont_result;
|
||
|
|
+ long int long_int_out, long_int_result;
|
||
|
|
+ unsigned int unsigned_int_out, unsigned_int_result;
|
||
|
|
+ unsigned long int unsigned_long_int_out, unsigned_long_int_result;
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0a0a0a0a0a0a0a0a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0a0a0a0a0a0a0a0a;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_b (__m128i_op0, 10);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_b (__m128i_op0, -7);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x1000100010001000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x1000100010001000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x1000100010001000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x1000100010001000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_b (__m128i_op0, -10);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000000003be14000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000003bfb4000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_b (__m128i_op0, -5);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0b0b0b0b0b0b0b0b;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0b0b0b0b0b0b0b0b;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_b (__m128i_op0, 11);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000000007ffffffb;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0101010101010101;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x010101017f010101;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_b (__m128i_op0, 1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00000000000007f8;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00000000000007f8;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0b0b0b0b0b0b0b0b;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0b0b0b0b0b0b0b0b;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_b (__m128i_op0, 11);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000000000000000c;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000000000000c;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_b (__m128i_op0, -7);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0001000100010001;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0001000100010001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0001000100010001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0001000100010001;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_b (__m128i_op0, 0);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0606060606060606;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0606060606060606;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_b (__m128i_op0, 6);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0fffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0fffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_b (__m128i_op0, -16);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_h (__m128i_op0, -1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_h (__m128i_op0, -11);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x027c027c000027c0;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x027c027c000027c0;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_h (__m128i_op0, -6);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0002000000020000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000001fc00000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0002000000020000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000001fc00000000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_h (__m128i_op0, -7);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000fff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000fff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000fff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000fff;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_h (__m128i_op0, -14);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x000000007ff000ff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000a1ff4c;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000300037ff000ff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0003000300a10003;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_h (__m128i_op0, 3);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_h (__m128i_op0, -2);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000002;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000b000b000b000b;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000b000b000b000b;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_h (__m128i_op0, 11);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0004000400040004;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0004000400040004;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_h (__m128i_op0, 4);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xfe07e5fefefdddfe;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00020100fedd0c00;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000b0000000b;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000201000000000b;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_w (__m128i_op0, 11);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000001000001;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0001000100000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000401000001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0001000100000004;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_w (__m128i_op0, 4);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_w (__m128i_op0, -10);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x000000000000006f;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000001f0a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000000000006f;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000001f0a;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_w (__m128i_op0, -12);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x000000000000007b;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000050000007b;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000500000005;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_w (__m128i_op0, 5);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000400000004;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000400000004;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_w (__m128i_op0, 4);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x001fffff001fffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x001fffff001fffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x001fffff001fffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x001fffff001fffff;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_w (__m128i_op0, -7);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000b0000000b;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000b0000000b;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_w (__m128i_op0, 11);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000e0000000e;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000e0000000e;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_w (__m128i_op0, 14);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000020;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000900000020;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000900000009;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_w (__m128i_op0, 9);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x9c9c9c9c9c9c9c9c;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x9c9c9c9c9c9c9c9c;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000600000006;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000600000006;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_w (__m128i_op0, 6);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x7f80000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x7f80000000000007;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000700000007;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_w (__m128i_op0, 7);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000002;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000002;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_d (__m128i_op0, 2);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000007f00;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000001000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000007f00;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000001000000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_d (__m128i_op0, -4);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xfff489b693120950;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfffc45a851c40c18;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000000000000a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000000000000a;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_d (__m128i_op0, 10);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_d (__m128i_op0, -5);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x63636b6afe486741;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x41f8e880ffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x63636b6afe486741;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x41f8e880ffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_d (__m128i_op0, -2);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ return 0;
|
||
|
|
+}
|
||
|
|
diff --git a/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmaxi-2.c b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmaxi-2.c
|
||
|
|
new file mode 100644
|
||
|
|
index 000000000..b79af2228
|
||
|
|
--- /dev/null
|
||
|
|
+++ b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmaxi-2.c
|
||
|
|
@@ -0,0 +1,223 @@
|
||
|
|
+/* { dg-do run } */
|
||
|
|
+/* { dg-options "-mlsx -w -fno-strict-aliasing" } */
|
||
|
|
+#include "../simd_correctness_check.h"
|
||
|
|
+#include <lsxintrin.h>
|
||
|
|
+
|
||
|
|
+int
|
||
|
|
+main ()
|
||
|
|
+{
|
||
|
|
+ __m128i __m128i_op0, __m128i_op1, __m128i_op2, __m128i_out, __m128i_result;
|
||
|
|
+ __m128 __m128_op0, __m128_op1, __m128_op2, __m128_out, __m128_result;
|
||
|
|
+ __m128d __m128d_op0, __m128d_op1, __m128d_op2, __m128d_out, __m128d_result;
|
||
|
|
+
|
||
|
|
+ int int_op0, int_op1, int_op2, int_out, int_result, i = 1, fail;
|
||
|
|
+ long int long_op0, long_op1, long_op2, lont_out, lont_result;
|
||
|
|
+ long int long_int_out, long_int_result;
|
||
|
|
+ unsigned int unsigned_int_out, unsigned_int_result;
|
||
|
|
+ unsigned long int unsigned_long_int_out, unsigned_long_int_result;
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000020002;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000020002;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0303030303030303;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0303030303030303;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_bu (__m128i_op0, 0x3);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x1111111111111111;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x1111111111111111;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_bu (__m128i_op0, 0x11);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x1111111111111111;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x1111111111111111;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_bu (__m128i_op0, 0x11);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0a0a0a0a0a0a0a0a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0a0a0a0a0a0a0a0a;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_bu (__m128i_op0, 0xa);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0011001100110011;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_hu (__m128i_op0, 0x11);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x11000f2010000e20;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0f000d200e000c20;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x11000f2010000e20;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0f000d200e000c20;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_hu (__m128i_op0, 0xb);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x001ffff0003ffff0;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000fffefffefffef;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x001ffff0003ffff0;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000fffefffefffef;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_hu (__m128i_op0, 0x6);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0005000500050005;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0005000500050005;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_hu (__m128i_op0, 0x5);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000020000020;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000020000020;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x001d001d20000020;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x001d001d20000020;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_hu (__m128i_op0, 0x1d);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00003fff00010000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x00123fff00120012;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0012001200120012;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_hu (__m128i_op0, 0x12);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x001a001a001a001a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x001a001a001a001a;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_hu (__m128i_op0, 0x1a);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x001e001e001e001e;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x001e001e001e001e;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_hu (__m128i_op0, 0x1e);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x001d001d001d001d;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x001d001d001d001d;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_hu (__m128i_op0, 0x1d);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000800000008;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000800000008;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_wu (__m128i_op0, 0x8);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000001600000016;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000001600000016;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_wu (__m128i_op0, 0x16);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_wu (__m128i_op0, 0xf);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xfffffacdb6dbecac;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x1f5533a694f902c0;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffacdb6dbecac;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x1f5533a694f902c0;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_wu (__m128i_op0, 0xd);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x37c0001000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x37c0001000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x37c0001000000001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x37c0001000000001;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_wu (__m128i_op0, 0x1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0010001000100010;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0010001000100010;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0010001000100010;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0010001000100010;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_wu (__m128i_op0, 0x1a);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xbf8000000000ffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xcf00000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xbf8000000000ffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xcf00000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_du (__m128i_op0, 0x16);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000011;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000011;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_du (__m128i_op0, 0x11);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000000000001c;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000000000001c;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_du (__m128i_op0, 0x1c);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000000000000d;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000000000000d;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_du (__m128i_op0, 0xd);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000000000000b;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000000000000b;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_du (__m128i_op0, 0xb);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x43d3e0000013e000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x43d3e0000013e000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x43d3e0000013e000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x43d3e0000013e000;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_du (__m128i_op0, 0xf);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x000100010001007c;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0001000100010001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000100010001007c;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0001000100010001;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_du (__m128i_op0, 0x1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000000000001d;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000000000001d;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_du (__m128i_op0, 0x1d);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000000000001b;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000000000001b;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_du (__m128i_op0, 0x1b);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000004;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000004;
|
||
|
|
+ __m128i_out = __lsx_vmaxi_du (__m128i_op0, 0x4);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ return 0;
|
||
|
|
+}
|
||
|
|
diff --git a/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmin-1.c b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmin-1.c
|
||
|
|
new file mode 100644
|
||
|
|
index 000000000..b2a7a35bd
|
||
|
|
--- /dev/null
|
||
|
|
+++ b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmin-1.c
|
||
|
|
@@ -0,0 +1,434 @@
|
||
|
|
+/* { dg-do run } */
|
||
|
|
+/* { dg-options "-mlsx -w -fno-strict-aliasing" } */
|
||
|
|
+#include "../simd_correctness_check.h"
|
||
|
|
+#include <lsxintrin.h>
|
||
|
|
+
|
||
|
|
+int
|
||
|
|
+main ()
|
||
|
|
+{
|
||
|
|
+ __m128i __m128i_op0, __m128i_op1, __m128i_op2, __m128i_out, __m128i_result;
|
||
|
|
+ __m128 __m128_op0, __m128_op1, __m128_op2, __m128_out, __m128_result;
|
||
|
|
+ __m128d __m128d_op0, __m128d_op1, __m128d_op2, __m128d_out, __m128d_result;
|
||
|
|
+
|
||
|
|
+ int int_op0, int_op1, int_op2, int_out, int_result, i = 1, fail;
|
||
|
|
+ long int long_op0, long_op1, long_op2, lont_out, lont_result;
|
||
|
|
+ long int long_int_out, long_int_result;
|
||
|
|
+ unsigned int unsigned_int_out, unsigned_int_result;
|
||
|
|
+ unsigned long int unsigned_long_int_out, unsigned_long_int_result;
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000ff000000ff00;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x3fffff0000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x3fffff0000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x00ffff0000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x00ffff000000ff00;
|
||
|
|
+ __m128i_out = __lsx_vmin_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000ff91fffffff5;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffff00650001ffb0;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000001;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000067400002685;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000ff91fffffff5;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffff00650000ff85;
|
||
|
|
+ __m128i_out = __lsx_vmin_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x00000001ca02f854;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000100013fa0;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffcafff8ff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x00000000000000a0;
|
||
|
|
+ __m128i_out = __lsx_vmin_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x7f8000007f800000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x7f8000008680f1ff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xff80ffffff80ffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xff80ffff8680f1ff;
|
||
|
|
+ __m128i_out = __lsx_vmin_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xff00e400ff00e400;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xff01e41ffff0e440;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffe4ffffffe4ff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffe4fffff0e4ff;
|
||
|
|
+ __m128i_out = __lsx_vmin_b (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000100000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x00000000a16316b0;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000063636363;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x00000000a1630000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffc0ff81000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000002000000020;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000600000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffc0ff81000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000401000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000080000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000080000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x7fffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00fdffffffffff02;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xfe80000000000001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfe80ffffffffff02;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfe80ffffffffff02;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x027e0000000000ff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfe80ffffffffff02;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00000000ffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00000000ffff0000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffffffe0000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x00000000ffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffe0000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xfff0000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfff0000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xc0b4d1a5f8babad3;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xbbc8ecc5f3ced5f3;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xc0b4d1a5f8babad3;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xbbc8ecc5f3ced5f3;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xfffffffffffbfffc;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xc090380000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xfffffffffffbfffc;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xc090380000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffffffffbfffc;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xc090380000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_h (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000200000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x8493941335f5cc0c;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x625a7312befcb21e;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x8493941300000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x00000002befcb21e;
|
||
|
|
+ __m128i_out = __lsx_vmin_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmin_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000000000000000d;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000078c00000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000000000000d;
|
||
|
|
+ __m128i_out = __lsx_vmin_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x000a000a000a000a;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000a000a000a000a;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x000a000a000a000a;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x000a000a000a000a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000a000a000a000a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000a000a000a000a;
|
||
|
|
+ __m128i_out = __lsx_vmin_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xa2a2a2a3a2a2a2a3;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xc605c000aedd0000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x5d5d5d5d5d5d5d5d;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x5d5d5d5d5d5d0000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xa2a2a2a3a2a2a2a3;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xc605c000aedd0000;
|
||
|
|
+ __m128i_out = __lsx_vmin_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x000003000000d613;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x00000000c0000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x00000000c0000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x000000200000001b;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000002000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xff800000ff800000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xff800000ff800000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xff800000ff800000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xff800000ff800000;
|
||
|
|
+ __m128i_out = __lsx_vmin_w (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x000000017fff9000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000210011084;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x000000017fff9000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000210011084;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000017fff9000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000210011084;
|
||
|
|
+ __m128i_out = __lsx_vmin_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00000000017f0a82;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x5a5a5a5a5b5a5b5a;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x5a5a5a5a5b5a5b5a;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x027c027c000027c0;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x027c027c000027c0;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x027c027c000027c0;
|
||
|
|
+ __m128i_out = __lsx_vmin_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmin_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000010000000100;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x3e25c8317394dae6;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xcda585aebbb2836a;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xcda585aebbb2836a;
|
||
|
|
+ __m128i_out = __lsx_vmin_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x98147a504d145000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x377b810912c0e000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x98147a504d145000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x377b810912c0e000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x98147a504d145000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x377b810912c0e000;
|
||
|
|
+ __m128i_out = __lsx_vmin_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000005;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xfcfcfcfcfcfcfcfd;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xfcfcfcfcfcfcfcfd;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfcfcfcfcfcfcfcfd;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfcfcfcfcfcfcfcfd;
|
||
|
|
+ __m128i_out = __lsx_vmin_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00000000ffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xd3259a2984048c23;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xf9796558e39953fd;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xd3259a2984048c23;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xf9796558e39953fd;
|
||
|
|
+ __m128i_out = __lsx_vmin_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffffffffffff00ff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffff00ff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmin_d (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ return 0;
|
||
|
|
+}
|
||
|
|
diff --git a/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmin-2.c b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmin-2.c
|
||
|
|
new file mode 100644
|
||
|
|
index 000000000..c90cae75e
|
||
|
|
--- /dev/null
|
||
|
|
+++ b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmin-2.c
|
||
|
|
@@ -0,0 +1,344 @@
|
||
|
|
+/* { dg-do run } */
|
||
|
|
+/* { dg-options "-mlsx -w -fno-strict-aliasing" } */
|
||
|
|
+#include "../simd_correctness_check.h"
|
||
|
|
+#include <lsxintrin.h>
|
||
|
|
+
|
||
|
|
+int
|
||
|
|
+main ()
|
||
|
|
+{
|
||
|
|
+ __m128i __m128i_op0, __m128i_op1, __m128i_op2, __m128i_out, __m128i_result;
|
||
|
|
+ __m128 __m128_op0, __m128_op1, __m128_op2, __m128_out, __m128_result;
|
||
|
|
+ __m128d __m128d_op0, __m128d_op1, __m128d_op2, __m128d_out, __m128d_result;
|
||
|
|
+
|
||
|
|
+ int int_op0, int_op1, int_op2, int_out, int_result, i = 1, fail;
|
||
|
|
+ long int long_op0, long_op1, long_op2, lont_out, lont_result;
|
||
|
|
+ long int long_int_out, long_int_result;
|
||
|
|
+ unsigned int unsigned_int_out, unsigned_int_result;
|
||
|
|
+ unsigned long int unsigned_long_int_out, unsigned_long_int_result;
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmin_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000300000001;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000100010001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfffe0004fffe0004;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xd3259a2984048c23;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xf9796558e39953fd;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xd3259a2984048c23;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xf9796558e39953fd;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xd3259a2984048c23;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xf9796558e39953fd;
|
||
|
|
+ __m128i_out = __lsx_vmin_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xf6548a1747e59090;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x27b169bbb8145f50;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xf6548a1747e59090;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x27b169bbb8145f50;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xf6548a1747e59090;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x27b169bbb8145f50;
|
||
|
|
+ __m128i_out = __lsx_vmin_bu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x9c9c9c9c9c9c9c9c;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x9c9c9c9c63636363;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffffff00000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x9c9c9c9c00000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x2020202020202020;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x2020202020207f7f;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x000000000000003f;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x7f417f417f027e03;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000000000003f;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x2020202020207e03;
|
||
|
|
+ __m128i_out = __lsx_vmin_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00008d3200000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x09e8e9012fded7fd;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x479f64b03373df61;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x00008d3200000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0c0b0a090b0a0908;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0a09080709080706;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0c0b0a090b0a0908;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0a09080709080706;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0c0b0a090b0a0908;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0a09080709080706;
|
||
|
|
+ __m128i_out = __lsx_vmin_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xa87745dbd93e4ea1;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xaa49601e26d39860;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x5252525252525252;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x5252525252525252;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x2006454690d3de87;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x2006454690d3de87;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x2006454652525252;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x2006454652525252;
|
||
|
|
+ __m128i_out = __lsx_vmin_hu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000040100;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0001000100010000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffe000ffff2382;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000040100;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0001000100010000;
|
||
|
|
+ __m128i_out = __lsx_vmin_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x03574e3a62407e03;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000001010000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x7da9b23a624082fd;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x00000000ffff0000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x03574e3a62407e03;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000001010000;
|
||
|
|
+ __m128i_out = __lsx_vmin_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0505050505050505;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000005050000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0028280000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0028280000282800;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0028280000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000282800;
|
||
|
|
+ __m128i_out = __lsx_vmin_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xfc01fd13fc02fe0c;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfe00fd14fe01fd16;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xffffffff00000001;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0xffffff0000010000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfc01fd1300000001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfe00fd1400010000;
|
||
|
|
+ __m128i_out = __lsx_vmin_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00000001ca02f854;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000100013fa0;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x2000200020002000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x2000200020002000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000120002000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000100013fa0;
|
||
|
|
+ __m128i_out = __lsx_vmin_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000ffff00000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000014;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x000000000005003a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xcd636363cd636363;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xcd636363cd636363;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x86dd8341b164f12b;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x9611c3985b3159f5;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x86dd8341b164f12b;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x9611c3985b3159f5;
|
||
|
|
+ __m128i_out = __lsx_vmin_wu (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x3ff0000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000de0000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000001f0a;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000006f00000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000001f0a;
|
||
|
|
+ __m128i_out = __lsx_vmin_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0001000100010001;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0001000100010001;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00000fea0000fffe;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xff0cff78ff96ff14;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffff007fff810001;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000400530050ffa6;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0xff7f810100001000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x001fffc0ffffe001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xff7f810100001000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000400530050ffa6;
|
||
|
|
+ __m128i_out = __lsx_vmin_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00007efe7f7f8000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x00000000b81c8382;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000077af9450;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000077af9450;
|
||
|
|
+ __m128i_out = __lsx_vmin_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op1[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmin_du (__m128i_op0, __m128i_op1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ return 0;
|
||
|
|
+}
|
||
|
|
diff --git a/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmini-1.c b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmini-1.c
|
||
|
|
new file mode 100644
|
||
|
|
index 000000000..772d040c3
|
||
|
|
--- /dev/null
|
||
|
|
+++ b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmini-1.c
|
||
|
|
@@ -0,0 +1,314 @@
|
||
|
|
+/* { dg-do run } */
|
||
|
|
+/* { dg-options "-mlsx -w -fno-strict-aliasing" } */
|
||
|
|
+#include "../simd_correctness_check.h"
|
||
|
|
+#include <lsxintrin.h>
|
||
|
|
+
|
||
|
|
+int
|
||
|
|
+main ()
|
||
|
|
+{
|
||
|
|
+ __m128i __m128i_op0, __m128i_op1, __m128i_op2, __m128i_out, __m128i_result;
|
||
|
|
+ __m128 __m128_op0, __m128_op1, __m128_op2, __m128_out, __m128_result;
|
||
|
|
+ __m128d __m128d_op0, __m128d_op1, __m128d_op2, __m128d_out, __m128d_result;
|
||
|
|
+
|
||
|
|
+ int int_op0, int_op1, int_op2, int_out, int_result, i = 1, fail;
|
||
|
|
+ long int long_op0, long_op1, long_op2, lont_out, lont_result;
|
||
|
|
+ long int long_int_out, long_int_result;
|
||
|
|
+ unsigned int unsigned_int_out, unsigned_int_result;
|
||
|
|
+ unsigned long int unsigned_long_int_out, unsigned_long_int_result;
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfffefffefffffffc;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffefffefffffffc;
|
||
|
|
+ __m128i_out = __lsx_vmini_b (__m128i_op0, 4);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000006f00002f0a;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000958aefff895e;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfafafafafafafafa;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfafa958aeffa89fa;
|
||
|
|
+ __m128i_out = __lsx_vmini_b (__m128i_op0, -6);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmini_b (__m128i_op0, 1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00000000adadadad;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00000000adadadad;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfbfbfbfbadadadad;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfbfbfbfbadadadad;
|
||
|
|
+ __m128i_out = __lsx_vmini_b (__m128i_op0, -5);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_b (__m128i_op0, 12);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000202020200;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000100;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000202020200;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000100;
|
||
|
|
+ __m128i_out = __lsx_vmini_b (__m128i_op0, 5);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xf1f1f1f1f1f1f1f1;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xf1f1f1f1f1f1f1f1;
|
||
|
|
+ __m128i_out = __lsx_vmini_b (__m128i_op0, -15);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000f50000007500;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00007e1600007d98;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000f50000000900;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000090900000998;
|
||
|
|
+ __m128i_out = __lsx_vmini_b (__m128i_op0, 9);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x10f881a20ffd02b0;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00000000ff800000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xf1f181a2f1f1f1b0;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xf1f1f1f1f180f1f1;
|
||
|
|
+ __m128i_out = __lsx_vmini_b (__m128i_op0, -15);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfff6fff6fff6fff6;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfff6fff6fff6fff6;
|
||
|
|
+ __m128i_out = __lsx_vmini_h (__m128i_op0, -10);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x1716151416151413;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x1514131214131211;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfff3fff3fff3fff3;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfff3fff3fff3fff3;
|
||
|
|
+ __m128i_out = __lsx_vmini_h (__m128i_op0, -13);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xfefefefefefefefe;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfefefefefefefefe;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfefefefefefefefe;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfefefefefefefefe;
|
||
|
|
+ __m128i_out = __lsx_vmini_h (__m128i_op0, 2);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_h (__m128i_op0, 3);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_h (__m128i_op0, 11);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_h (__m128i_op0, 3);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffff4fffffff4;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffff4fffffff4;
|
||
|
|
+ __m128i_out = __lsx_vmini_w (__m128i_op0, -12);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_w (__m128i_op0, 1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_w (__m128i_op0, 0);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffff3fffffff3;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffff3fffffff3;
|
||
|
|
+ __m128i_out = __lsx_vmini_w (__m128i_op0, -13);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x001ffff0003ffff0;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000fffefffefffef;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x00000000ffefffef;
|
||
|
|
+ __m128i_out = __lsx_vmini_w (__m128i_op0, 0);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000800000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xff01fe0400000006;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000500000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xff01fe0400000005;
|
||
|
|
+ __m128i_out = __lsx_vmini_w (__m128i_op0, 5);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffffafffffffa;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffffafffffffa;
|
||
|
|
+ __m128i_out = __lsx_vmini_w (__m128i_op0, -6);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x6363636363636363;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000d0000000d;
|
||
|
|
+ __m128i_out = __lsx_vmini_w (__m128i_op0, 13);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x8080808080808080;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x8080808080808080;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x8080808080808080;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x8080808080808080;
|
||
|
|
+ __m128i_out = __lsx_vmini_w (__m128i_op0, 8);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x345002920f3017d6;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffff7fffffff7;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffff7fffffff7;
|
||
|
|
+ __m128i_out = __lsx_vmini_w (__m128i_op0, -9);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffff00000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffff00000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, 1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x03574e3a62407e03;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffffffffffff7;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffffffffffff7;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, -9);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x1000000010000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000100100000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffffffffffff1;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffffffffffff1;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, -15);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000034;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000006;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, 6);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000100000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000006;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, 6);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xff84fff4ff84fff4;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00a6ffceffb60052;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xff84fff4ff84fff4;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffffffffffff0;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, -16);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffffffffffff9;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffffffffffff9;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, -7);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x111110ff11111141;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x1111113111111100;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xffffffffffffffff;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, -1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x55aa55c3d5aa55c4;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xaa55556fd5aaaac1;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000000000000c;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xaa55556fd5aaaac1;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, 12);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, 12);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffffffffffff4;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffffffffffff4;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, -12);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffffffffffffb;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffffffffffffb;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, -5);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xfcfcfcdcfcfcfcdc;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfcfcfcdcfcfcfcdc;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfcfcfcdcfcfcfcdc;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfcfcfcdcfcfcfcdc;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, 3);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000001030103;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffffffffffffc;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffffffffffffc;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, -4);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x000085af0000b000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00017ea200002000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffffffffffff7;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffffffffffff7;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, -9);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xffffffffffffffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xfffffffffffffff4;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xfffffffffffffff4;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, -12);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xff00e400ff00e400;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xff01e41ffff0ffff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0xff00e400ff00e400;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0xff01e41ffff0ffff;
|
||
|
|
+ __m128i_out = __lsx_vmini_d (__m128i_op0, 14);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ return 0;
|
||
|
|
+}
|
||
|
|
diff --git a/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmini-2.c b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmini-2.c
|
||
|
|
new file mode 100644
|
||
|
|
index 000000000..6eaae2134
|
||
|
|
--- /dev/null
|
||
|
|
+++ b/gcc/testsuite/gcc.target/loongarch/vector/lsx/lsx-vmini-2.c
|
||
|
|
@@ -0,0 +1,216 @@
|
||
|
|
+/* { dg-do run } */
|
||
|
|
+/* { dg-options "-mlsx -w -fno-strict-aliasing" } */
|
||
|
|
+#include "../simd_correctness_check.h"
|
||
|
|
+#include <lsxintrin.h>
|
||
|
|
+
|
||
|
|
+int
|
||
|
|
+main ()
|
||
|
|
+{
|
||
|
|
+ __m128i __m128i_op0, __m128i_op1, __m128i_op2, __m128i_out, __m128i_result;
|
||
|
|
+ __m128 __m128_op0, __m128_op1, __m128_op2, __m128_out, __m128_result;
|
||
|
|
+ __m128d __m128d_op0, __m128d_op1, __m128d_op2, __m128d_out, __m128d_result;
|
||
|
|
+
|
||
|
|
+ int int_op0, int_op1, int_op2, int_out, int_result, i = 1, fail;
|
||
|
|
+ long int long_op0, long_op1, long_op2, lont_out, lont_result;
|
||
|
|
+ long int long_int_out, long_int_result;
|
||
|
|
+ unsigned int unsigned_int_out, unsigned_int_result;
|
||
|
|
+ unsigned long int unsigned_long_int_out, unsigned_long_int_result;
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffff0001ffff0001;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000a163000016b0;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0303000103030001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000030300000303;
|
||
|
|
+ __m128i_out = __lsx_vmini_bu (__m128i_op0, 0x3);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xd8248069ffe78077;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0d0d0d0d0d0d0d0d;
|
||
|
|
+ __m128i_out = __lsx_vmini_bu (__m128i_op0, 0xd);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x7da9b23a624082fd;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00000000ffff0000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0505050505050505;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000005050000;
|
||
|
|
+ __m128i_out = __lsx_vmini_bu (__m128i_op0, 0x5);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000001300000013;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000001300000013;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000e0000000e;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000e0000000e;
|
||
|
|
+ __m128i_out = __lsx_vmini_bu (__m128i_op0, 0xe);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_bu (__m128i_op0, 0xf);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x000001fffdfffdff;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000001fffdfffdff;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000010101010101;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000010101010101;
|
||
|
|
+ __m128i_out = __lsx_vmini_bu (__m128i_op0, 0x1);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x000000009c007c00;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000071007600;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000009000900;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000009000900;
|
||
|
|
+ __m128i_out = __lsx_vmini_bu (__m128i_op0, 0x9);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xc0b4d1a5f8babad3;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xbbc8ecc5f3ced5f3;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0303030303030303;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0303030303030303;
|
||
|
|
+ __m128i_out = __lsx_vmini_bu (__m128i_op0, 0x3);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xd3220000d3f20000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x8bff0000a7b80000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0909000009090000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0909000009090000;
|
||
|
|
+ __m128i_out = __lsx_vmini_bu (__m128i_op0, 0x9);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_hu (__m128i_op0, 0xd);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x80000000b57ec564;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x8000000083ff0be0;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0014000000140014;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0014000000140014;
|
||
|
|
+ __m128i_out = __lsx_vmini_hu (__m128i_op0, 0x14);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x1000100010001000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x1000100010001000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0013001300130013;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0013001300130013;
|
||
|
|
+ __m128i_out = __lsx_vmini_hu (__m128i_op0, 0x13);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_hu (__m128i_op0, 0x1b);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000005;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000005;
|
||
|
|
+ __m128i_out = __lsx_vmini_hu (__m128i_op0, 0x1b);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x02b010f881a281a2;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x27b169bbb8145f50;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0002000200020002;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0002000200020002;
|
||
|
|
+ __m128i_out = __lsx_vmini_hu (__m128i_op0, 0x2);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0x19);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000040004000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0010002000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0x0);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00ff00ff0000007f;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000004;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0x4);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x7ff8000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x7ff8000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000005;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000005;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0x5);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x00000003fc00ff00;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x00000001fe01fe00;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000000000000a;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000000000000a;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0xa);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x7fc000007fc00000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x7fc000007fc00000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x000000000000000b;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x000000000000000b;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0xb);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0001000101010001;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0001000100010001;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000014;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000014;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0x14);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0x18);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xfffefffefffefffe;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0xfffefffefffefffe;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000005;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000005;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0x5);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0x11);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000d3460001518a;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x000084300000e55f;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000016;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000016;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0x16);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000000;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000000;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0x3);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ *((unsigned long *)&__m128i_op0[1]) = 0xffff2356fe165486;
|
||
|
|
+ *((unsigned long *)&__m128i_op0[0]) = 0x5efeb3165bd7653d;
|
||
|
|
+ *((unsigned long *)&__m128i_result[1]) = 0x0000000000000007;
|
||
|
|
+ *((unsigned long *)&__m128i_result[0]) = 0x0000000000000007;
|
||
|
|
+ __m128i_out = __lsx_vmini_du (__m128i_op0, 0x7);
|
||
|
|
+ ASSERTEQ_64 (__LINE__, __m128i_result, __m128i_out);
|
||
|
|
+
|
||
|
|
+ return 0;
|
||
|
|
+}
|
||
|
|
--
|
||
|
|
2.33.0
|
||
|
|
|