Viewing file: fold-vec-minmax-longlong.c (1.4 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* Verify that overloaded built-ins for vec_min with long long inputs produce the right results. */
/* { dg-do compile } */ /* { dg-require-effective-target powerpc_p8vector_ok } */ /* { dg-options "-mpower8-vector" } */
#include <altivec.h>
vector signed long long test3_min (vector signed long long x, vector signed long long y) { return vec_min (x, y); }
vector unsigned long long test6_min (vector unsigned long long x, vector unsigned long long y) { return vec_min (x, y); }
vector signed long long test3_max (vector signed long long x, vector signed long long y) { return vec_max (x, y); }
vector unsigned long long test6_max (vector unsigned long long x, vector unsigned long long y) { return vec_max (x, y); }
vector signed long long test7_max (vector signed long long x, vector long long bool y) { return vec_max (x, y); }
vector signed long long test8_max (vector long long bool x, vector signed long long y) { return vec_max (x, y); }
vector unsigned long long test9_max (vector unsigned long long x, vector long long bool y) { return vec_max (x, y); }
vector unsigned long long test10_max (vector long long bool x, vector unsigned long long y) { return vec_max (x, y); }
/* { dg-final { scan-assembler-times "vminsd" 1 } } */ /* { dg-final { scan-assembler-times "vmaxsd" 3 } } */ /* { dg-final { scan-assembler-times "vminud" 1 } } */ /* { dg-final { scan-assembler-times "vmaxud" 3 } } */
|