blob: 27ef09ada801bd45f4eed92db0ac02ae4ea53dde [file] [log] [blame]
/* Verify that overloaded built-ins for vec_or, vec_xor, vec_nor with
* long long inputs produce the right results. */
/* { dg-do compile } */
/* { dg-require-effective-target powerpc_p8vector_ok } */
/* { dg-options "-mpower8-vector -O2" } */
#include <altivec.h>
vector signed long long
test1_or (vector bool long long x, vector signed long long y)
{
vector signed long long *foo;
*foo += vec_or (x, y);
return *foo;
}
vector signed long long
test1_xor (vector bool long long x, vector signed long long y)
{
vector signed long long *foo;
*foo += vec_xor (x, y);
return *foo;
}
vector signed long long
test1_nor (vector bool long long x, vector signed long long y)
{
vector signed long long *foo;
*foo += vec_nor (x, y);
return *foo;
}
vector signed long long
test2_or (vector signed long long x, vector bool long long y)
{
vector signed long long *foo;
*foo += vec_or (x, y);
return *foo;
}
vector signed long long
test2_xor (vector signed long long x, vector bool long long y)
{
vector signed long long *foo;
*foo += vec_xor (x, y);
return *foo;
}
vector signed long long
test2_nor (vector signed long long x, vector bool long long y)
{
vector signed long long *foo;
*foo += vec_nor (x, y);
return *foo;
}
vector signed long long
test3_or (vector signed long long x, vector signed long long y)
{
vector signed long long *foo;
*foo += vec_or (x, y);
return *foo;
}
vector signed long long
test3_xor (vector signed long long x, vector signed long long y)
{
vector signed long long *foo;
*foo += vec_xor (x, y);
return *foo;
}
vector signed long long
test3_nor (vector signed long long x, vector signed long long y)
{
vector signed long long *foo;
*foo += vec_nor (x, y);
return *foo;
}
vector unsigned long long
test4_or (vector bool long long x, vector unsigned long long y)
{
vector unsigned long long *foo;
*foo += vec_or (x, y);
return *foo;
}
vector unsigned long long
test4_xor (vector bool long long x, vector unsigned long long y)
{
vector unsigned long long *foo;
*foo += vec_xor (x, y);
return *foo;
}
vector unsigned long long
test4_nor (vector bool long long x, vector unsigned long long y)
{
vector unsigned long long *foo;
*foo += vec_nor (x, y);
return *foo;
}
vector unsigned long long
test5_or (vector unsigned long long x, vector bool long long y)
{
vector unsigned long long *foo;
*foo += vec_or (x, y);
return *foo;
}
vector unsigned long long
test5_xor (vector unsigned long long x, vector bool long long y)
{
vector unsigned long long *foo;
*foo += vec_xor (x, y);
return *foo;
}
vector unsigned long long
test5_nor (vector unsigned long long x, vector bool long long y)
{
vector unsigned long long *foo;
*foo += vec_nor (x, y);
return *foo;
}
vector unsigned long long
test6_or (vector unsigned long long x, vector unsigned long long y)
{
vector unsigned long long *foo;
*foo += vec_or (x, y);
return *foo;
}
vector unsigned long long
test6_xor (vector unsigned long long x, vector unsigned long long y)
{
vector unsigned long long *foo;
*foo += vec_xor (x, y);
return *foo;
}
vector unsigned long long
test6_nor (vector unsigned long long x, vector unsigned long long y)
{
vector unsigned long long *foo;
*foo += vec_nor (x, y);
return *foo;
}
// The number of xxlor instructions generated varies between 6 and 24 for
// older systems (power6,power7), as well as for 32-bit versus 64-bit targets.
// For simplicity, this test now only targets "powerpc_p8vector_ok" environments
// where the answer is expected to be 6.
/* { dg-final { scan-assembler-times {\mxxlor\M} 9 } } */
/* { dg-final { scan-assembler-times {\mxxlxor\M} 6 } } */
/* { dg-final { scan-assembler-times {\mxxlnor\M} 3 } } */