blob: 30a2d8bd08b437d2f9bc9a27fb0ac2ca00e41c49 [file] [log] [blame]
/* { dg-do run } */
/* { dg-options "-O2 -fno-strict-aliasing -msse2" } */
/* { dg-additional-options "-mno-mmx" { target { ! ia32 } } } */
#include "sse2-check.h"
#include "mmx-vals.h"
__attribute__((noinline, noclone))
static void
test_psrawi (long long *ll1, unsigned int imm, long long *r)
{
__m64 t1 = *(__m64 *) ll1;
switch (imm)
{
case 0:
*(__m64 *) r = _m_psrawi (t1, 0);
break;
case 1:
*(__m64 *) r = _m_psrawi (t1, 1);
break;
case 2:
*(__m64 *) r = _m_psrawi (t1, 2);
break;
case 3:
*(__m64 *) r = _m_psrawi (t1, 3);
break;
case 4:
*(__m64 *) r = _m_psrawi (t1, 4);
break;
case 5:
*(__m64 *) r = _m_psrawi (t1, 5);
break;
case 6:
*(__m64 *) r = _m_psrawi (t1, 6);
break;
case 7:
*(__m64 *) r = _m_psrawi (t1, 7);
break;
case 8:
*(__m64 *) r = _m_psrawi (t1, 8);
break;
case 9:
*(__m64 *) r = _m_psrawi (t1, 9);
break;
case 10:
*(__m64 *) r = _m_psrawi (t1, 10);
break;
case 11:
*(__m64 *) r = _m_psrawi (t1, 11);
break;
case 12:
*(__m64 *) r = _m_psrawi (t1, 12);
break;
case 13:
*(__m64 *) r = _m_psrawi (t1, 13);
break;
case 14:
*(__m64 *) r = _m_psrawi (t1, 14);
break;
case 15:
*(__m64 *) r = _m_psrawi (t1, 15);
break;
default:
*(__m64 *) r = _m_psrawi (t1, 16);
break;
}
}
/* Routine to manually compute the results */
static void
compute_correct_result (long long *src_p, unsigned int imm,
long long *res_p)
{
short *src = (short *) src_p;
short *res = (short *) res_p;
int i;
if (imm > 15)
for (i = 0; i < 4; i++)
res[i] = src[i] < 0 ? -1 : 0;
else
for (i = 0; i < 4; i++)
res[i] = src[i] >> imm;
}
static void
sse2_test (void)
{
int i;
unsigned int count;
long long r, ck;
int fail = 0;
/* Run the MMX tests */
for (i = 0; i < MMX_num_ops; i++)
{
count = MMXops[i];
test_psrawi (&MMXops[i], count, &r);
compute_correct_result (&MMXops[i], count, &ck);
if (ck != r)
fail++;
}
if (fail != 0)
abort ();
}