re PR target/87853 (_mm_cmpgt_epi8 broken with -funsigned-char)
authorXuepeng Guo <xuepeng.guo@intel.com>
Mon, 5 Nov 2018 09:51:09 +0000 (09:51 +0000)
committerXuepeng Guo <xguo@gcc.gnu.org>
Mon, 5 Nov 2018 09:51:09 +0000 (09:51 +0000)
2018-11-05  Xuepeng Guo  <xuepeng.guo@intel.com>

PR target/87853
* config/i386/emmintrin.h (__v16qs): New to cope with option
-funsigned-char.
(_mm_cmpeq_epi8): Replace __v16qi with __v16qs.
(_mm_cmplt_epi8): Likewise.
(_mm_cmpgt_epi8): Likewise.

From-SVN: r265792

gcc/ChangeLog
gcc/config/i386/emmintrin.h

index b3a2567..f1a9d11 100644 (file)
@@ -1,3 +1,12 @@
+2018-11-05  Xuepeng Guo  <xuepeng.guo@intel.com>
+
+       PR target/87853
+       * config/i386/emmintrin.h (__v16qs): New to cope with option
+       -funsigned-char.
+       (_mm_cmpeq_epi8): Replace __v16qi with __v16qs.
+       (_mm_cmplt_epi8): Likewise.
+       (_mm_cmpgt_epi8): Likewise.
+
 2018-11-05  Richard Biener  <rguenther@suse.de>
 
        PR rtl-optimization/87852
index 7a6ff80..3c1f04b 100644 (file)
@@ -45,6 +45,7 @@ typedef unsigned int __v4su __attribute__ ((__vector_size__ (16)));
 typedef short __v8hi __attribute__ ((__vector_size__ (16)));
 typedef unsigned short __v8hu __attribute__ ((__vector_size__ (16)));
 typedef char __v16qi __attribute__ ((__vector_size__ (16)));
+typedef signed char __v16qs __attribute__ ((__vector_size__ (16)));
 typedef unsigned char __v16qu __attribute__ ((__vector_size__ (16)));
 
 /* The Intel API is flexible enough that we must allow aliasing with other
@@ -1295,7 +1296,7 @@ _mm_xor_si128 (__m128i __A, __m128i __B)
 extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
 _mm_cmpeq_epi8 (__m128i __A, __m128i __B)
 {
-  return (__m128i) ((__v16qi)__A == (__v16qi)__B);
+  return (__m128i) ((__v16qs)__A == (__v16qs)__B);
 }
 
 extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
@@ -1313,7 +1314,7 @@ _mm_cmpeq_epi32 (__m128i __A, __m128i __B)
 extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
 _mm_cmplt_epi8 (__m128i __A, __m128i __B)
 {
-  return (__m128i) ((__v16qi)__A < (__v16qi)__B);
+  return (__m128i) ((__v16qs)__A < (__v16qs)__B);
 }
 
 extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
@@ -1331,7 +1332,7 @@ _mm_cmplt_epi32 (__m128i __A, __m128i __B)
 extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
 _mm_cmpgt_epi8 (__m128i __A, __m128i __B)
 {
-  return (__m128i) ((__v16qi)__A > (__v16qi)__B);
+  return (__m128i) ((__v16qs)__A > (__v16qs)__B);
 }
 
 extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))