blob: dbb7884d6b7a878461531fd6ca52029c6465c1c2 [file] [log] [blame]
/* Verify that overloaded built-ins for vec_orc and vec_nand with short
* inputs produce the right results. These intrinsics (vec_orc,
* vec_nand) were added as part of ISA 2.07 (P8). */
/* { dg-do compile } */
/* { dg-require-effective-target powerpc_vsx_ok } */
/* { dg-options "-mvsx -O1" } */
/* { dg-additional-options "-mdejagnu-cpu=power8" { target { ! has_arch_pwr8 } } } */
#include <altivec.h>
vector signed short
test1_orc (vector bool short x, vector signed short y)
{
vector signed short *foo;
*foo += vec_orc (x, y);
return *foo;
}
vector signed short
test1_nand (vector bool short x, vector signed short y)
{
vector signed short *foo;
*foo += vec_nand (x, y);
return *foo;
}
vector signed short
test2_orc (vector signed short x, vector bool short y)
{
vector signed short *foo;
*foo += vec_orc (x, y);
return *foo;
}
vector signed short
test2_nand (vector signed short x, vector bool short y)
{
vector signed short *foo;
*foo += vec_nand (x, y);
return *foo;
}
vector signed short
test3_orc (vector signed short x, vector signed short y)
{
vector signed short *foo;
*foo += vec_orc (x, y);
return *foo;
}
vector signed short
test3_nand (vector signed short x, vector signed short y)
{
vector signed short *foo;
*foo += vec_nand (x, y);
return *foo;
}
vector unsigned short
test4_orc (vector bool short x, vector unsigned short y)
{
vector unsigned short *foo;
*foo += vec_orc (x, y);
return *foo;
}
vector unsigned short
test4_nand (vector bool short x, vector unsigned short y)
{
vector unsigned short *foo;
*foo += vec_nand (x, y);
return *foo;
}
vector unsigned short
test5_orc (vector unsigned short x, vector bool short y)
{
vector unsigned short *foo;
*foo += vec_orc (x, y);
return *foo;
}
vector unsigned short
test5_nand (vector unsigned short x, vector bool short y)
{
vector unsigned short *foo;
*foo += vec_nand (x, y);
return *foo;
}
vector unsigned short
test6_orc (vector unsigned short x, vector unsigned short y)
{
vector unsigned short *foo;
*foo += vec_orc (x, y);
return *foo;
}
vector unsigned short
test6_nand (vector unsigned short x, vector unsigned short y)
{
vector unsigned short *foo;
*foo += vec_nand (x, y);
return *foo;
}
/* { dg-final { scan-assembler-times {\mxxlnand\M} 6 } } */
/* { dg-final { scan-assembler-times {\mxxlorc\M} 6 } } */