| /* { 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 (); |
| } |