aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/mips/msa-minmax.c
blob: 72cfdacf80bdd418d31be7a7db8ea294c67d9a2d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/* { dg-do compile } */
/* { dg-options "-mno-mips16 -mfp64 -mhard-float -mmsa" } */

typedef int v4i32 __attribute__ ((vector_size(16)));
typedef float v4f32 __attribute__ ((vector_size(16)));

/* Test MSA signed min/max immediate for correct assembly output.  */

void
min_s_msa (v4i32 *vx, v4i32 *vy)
{
  *vy = __builtin_msa_mini_s_w (*vx, -15);
}
/* { dg-final { scan-assembler "-15" } }  */

void
max_s_msa (v4i32 *vx, v4i32 *vy)
{
  *vy = __builtin_msa_maxi_s_w (*vx, -15);
}
/* { dg-final { scan-assembler "-15" } }  */

/* Test MSA min_a/max_a instructions for forward propagation optimization.  */

#define FUNC(NAME, TYPE, RETTYPE) RETTYPE NAME##_a_msa (TYPE *vx, TYPE *vy) \
{ \
  TYPE dest = __builtin_msa_##NAME##_a_w (*vx, *vy); \
  return dest[0]; \
}

FUNC(fmin, v4f32, float)
/* { dg-final { scan-assembler "fmin_a.w" } }  */
FUNC(fmax, v4f32, float)
/* { dg-final { scan-assembler "fmax_a.w" } }  */
FUNC(min, v4i32, int)
/* { dg-final { scan-assembler "min_a.w" } }  */
FUNC(max, v4i32, int)
/* { dg-final { scan-assembler "max_a.w" } }  */