32 lines
802 B
C
32 lines
802 B
C
/* { dg-do compile } */
|
|
/* { dg-options "-O -mcpu=ultrasparc -mvis" } */
|
|
typedef short vec16 __attribute__((vector_size(8)));
|
|
typedef int vec32 __attribute__((vector_size(8)));
|
|
|
|
vec16 fun16(vec16 a, vec16 b)
|
|
{
|
|
return (~a & b) + (b | a) - (a ^ b);
|
|
}
|
|
|
|
vec32 fun32(vec32 a, vec32 b)
|
|
{
|
|
return (~a & b) + (b | a) - (a ^ b);
|
|
}
|
|
|
|
/* This should be transformed into ~b & a. */
|
|
vec16 fun16b(vec16 a, vec16 b)
|
|
{
|
|
return (a & ~b) + (b | a) - (a ^ b);
|
|
}
|
|
|
|
vec32 fun32b(vec32 a, vec32 b)
|
|
{
|
|
return (a & ~b) + (b | a) - (a ^ b);
|
|
}
|
|
|
|
/* { dg-final { scan-assembler-times "fandnot1\t%" 4 } } */
|
|
/* { dg-final { scan-assembler-times "for\t%" 4 } } */
|
|
/* { dg-final { scan-assembler-times "fpadd" 4 } } */
|
|
/* { dg-final { scan-assembler-times "fxor\t%" 4 } } */
|
|
/* { dg-final { scan-assembler-times "fpsub" 4 } } */
|