This is the mail archive of the gcc-patches@gcc.gnu.org mailing list for the GCC project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Re: [PATCH][AArch64] Vectorize MULH(R)S patterns with SVE2 instructions


Yuliang Wang <Yuliang.Wang@arm.com> writes:
> Hi Richard,
>
> Thanks for your comments and advice; I have applied the relevant changes.
>
> Regards,
> Yuliang
>
>
> UPDATE:
>
> Added new tests. Built and regression tested on aarch64-none-elf and aarch64-linux-gnu.
>
> gcc/ChangeLog:
>
> 2019-09-1  Yuliang Wang  <yuliang.wang@arm.com>
>
> 	PR tree-optimization/89386
>
> 	* config/aarch64/aarch64-sve2.md (<su>mull<bt><Vwide>)
> 	(<r>shrnb<mode>, <r>shrnt<mode>): New SVE2 patterns.
> 	(<su>mulh<r>s<mode>3): New pattern for MULHRS.
> 	* config/aarch64/iterators.md (UNSPEC_SMULLB, UNSPEC_SMULLT)
> 	(UNSPEC_UMULLB, UNSPEC_UMULLT, UNSPEC_SHRNB, UNSPEC_SHRNT)
> 	(UNSPEC_RSHRNB, UNSPEC_RSHRNT, UNSPEC_SMULHS, UNSPEC_SMULHRS)
> 	UNSPEC_UMULHS, UNSPEC_UMULHRS): New unspecs.
> 	(MULLBT, SHRNB, SHRNT, MULHRS): New int iterators.
> 	(su, r): Handle the unspecs above.
> 	(bt): New int attribute.
> 	* internal-fn.def (IFN_MULHS, IFN_MULHRS): New internal functions.
> 	* internal-fn.c (first_commutative_argument): Commutativity info for above.
> 	* optabs.def (smulhs_optab, smulhrs_optab, umulhs_optab, umulhrs_optab):
> 	New optabs.
> 	* doc/md.texi (smulhs$var{m3}, umulhs$var{m3})
> 	(smulhrs$var{m3}, umulhrs$var{m3}): Documentation for the above.
> 	* tree-vect-patterns.c (vect_recog_mulhs_pattern): New pattern function.
> 	(vect_vect_recog_func_ptrs): Add it.
> 	* testsuite/gcc.target/aarch64/sve2/mulhrs_1.c: New test.
> 	* testsuite/gcc.dg/vect/vect-mulhrs-1.c: As above.
> 	* testsuite/gcc.dg/vect/vect-mulhrs-2.c: As above.
> 	* testsuite/gcc.dg/vect/vect-mulhrs-3.c: As above.
> 	* testsuite/gcc.dg/vect/vect-mulhrs-4.c: As above.
> 	* doc/sourcebuild.texi (vect_mulhrs_hi): Document new target selector.
> 	* testsuite/lib/target-supports.exp (check_effective_target_vect_mulhrs_hi):
> 	Return true for AArch64 without SVE2.
(with SVE2)

Thanks for doing this.  Applied with some very minor whitespace tweaks
as r275682.

Richard


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]