]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
LoongArch: testsuite: Rewrite {x,}vfcmp-{d,f}.c to avoid named registers
authorXi Ruoyao <xry111@xry111.site>
Tue, 5 Mar 2024 12:46:57 +0000 (20:46 +0800)
committerXi Ruoyao <xry111@xry111.site>
Wed, 6 Mar 2024 11:01:16 +0000 (19:01 +0800)
Loops on named vector register are not vectorized (see comment 11 of
PR113622), so the these test cases have been failing for a while.
Rewrite them using check-function-bodies to remove hard coding register
names.  A barrier is needed to always load the first operand before the
second operand.

gcc/testsuite/ChangeLog:

* gcc.target/loongarch/vfcmp-f.c: Rewrite to avoid named
registers.
* gcc.target/loongarch/vfcmp-d.c: Likewise.
* gcc.target/loongarch/xvfcmp-f.c: Likewise.
* gcc.target/loongarch/xvfcmp-d.c: Likewise.

gcc/testsuite/gcc.target/loongarch/vfcmp-d.c
gcc/testsuite/gcc.target/loongarch/vfcmp-f.c
gcc/testsuite/gcc.target/loongarch/xvfcmp-d.c
gcc/testsuite/gcc.target/loongarch/xvfcmp-f.c

index 8b870ef38a0e91e772d5fb0e3ebfe8ed4c00bc13..87e4ed19e96bb7640c57d2e6dc3ffee6119eef70 100644 (file)
 /* { dg-do compile } */
-/* { dg-options "-O2 -mlsx -ffixed-f0 -ffixed-f1 -ffixed-f2 -fno-vect-cost-model" } */
+/* { dg-options "-O2 -mlsx -fno-vect-cost-model" } */
+/* { dg-final { check-function-bodies "**" "" } } */
 
 #define F double
 #define I long long
 
 #include "vfcmp-f.c"
 
-/* { dg-final { scan-assembler "compare_quiet_equal:.*\tvfcmp\\.ceq\\.d\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_equal\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_not_equal:.*\tvfcmp\\.cune\\.d\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_not_equal\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_greater:.*\tvfcmp\\.slt\\.d\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_signaling_greater\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_greater_equal:.*\tvfcmp\\.sle\\.d\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_signaling_greater_equal\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_less:.*\tvfcmp\\.slt\\.d\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_signaling_less\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_less_equal:.*\tvfcmp\\.sle\\.d\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_signaling_less_equal\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_not_greater:.*\tvfcmp\\.sule\\.d\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_signaling_not_greater\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_less_unordered:.*\tvfcmp\\.sult\\.d\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_signaling_less_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_not_less:.*\tvfcmp\\.sule\\.d\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_signaling_not_less\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_greater_unordered:.*\tvfcmp\\.sult\\.d\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_signaling_greater_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_less:.*\tvfcmp\\.clt\\.d\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_less\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_less_equal:.*\tvfcmp\\.cle\\.d\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_less_equal\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_greater:.*\tvfcmp\\.clt\\.d\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_quiet_greater\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_greater_equal:.*\tvfcmp\\.cle\\.d\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_quiet_greater_equal\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_not_less:.*\tvfcmp\\.cule\\.d\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_quiet_not_less\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_greater_unordered:.*\tvfcmp\\.cult\\.d\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_quiet_greater_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_not_greater:.*\tvfcmp\\.cule\\.d\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_not_greater\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_less_unordered:.*\tvfcmp\\.cult\\.d\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_less_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_unordered:.*\tvfcmp\\.cun\\.d\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_ordered:.*\tvfcmp\\.cor\\.d\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_ordered\n" } } */
+/*
+** compare_quiet_equal:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.ceq.d     (\$vr[0-9]+),(\1,\2|\2,\1)
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_not_equal:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cune.d    (\$vr[0-9]+),(\1,\2|\2,\1)
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_greater:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.slt.d     (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_greater_equal:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.sle.d     (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_less:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.slt.d     (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_less_equal:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.sle.d     (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_not_greater:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.sule.d    (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_less_unordered:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.sult.d    (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_not_less:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.sule.d    (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_greater_unordered:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.sult.d    (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_less:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.clt.d     (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_less_equal:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cle.d     (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_greater:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.clt.d     (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_greater_equal:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cle.d     (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_not_less:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cule.d    (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_greater_unordered:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cult.d    (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_not_greater:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cule.d    (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_less_unordered:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cult.d    (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_unordered:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cun.d     (\$vr[0-9]+),(\1,\2|\2,\1)
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_ordered:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cor.d     (\$vr[0-9]+),(\1,\2|\2,\1)
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
index b9110b90cb553c6b03b47210f80051906102a7b6..8d2671998ecfa738a547cc2cbb45294fc903d253 100644 (file)
@@ -2,7 +2,8 @@
    For details read C23 Annex F.3 and LoongArch Vol. 1 section 3.2.2.1.  */
 
 /* { dg-do compile } */
-/* { dg-options "-O2 -mlsx -ffixed-f0 -ffixed-f1 -ffixed-f2 -fno-vect-cost-model" } */
+/* { dg-options "-O2 -mlsx -fno-vect-cost-model" } */
+/* { dg-final { check-function-bodies "**" "" } } */
 
 #ifndef F
 #define F float
 typedef F VF __attribute__ ((vector_size (VL)));
 typedef I VI __attribute__ ((vector_size (VL)));
 
-register VF a asm ("f0");
-register VF b asm ("f1");
-register VI c asm ("f2");
+#define ARGS const VF *a, const VF *b, VI *c
 
 void
-compare_quiet_equal (void)
+compare_quiet_equal (ARGS)
 {
-  c = (a == b);
+  VF _a = *a;
+  asm("" ::: "memory");
+  *c = (_a == *b);
 }
 
 void
-compare_quiet_not_equal (void)
+compare_quiet_not_equal (ARGS)
 {
-  c = (a != b);
+  VF _a = *a;
+  asm("" ::: "memory");
+  *c = (_a != *b);
 }
 
 void
-compare_signaling_greater (void)
+compare_signaling_greater (ARGS)
 {
-  c = (a > b);
+  VF _a = *a;
+  asm("" ::: "memory");
+  *c = (_a > *b);
 }
 
 void
-compare_signaling_greater_equal (void)
+compare_signaling_greater_equal (ARGS)
 {
-  c = (a >= b);
+  VF _a = *a;
+  asm("" ::: "memory");
+  *c = (_a >= *b);
 }
 
 void
-compare_signaling_less (void)
+compare_signaling_less (ARGS)
 {
-  c = (a < b);
+  VF _a = *a;
+  asm("" ::: "memory");
+  *c = (_a < *b);
 }
 
 void
-compare_signaling_less_equal (void)
+compare_signaling_less_equal (ARGS)
 {
-  c = (a <= b);
+  VF _a = *a;
+  asm("" ::: "memory");
+  *c = (_a <= *b);
 }
 
 void
-compare_signaling_not_greater (void)
+compare_signaling_not_greater (ARGS)
 {
-  c = ~(a > b);
+  VF _a = *a;
+  asm("" ::: "memory");
+  *c = ~(_a > *b);
 }
 
 void
-compare_signaling_less_unordered (void)
+compare_signaling_less_unordered (ARGS)
 {
-  c = ~(a >= b);
+  VF _a = *a;
+  asm("" ::: "memory");
+  *c = ~(_a >= *b);
 }
 
 void
-compare_signaling_not_less (void)
+compare_signaling_not_less (ARGS)
 {
-  c = ~(a < b);
+  VF _a = *a;
+  asm("" ::: "memory");
+  *c = ~(_a < *b);
 }
 
 void
-compare_signaling_greater_unordered (void)
+compare_signaling_greater_unordered (ARGS)
 {
-  c = ~(a <= b);
+  VF _a = *a;
+  asm("" ::: "memory");
+  *c = ~(_a <= *b);
 }
 
 void
-compare_quiet_less (void)
+compare_quiet_less (ARGS)
 {
-  for (int i = 0; i < sizeof (c) / sizeof (c[0]); i++)
-    c[i] = __builtin_isless (a[i], b[i]) ? -1 : 0;
+  VF _a = *a;
+  asm("" ::: "memory");
+  for (int i = 0; i < sizeof (*c) / sizeof ((*c)[0]); i++)
+    (*c)[i] = __builtin_isless (_a[i], (*b)[i]) ? -1 : 0;
 }
 
 void
-compare_quiet_less_equal (void)
+compare_quiet_less_equal (ARGS)
 {
-  for (int i = 0; i < sizeof (c) / sizeof (c[0]); i++)
-    c[i] = __builtin_islessequal (a[i], b[i]) ? -1 : 0;
+  VF _a = *a;
+  asm("" ::: "memory");
+  for (int i = 0; i < sizeof (*c) / sizeof ((*c)[0]); i++)
+    (*c)[i] = __builtin_islessequal (_a[i], (*b)[i]) ? -1 : 0;
 }
 
 void
-compare_quiet_greater (void)
+compare_quiet_greater (ARGS)
 {
-  for (int i = 0; i < sizeof (c) / sizeof (c[0]); i++)
-    c[i] = __builtin_isgreater (a[i], b[i]) ? -1 : 0;
+  VF _a = *a;
+  asm("" ::: "memory");
+  for (int i = 0; i < sizeof (*c) / sizeof ((*c)[0]); i++)
+    (*c)[i] = __builtin_isgreater (_a[i], (*b)[i]) ? -1 : 0;
 }
 
 void
-compare_quiet_greater_equal (void)
+compare_quiet_greater_equal (ARGS)
 {
-  for (int i = 0; i < sizeof (c) / sizeof (c[0]); i++)
-    c[i] = __builtin_isgreaterequal (a[i], b[i]) ? -1 : 0;
+  VF _a = *a;
+  asm("" ::: "memory");
+  for (int i = 0; i < sizeof (*c) / sizeof ((*c)[0]); i++)
+    (*c)[i] = __builtin_isgreaterequal (_a[i], (*b)[i]) ? -1 : 0;
 }
 
 void
-compare_quiet_not_less (void)
+compare_quiet_not_less (ARGS)
 {
-  for (int i = 0; i < sizeof (c) / sizeof (c[0]); i++)
-    c[i] = __builtin_isless (a[i], b[i]) ? 0 : -1;
+  VF _a = *a;
+  asm("" ::: "memory");
+  for (int i = 0; i < sizeof (*c) / sizeof ((*c)[0]); i++)
+    (*c)[i] = __builtin_isless (_a[i], (*b)[i]) ? 0 : -1;
 }
 
 void
-compare_quiet_greater_unordered (void)
+compare_quiet_greater_unordered (ARGS)
 {
-  for (int i = 0; i < sizeof (c) / sizeof (c[0]); i++)
-    c[i] = __builtin_islessequal (a[i], b[i]) ? 0 : -1;
+  VF _a = *a;
+  asm("" ::: "memory");
+  for (int i = 0; i < sizeof (*c) / sizeof ((*c)[0]); i++)
+    (*c)[i] = __builtin_islessequal (_a[i], (*b)[i]) ? 0 : -1;
 }
 
 void
-compare_quiet_not_greater (void)
+compare_quiet_not_greater (ARGS)
 {
-  for (int i = 0; i < sizeof (c) / sizeof (c[0]); i++)
-    c[i] = __builtin_isgreater (a[i], b[i]) ? 0 : -1;
+  VF _a = *a;
+  asm("" ::: "memory");
+  for (int i = 0; i < sizeof (*c) / sizeof ((*c)[0]); i++)
+    (*c)[i] = __builtin_isgreater (_a[i], (*b)[i]) ? 0 : -1;
 }
 
 void
-compare_quiet_less_unordered (void)
+compare_quiet_less_unordered (ARGS)
 {
-  for (int i = 0; i < sizeof (c) / sizeof (c[0]); i++)
-    c[i] = __builtin_isgreaterequal (a[i], b[i]) ? 0 : -1;
+  VF _a = *a;
+  asm("" ::: "memory");
+  for (int i = 0; i < sizeof (*c) / sizeof ((*c)[0]); i++)
+    (*c)[i] = __builtin_isgreaterequal (_a[i], (*b)[i]) ? 0 : -1;
 }
 
 void
-compare_quiet_unordered (void)
+compare_quiet_unordered (ARGS)
 {
-  for (int i = 0; i < sizeof (c) / sizeof (c[0]); i++)
-    c[i] = __builtin_isunordered (a[i], b[i]) ? -1 : 0;
+  VF _a = *a;
+  asm("" ::: "memory");
+  for (int i = 0; i < sizeof (*c) / sizeof ((*c)[0]); i++)
+    (*c)[i] = __builtin_isunordered (_a[i], (*b)[i]) ? -1 : 0;
 }
 
 void
-compare_quiet_ordered (void)
+compare_quiet_ordered (ARGS)
 {
-  for (int i = 0; i < sizeof (c) / sizeof (c[0]); i++)
-    c[i] = __builtin_isunordered (a[i], b[i]) ? 0 : -1;
+  VF _a = *a;
+  asm("" ::: "memory");
+  for (int i = 0; i < sizeof (*c) / sizeof ((*c)[0]); i++)
+    (*c)[i] = __builtin_isunordered (_a[i], (*b)[i]) ? 0 : -1;
 }
 
-/* The "-<function_name>" matches the .size directive after the function
-   body, so we can ensure the instruction is in the correct function.  */
+/*
+** compare_quiet_equal:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.ceq.s     (\$vr[0-9]+),(\1,\2|\2,\1)
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
 
-/* { dg-final { scan-assembler "compare_quiet_equal:.*\tvfcmp\\.ceq\\.s\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_equal\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_not_equal:.*\tvfcmp\\.cune\\.s\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_not_equal\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_greater:.*\tvfcmp\\.slt\\.s\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_signaling_greater\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_greater_equal:.*\tvfcmp\\.sle\\.s\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_signaling_greater_equal\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_less:.*\tvfcmp\\.slt\\.s\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_signaling_less\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_less_equal:.*\tvfcmp\\.sle\\.s\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_signaling_less_equal\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_not_greater:.*\tvfcmp\\.sule\\.s\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_signaling_not_greater\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_less_unordered:.*\tvfcmp\\.sult\\.s\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_signaling_less_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_not_less:.*\tvfcmp\\.sule\\.s\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_signaling_not_less\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_greater_unordered:.*\tvfcmp\\.sult\\.s\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_signaling_greater_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_less:.*\tvfcmp\\.clt\\.s\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_less\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_less_equal:.*\tvfcmp\\.cle\\.s\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_less_equal\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_greater:.*\tvfcmp\\.clt\\.s\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_quiet_greater\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_greater_equal:.*\tvfcmp\\.cle\\.s\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_quiet_greater_equal\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_not_less:.*\tvfcmp\\.cule\\.s\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_quiet_not_less\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_greater_unordered:.*\tvfcmp\\.cult\\.s\t\\\$vr2,\\\$vr1,\\\$vr0.*-compare_quiet_greater_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_not_greater:.*\tvfcmp\\.cule\\.s\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_not_greater\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_less_unordered:.*\tvfcmp\\.cult\\.s\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_less_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_unordered:.*\tvfcmp\\.cun\\.s\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_ordered:.*\tvfcmp\\.cor\\.s\t\\\$vr2,\\\$vr0,\\\$vr1.*-compare_quiet_ordered\n" } } */
+/*
+** compare_quiet_not_equal:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cune.s    (\$vr[0-9]+),(\1,\2|\2,\1)
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_greater:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.slt.s     (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_greater_equal:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.sle.s     (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_less:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.slt.s     (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_less_equal:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.sle.s     (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_not_greater:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.sule.s    (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_less_unordered:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.sult.s    (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_not_less:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.sule.s    (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_greater_unordered:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.sult.s    (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_less:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.clt.s     (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_less_equal:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cle.s     (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_greater:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.clt.s     (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_greater_equal:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cle.s     (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_not_less:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cule.s    (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_greater_unordered:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cult.s    (\$vr[0-9]+),\2,\1
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_not_greater:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cule.s    (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_less_unordered:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cult.s    (\$vr[0-9]+),\1,\2
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_unordered:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cun.s     (\$vr[0-9]+),(\1,\2|\2,\1)
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_ordered:
+**     vld     (\$vr[0-9]+),\$r4,0
+**     vld     (\$vr[0-9]+),\$r5,0
+**     vfcmp.cor.s     (\$vr[0-9]+),(\1,\2|\2,\1)
+**     vst     \3,\$r6,0
+**     jr      \$r1
+*/
index d8017caaa01709729d6bcd3aab1705e1a58fc540..b27efebad8ca266a949e30b712b56315ce573b32 100644 (file)
@@ -1,5 +1,6 @@
 /* { dg-do compile } */
-/* { dg-options "-O2 -mlasx -ffixed-f0 -ffixed-f1 -ffixed-f2 -fno-vect-cost-model" } */
+/* { dg-options "-O2 -mlasx -fno-vect-cost-model" } */
+/* { dg-final { check-function-bodies "**" "" } } */
 
 #define F double
 #define I long long
 
 #include "vfcmp-f.c"
 
-/* { dg-final { scan-assembler "compare_quiet_equal:.*\txvfcmp\\.ceq\\.d\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_equal\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_not_equal:.*\txvfcmp\\.cune\\.d\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_not_equal\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_greater:.*\txvfcmp\\.slt\\.d\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_signaling_greater\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_greater_equal:.*\txvfcmp\\.sle\\.d\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_signaling_greater_equal\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_less:.*\txvfcmp\\.slt\\.d\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_signaling_less\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_less_equal:.*\txvfcmp\\.sle\\.d\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_signaling_less_equal\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_not_greater:.*\txvfcmp\\.sule\\.d\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_signaling_not_greater\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_less_unordered:.*\txvfcmp\\.sult\\.d\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_signaling_less_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_not_less:.*\txvfcmp\\.sule\\.d\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_signaling_not_less\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_greater_unordered:.*\txvfcmp\\.sult\\.d\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_signaling_greater_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_less:.*\txvfcmp\\.clt\\.d\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_less\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_less_equal:.*\txvfcmp\\.cle\\.d\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_less_equal\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_greater:.*\txvfcmp\\.clt\\.d\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_quiet_greater\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_greater_equal:.*\txvfcmp\\.cle\\.d\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_quiet_greater_equal\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_not_less:.*\txvfcmp\\.cule\\.d\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_quiet_not_less\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_greater_unordered:.*\txvfcmp\\.cult\\.d\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_quiet_greater_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_not_greater:.*\txvfcmp\\.cule\\.d\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_not_greater\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_less_unordered:.*\txvfcmp\\.cult\\.d\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_less_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_unordered:.*\txvfcmp\\.cun\\.d\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_ordered:.*\txvfcmp\\.cor\\.d\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_ordered\n" } } */
+/*
+** compare_quiet_equal:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.ceq.d    (\$xr[0-9]+),(\1,\2|\2,\1)
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_not_equal:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cune.d   (\$xr[0-9]+),(\1,\2|\2,\1)
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_greater:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.slt.d    (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_greater_equal:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.sle.d    (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_less:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.slt.d    (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_less_equal:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.sle.d    (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_not_greater:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.sule.d   (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_less_unordered:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.sult.d   (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_not_less:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.sule.d   (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_greater_unordered:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.sult.d   (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_less:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.clt.d    (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_less_equal:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cle.d    (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_greater:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.clt.d    (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_greater_equal:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cle.d    (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_not_less:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cule.d   (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_greater_unordered:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cult.d   (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_not_greater:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cule.d   (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_less_unordered:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cult.d   (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_unordered:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cun.d    (\$xr[0-9]+),(\1,\2|\2,\1)
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_ordered:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cor.d    (\$xr[0-9]+),(\1,\2|\2,\1)
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
index b5455647554cdc8ee1541277a15010752ecc9818..1ca1e6c8b69314afaf5165b70278b3232a4d2bf7 100644 (file)
 /* { dg-do compile } */
-/* { dg-options "-O2 -mlasx -ffixed-f0 -ffixed-f1 -ffixed-f2" } */
+/* { dg-options "-O2 -mlasx -fno-vect-cost-model" } */
+/* { dg-final { check-function-bodies "**" "" } } */
 
+#define F float
+#define I int
 #define VL 32
 
 #include "vfcmp-f.c"
 
-/* { dg-final { scan-assembler "compare_quiet_equal:.*\txvfcmp\\.ceq\\.s\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_equal\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_not_equal:.*\txvfcmp\\.cune\\.s\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_not_equal\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_greater:.*\txvfcmp\\.slt\\.s\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_signaling_greater\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_greater_equal:.*\txvfcmp\\.sle\\.s\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_signaling_greater_equal\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_less:.*\txvfcmp\\.slt\\.s\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_signaling_less\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_less_equal:.*\txvfcmp\\.sle\\.s\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_signaling_less_equal\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_not_greater:.*\txvfcmp\\.sule\\.s\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_signaling_not_greater\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_less_unordered:.*\txvfcmp\\.sult\\.s\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_signaling_less_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_not_less:.*\txvfcmp\\.sule\\.s\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_signaling_not_less\n" } } */
-/* { dg-final { scan-assembler "compare_signaling_greater_unordered:.*\txvfcmp\\.sult\\.s\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_signaling_greater_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_less:.*\txvfcmp\\.clt\\.s\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_less\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_less_equal:.*\txvfcmp\\.cle\\.s\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_less_equal\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_greater:.*\txvfcmp\\.clt\\.s\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_quiet_greater\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_greater_equal:.*\txvfcmp\\.cle\\.s\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_quiet_greater_equal\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_not_less:.*\txvfcmp\\.cule\\.s\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_quiet_not_less\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_greater_unordered:.*\txvfcmp\\.cult\\.s\t\\\$xr2,\\\$xr1,\\\$xr0.*-compare_quiet_greater_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_not_greater:.*\txvfcmp\\.cule\\.s\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_not_greater\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_less_unordered:.*\txvfcmp\\.cult\\.s\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_less_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_unordered:.*\txvfcmp\\.cun\\.s\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_unordered\n" } } */
-/* { dg-final { scan-assembler "compare_quiet_ordered:.*\txvfcmp\\.cor\\.s\t\\\$xr2,\\\$xr0,\\\$xr1.*-compare_quiet_ordered\n" } } */
+/*
+** compare_quiet_equal:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.ceq.s    (\$xr[0-9]+),(\1,\2|\2,\1)
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_not_equal:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cune.s   (\$xr[0-9]+),(\1,\2|\2,\1)
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_greater:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.slt.s    (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_greater_equal:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.sle.s    (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_less:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.slt.s    (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_less_equal:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.sle.s    (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_not_greater:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.sule.s   (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_less_unordered:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.sult.s   (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_not_less:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.sule.s   (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_signaling_greater_unordered:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.sult.s   (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_less:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.clt.s    (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_less_equal:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cle.s    (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_greater:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.clt.s    (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_greater_equal:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cle.s    (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_not_less:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cule.s   (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_greater_unordered:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cult.s   (\$xr[0-9]+),\2,\1
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_not_greater:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cule.s   (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_less_unordered:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cult.s   (\$xr[0-9]+),\1,\2
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_unordered:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cun.s    (\$xr[0-9]+),(\1,\2|\2,\1)
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/
+
+/*
+** compare_quiet_ordered:
+**     xvld    (\$xr[0-9]+),\$r4,0
+**     xvld    (\$xr[0-9]+),\$r5,0
+**     xvfcmp.cor.s    (\$xr[0-9]+),(\1,\2|\2,\1)
+**     xvst    \3,\$r6,0
+**     jr      \$r1
+*/