1  /* { dg-do run } */
       2  /* { dg-options "-O3 -mpower8-vector" } */
       3  /* { dg-require-effective-target p8vector_hw } */
       4  
       5  #define NO_WARN_X86_INTRINSICS 1
       6  #ifndef CHECK_H
       7  #define CHECK_H "mmx-check.h"
       8  #endif
       9  
      10  #ifndef TEST
      11  #define TEST mmx_test
      12  #endif
      13  
      14  #include CHECK_H
      15  
      16  #include <mmintrin.h>
      17  
      18  static __m64
      19  __attribute__((noinline, unused))
      20  test (__m64 s1, __m64 s2)
      21  {
      22    return _mm_mulhi_pi16 (s1, s2);
      23  }
      24  
      25  static void
      26  TEST (void)
      27  {
      28    __m64_union u, s1, s2;
      29    __m64_union e;
      30    int i, tmp;
      31  
      32    s1.as_m64 = _mm_set_pi16 (10, 2067, -3033, 90);
      33    s2.as_m64 = _mm_set_pi16 (11, 9834, 7444, -10222);
      34    u.as_m64 = test (s1.as_m64, s2.as_m64);
      35  
      36    e.as_m64 = _mm_set_pi16 (
      37      ((s1.as_short[3] * s2.as_short[3]) & 0xffff0000) >> 16,
      38      ((s1.as_short[2] * s2.as_short[2]) & 0xffff0000) >> 16,
      39      ((s1.as_short[1] * s2.as_short[1]) & 0xffff0000) >> 16,
      40      ((s1.as_short[0] * s2.as_short[0]) & 0xffff0000) >> 16);
      41  
      42    if (u.as_m64 != e.as_m64)
      43      abort ();
      44  }