RE: [PATCH] i386: Fix incorrect intrinsic signature for AVX512 s{lli|rai|rli}
> -Original Message- > From: Hu, Lin1 > Sent: Thursday, May 25, 2023 3:52 PM > To: Hongtao Liu > Cc: gcc-patches@gcc.gnu.org; Liu, Hongtao ; > ubiz...@gmail.com > Subject: RE: [PATCH] i386: Fix incorrect intrinsic signature for AVX512 > s{lli|rai|rli} > > OK, I update the change log and modify a part of format. The attached file is > the new version. LGTM. > > -Original Message- > From: Hongtao Liu > Sent: Thursday, May 25, 2023 11:40 AM > To: Hu, Lin1 > Cc: gcc-patches@gcc.gnu.org; Liu, Hongtao ; > ubiz...@gmail.com > Subject: Re: [PATCH] i386: Fix incorrect intrinsic signature for AVX512 > s{lli|rai|rli} > > On Thu, May 25, 2023 at 10:55 AM Hu, Lin1 via Gcc-patches > wrote: > > > > Hi all, > > > > This patch aims to fix incorrect intrinsic signature for > _mm{512|256|}_s{lli|rai|rli}_epi*. And it has been tested on x86_64-pc- > linux-gnu. OK for trunk? > > > > BRs, > > Lin > > > > gcc/ChangeLog: > > > > PR target/109173 > > PR target/109174 > > * config/i386/avx512bwintrin.h (_mm512_srli_epi16): Change type > from > > int to const int. > int to unsigned int or const int to const unsigned int. > Others LGTM. > > (_mm512_mask_srli_epi16): Ditto. > > (_mm512_slli_epi16): Ditto. > > (_mm512_mask_slli_epi16): Ditto. > > (_mm512_maskz_slli_epi16): Ditto. > > (_mm512_srai_epi16): Ditto. > > (_mm512_mask_srai_epi16): Ditto. > > (_mm512_maskz_srai_epi16): Ditto. > > * config/i386/avx512vlintrin.h (_mm256_mask_srli_epi32): Ditto. > > (_mm256_maskz_srli_epi32): Ditto. > > (_mm_mask_srli_epi32): Ditto. > > (_mm_maskz_srli_epi32): Ditto. > > (_mm256_mask_srli_epi64): Ditto. > > (_mm256_maskz_srli_epi64): Ditto. > > (_mm_mask_srli_epi64): Ditto. > > (_mm_maskz_srli_epi64): Ditto. > > (_mm256_mask_srai_epi32): Ditto. > > (_mm256_maskz_srai_epi32): Ditto. > > (_mm_mask_srai_epi32): Ditto. > > (_mm_maskz_srai_epi32): Ditto. > > (_mm256_srai_epi64): Ditto. > > (_mm256_mask_srai_epi64): Ditto. > > (_mm256_maskz_srai_epi64): Ditto. > > (_mm_srai_epi64): Ditto. > > (_mm_mask_srai_epi64): Ditto. > > (_mm_maskz_srai_epi64): Ditto. > > (_mm_mask_slli_epi32): Ditto. > > (_mm_maskz_slli_epi32): Ditto. > > (_mm_mask_slli_epi64): Ditto. > > (_mm_maskz_slli_epi64): Ditto. > > (_mm256_mask_slli_epi32): Ditto. > > (_mm256_maskz_slli_epi32): Ditto. > > (_mm256_mask_slli_epi64): Ditto. > > (_mm256_maskz_slli_epi64): Ditto. > > (_mm_mask_srai_epi16): Ditto. > > (_mm_maskz_srai_epi16): Ditto. > > (_mm256_srai_epi16): Ditto. > > (_mm256_mask_srai_epi16): Ditto. > > (_mm_mask_slli_epi16): Ditto. > > (_mm_maskz_slli_epi16): Ditto. > > (_mm256_mask_slli_epi16): Ditto. > > (_mm256_maskz_slli_epi16): Ditto. > > > > gcc/testsuite/ChangeLog: > > > > PR target/109173 > > PR target/109174 > > * gcc.target/i386/pr109173-1.c: New test. > > * gcc.target/i386/pr109174-1.c: Ditto. > > --- > > gcc/config/i386/avx512bwintrin.h | 32 +++--- > > gcc/config/i386/avx512fintrin.h| 58 +++ > > gcc/config/i386/avx512vlbwintrin.h | 36 --- > > gcc/config/i386/avx512vlintrin.h | 112 +++-- > > gcc/testsuite/gcc.target/i386/pr109173-1.c | 57 +++ > > gcc/testsuite/gcc.target/i386/pr109174-1.c | 45 + > > 6 files changed, 236 insertions(+), 104 deletions(-) > > create mode 100644 gcc/testsuite/gcc.target/i386/pr109173-1.c > > create mode 100644 gcc/testsuite/gcc.target/i386/pr109174-1.c > > > > diff --git a/gcc/config/i386/avx512bwintrin.h > b/gcc/config/i386/avx512bwintrin.h > > index 89790f7917b..791d4e35f32 100644 > > --- a/gcc/config/i386/avx512bwintrin.h > > +++ b/gcc/config/i386/avx512bwintrin.h > > @@ -2880,7 +2880,7 @@ _mm512_maskz_dbsad_epu8 (__mmask32 __U, > __m512i __A, __m512i __B, > > > > extern __inline __m512i > > __attribute__ ((__gnu_inline__, __always_inline__, __artificial__)) > > -_mm512_srli_epi16 (__m512i __A, const int __imm) > > +_mm512_srli_epi16 (__m512i __A, const unsigned int __imm) > > { > >return (__m512i) __builtin_ia32_psrlwi512_mask ((
RE: [PATCH] i386: Fix incorrect intrinsic signature for AVX512 s{lli|rai|rli}
OK, I update the change log and modify a part of format. The attached file is the new version. -Original Message- From: Hongtao Liu Sent: Thursday, May 25, 2023 11:40 AM To: Hu, Lin1 Cc: gcc-patches@gcc.gnu.org; Liu, Hongtao ; ubiz...@gmail.com Subject: Re: [PATCH] i386: Fix incorrect intrinsic signature for AVX512 s{lli|rai|rli} On Thu, May 25, 2023 at 10:55 AM Hu, Lin1 via Gcc-patches wrote: > > Hi all, > > This patch aims to fix incorrect intrinsic signature for > _mm{512|256|}_s{lli|rai|rli}_epi*. And it has been tested on > x86_64-pc-linux-gnu. OK for trunk? > > BRs, > Lin > > gcc/ChangeLog: > > PR target/109173 > PR target/109174 > * config/i386/avx512bwintrin.h (_mm512_srli_epi16): Change type from > int to const int. int to unsigned int or const int to const unsigned int. Others LGTM. > (_mm512_mask_srli_epi16): Ditto. > (_mm512_slli_epi16): Ditto. > (_mm512_mask_slli_epi16): Ditto. > (_mm512_maskz_slli_epi16): Ditto. > (_mm512_srai_epi16): Ditto. > (_mm512_mask_srai_epi16): Ditto. > (_mm512_maskz_srai_epi16): Ditto. > * config/i386/avx512vlintrin.h (_mm256_mask_srli_epi32): Ditto. > (_mm256_maskz_srli_epi32): Ditto. > (_mm_mask_srli_epi32): Ditto. > (_mm_maskz_srli_epi32): Ditto. > (_mm256_mask_srli_epi64): Ditto. > (_mm256_maskz_srli_epi64): Ditto. > (_mm_mask_srli_epi64): Ditto. > (_mm_maskz_srli_epi64): Ditto. > (_mm256_mask_srai_epi32): Ditto. > (_mm256_maskz_srai_epi32): Ditto. > (_mm_mask_srai_epi32): Ditto. > (_mm_maskz_srai_epi32): Ditto. > (_mm256_srai_epi64): Ditto. > (_mm256_mask_srai_epi64): Ditto. > (_mm256_maskz_srai_epi64): Ditto. > (_mm_srai_epi64): Ditto. > (_mm_mask_srai_epi64): Ditto. > (_mm_maskz_srai_epi64): Ditto. > (_mm_mask_slli_epi32): Ditto. > (_mm_maskz_slli_epi32): Ditto. > (_mm_mask_slli_epi64): Ditto. > (_mm_maskz_slli_epi64): Ditto. > (_mm256_mask_slli_epi32): Ditto. > (_mm256_maskz_slli_epi32): Ditto. > (_mm256_mask_slli_epi64): Ditto. > (_mm256_maskz_slli_epi64): Ditto. > (_mm_mask_srai_epi16): Ditto. > (_mm_maskz_srai_epi16): Ditto. > (_mm256_srai_epi16): Ditto. > (_mm256_mask_srai_epi16): Ditto. > (_mm_mask_slli_epi16): Ditto. > (_mm_maskz_slli_epi16): Ditto. > (_mm256_mask_slli_epi16): Ditto. > (_mm256_maskz_slli_epi16): Ditto. > > gcc/testsuite/ChangeLog: > > PR target/109173 > PR target/109174 > * gcc.target/i386/pr109173-1.c: New test. > * gcc.target/i386/pr109174-1.c: Ditto. > --- > gcc/config/i386/avx512bwintrin.h | 32 +++--- > gcc/config/i386/avx512fintrin.h| 58 +++ > gcc/config/i386/avx512vlbwintrin.h | 36 --- > gcc/config/i386/avx512vlintrin.h | 112 +++-- > gcc/testsuite/gcc.target/i386/pr109173-1.c | 57 +++ > gcc/testsuite/gcc.target/i386/pr109174-1.c | 45 + > 6 files changed, 236 insertions(+), 104 deletions(-) > create mode 100644 gcc/testsuite/gcc.target/i386/pr109173-1.c > create mode 100644 gcc/testsuite/gcc.target/i386/pr109174-1.c > > diff --git a/gcc/config/i386/avx512bwintrin.h > b/gcc/config/i386/avx512bwintrin.h > index 89790f7917b..791d4e35f32 100644 > --- a/gcc/config/i386/avx512bwintrin.h > +++ b/gcc/config/i386/avx512bwintrin.h > @@ -2880,7 +2880,7 @@ _mm512_maskz_dbsad_epu8 (__mmask32 __U, __m512i __A, > __m512i __B, > > extern __inline __m512i > __attribute__ ((__gnu_inline__, __always_inline__, __artificial__)) > -_mm512_srli_epi16 (__m512i __A, const int __imm) > +_mm512_srli_epi16 (__m512i __A, const unsigned int __imm) > { >return (__m512i) __builtin_ia32_psrlwi512_mask ((__v32hi) __A, __imm, > (__v32hi) > @@ -2891,7 +2891,7 @@ _mm512_srli_epi16 (__m512i __A, const int __imm) > extern __inline __m512i > __attribute__ ((__gnu_inline__, __always_inline__, __artificial__)) > _mm512_mask_srli_epi16 (__m512i __W, __mmask32 __U, __m512i __A, > - const int __imm) > + const unsigned int __imm) > { >return (__m512i) __builtin_ia32_psrlwi512_mask ((__v32hi) __A, __imm, > (__v32hi) __W, > @@ -2910,7 +2910,7 @@ _mm512_maskz_srli_epi16 (__mmask32 __U, __m512i __A, > const int __imm) > > extern __inline __m512i > __attribute__ ((__gnu_inline__, __always_inline__, __artificial__)
Re: [PATCH] i386: Fix incorrect intrinsic signature for AVX512 s{lli|rai|rli}
On Thu, May 25, 2023 at 10:55 AM Hu, Lin1 via Gcc-patches wrote: > > Hi all, > > This patch aims to fix incorrect intrinsic signature for > _mm{512|256|}_s{lli|rai|rli}_epi*. And it has been tested on > x86_64-pc-linux-gnu. OK for trunk? > > BRs, > Lin > > gcc/ChangeLog: > > PR target/109173 > PR target/109174 > * config/i386/avx512bwintrin.h (_mm512_srli_epi16): Change type from > int to const int. int to unsigned int or const int to const unsigned int. Others LGTM. > (_mm512_mask_srli_epi16): Ditto. > (_mm512_slli_epi16): Ditto. > (_mm512_mask_slli_epi16): Ditto. > (_mm512_maskz_slli_epi16): Ditto. > (_mm512_srai_epi16): Ditto. > (_mm512_mask_srai_epi16): Ditto. > (_mm512_maskz_srai_epi16): Ditto. > * config/i386/avx512vlintrin.h (_mm256_mask_srli_epi32): Ditto. > (_mm256_maskz_srli_epi32): Ditto. > (_mm_mask_srli_epi32): Ditto. > (_mm_maskz_srli_epi32): Ditto. > (_mm256_mask_srli_epi64): Ditto. > (_mm256_maskz_srli_epi64): Ditto. > (_mm_mask_srli_epi64): Ditto. > (_mm_maskz_srli_epi64): Ditto. > (_mm256_mask_srai_epi32): Ditto. > (_mm256_maskz_srai_epi32): Ditto. > (_mm_mask_srai_epi32): Ditto. > (_mm_maskz_srai_epi32): Ditto. > (_mm256_srai_epi64): Ditto. > (_mm256_mask_srai_epi64): Ditto. > (_mm256_maskz_srai_epi64): Ditto. > (_mm_srai_epi64): Ditto. > (_mm_mask_srai_epi64): Ditto. > (_mm_maskz_srai_epi64): Ditto. > (_mm_mask_slli_epi32): Ditto. > (_mm_maskz_slli_epi32): Ditto. > (_mm_mask_slli_epi64): Ditto. > (_mm_maskz_slli_epi64): Ditto. > (_mm256_mask_slli_epi32): Ditto. > (_mm256_maskz_slli_epi32): Ditto. > (_mm256_mask_slli_epi64): Ditto. > (_mm256_maskz_slli_epi64): Ditto. > (_mm_mask_srai_epi16): Ditto. > (_mm_maskz_srai_epi16): Ditto. > (_mm256_srai_epi16): Ditto. > (_mm256_mask_srai_epi16): Ditto. > (_mm_mask_slli_epi16): Ditto. > (_mm_maskz_slli_epi16): Ditto. > (_mm256_mask_slli_epi16): Ditto. > (_mm256_maskz_slli_epi16): Ditto. > > gcc/testsuite/ChangeLog: > > PR target/109173 > PR target/109174 > * gcc.target/i386/pr109173-1.c: New test. > * gcc.target/i386/pr109174-1.c: Ditto. > --- > gcc/config/i386/avx512bwintrin.h | 32 +++--- > gcc/config/i386/avx512fintrin.h| 58 +++ > gcc/config/i386/avx512vlbwintrin.h | 36 --- > gcc/config/i386/avx512vlintrin.h | 112 +++-- > gcc/testsuite/gcc.target/i386/pr109173-1.c | 57 +++ > gcc/testsuite/gcc.target/i386/pr109174-1.c | 45 + > 6 files changed, 236 insertions(+), 104 deletions(-) > create mode 100644 gcc/testsuite/gcc.target/i386/pr109173-1.c > create mode 100644 gcc/testsuite/gcc.target/i386/pr109174-1.c > > diff --git a/gcc/config/i386/avx512bwintrin.h > b/gcc/config/i386/avx512bwintrin.h > index 89790f7917b..791d4e35f32 100644 > --- a/gcc/config/i386/avx512bwintrin.h > +++ b/gcc/config/i386/avx512bwintrin.h > @@ -2880,7 +2880,7 @@ _mm512_maskz_dbsad_epu8 (__mmask32 __U, __m512i __A, > __m512i __B, > > extern __inline __m512i > __attribute__ ((__gnu_inline__, __always_inline__, __artificial__)) > -_mm512_srli_epi16 (__m512i __A, const int __imm) > +_mm512_srli_epi16 (__m512i __A, const unsigned int __imm) > { >return (__m512i) __builtin_ia32_psrlwi512_mask ((__v32hi) __A, __imm, > (__v32hi) > @@ -2891,7 +2891,7 @@ _mm512_srli_epi16 (__m512i __A, const int __imm) > extern __inline __m512i > __attribute__ ((__gnu_inline__, __always_inline__, __artificial__)) > _mm512_mask_srli_epi16 (__m512i __W, __mmask32 __U, __m512i __A, > - const int __imm) > + const unsigned int __imm) > { >return (__m512i) __builtin_ia32_psrlwi512_mask ((__v32hi) __A, __imm, > (__v32hi) __W, > @@ -2910,7 +2910,7 @@ _mm512_maskz_srli_epi16 (__mmask32 __U, __m512i __A, > const int __imm) > > extern __inline __m512i > __attribute__ ((__gnu_inline__, __always_inline__, __artificial__)) > -_mm512_slli_epi16 (__m512i __A, const int __B) > +_mm512_slli_epi16 (__m512i __A, const unsigned int __B) > { >return (__m512i) __builtin_ia32_psllwi512_mask ((__v32hi) __A, __B, > (__v32hi) > @@ -2921,7 +2921,7 @@ _mm512_slli_epi16 (__m512i __A, const int __B) > extern __inline __m512i > __attribute__ ((__gnu_inline__, __always_inline__, __artificial__)) > _mm512_mask_slli_epi16 (__m512i __W, __mmask32 __U, __m512i __A, > - const int __B) > + const unsigned int __B) > { >return (__m512i) __builtin_ia32_psllwi512_mask ((__v32hi) __A, __B, >