-
- Downloads
Enable V4BFmode and V2BFmode.
Enable V4BFmode and V2BFmode with the same ABI as V4HFmode and V2HFmode. No real operation is supported for them except for movement. This should solve PR target/107261. Also I notice there's redundancy in VALID_AVX512FP16_REG_MODE, and remove V2BFmode remove it. gcc/ChangeLog: PR target/107261 * config/i386/i386-modes.def (VECTOR_MODE): Support V2BFmode. * config/i386/i386.cc (classify_argument): Handle V4BFmode and V2BFmode. (ix86_convert_const_vector_to_integer): Ditto. * config/i386/i386.h (VALID_AVX512FP16_REG_MODE): Remove V2BFmode. (VALID_SSE2_REG_MODE): Add V4BFmode and V2BFmode. (VALID_MMX_REG_MODE): Add V4BFmode. * config/i386/i386.md (mode): Add V4BF and V2BF. (MODE_SIZE): Ditto. * config/i386/mmx.md (MMXMODE) Add V4BF. (V_32): Add V2BF. (V_16_32_64): Add V4BF and V2BF. (mmxinsnmode): Add V4BF and V2BF. (*mov<mode>_internal): Hanlde V4BFmode and V2BFmode. gcc/testsuite/ChangeLog: * gcc.target/i386/pr107261.c: New test.
Showing
- gcc/config/i386/i386-modes.def 1 addition, 0 deletionsgcc/config/i386/i386-modes.def
- gcc/config/i386/i386.cc 6 additions, 0 deletionsgcc/config/i386/i386.cc
- gcc/config/i386/i386.h 4 additions, 5 deletionsgcc/config/i386/i386.h
- gcc/config/i386/i386.md 3 additions, 2 deletionsgcc/config/i386/i386.md
- gcc/config/i386/mmx.md 16 additions, 10 deletionsgcc/config/i386/mmx.md
- gcc/testsuite/gcc.target/i386/pr107261.c 38 additions, 0 deletionsgcc/testsuite/gcc.target/i386/pr107261.c
Loading
Please register or sign in to comment