This patch makes the vectoriser try mixtures of 64-bit and 128-bit vector modes on AArch64. It fixes some existing XFAILs and allows kernel 24 from the Livermore Loops test to be vectorised (by using a mixture of V2DF and V2SI). 2019-11-14 Richard Sandiford <richard.sandiford@arm.com> gcc/ * config/aarch64/aarch64.c (aarch64_vectorize_related_mode): New function. (aarch64_autovectorize_vector_modes): Also add V4HImode and V2SImode. (TARGET_VECTORIZE_RELATED_MODE): Define. gcc/testsuite/ * gcc.dg/vect/vect-outer-4f.c: Expect the test to pass on aarch64 targets. * gcc.dg/vect/vect-outer-4g.c: Likewise. * gcc.dg/vect/vect-outer-4k.c: Likewise. * gcc.dg/vect/vect-outer-4l.c: Likewise. * gfortran.dg/vect/vect-8.f90: Expect kernel 24 to be vectorized for aarch64. * gcc.target/aarch64/vect_mixed_sizes_1.c: New test. * gcc.target/aarch64/vect_mixed_sizes_2.c: Likewise. * gcc.target/aarch64/vect_mixed_sizes_3.c: Likewise. * gcc.target/aarch64/vect_mixed_sizes_4.c: Likewise. From-SVN: r278243
Name |
Last commit
|
Last update |
---|---|---|
.. | ||
O3-pr36119.f90 | Loading commit data... | |
O3-pr39595.f | Loading commit data... | |
O3-pr49957.f | Loading commit data... | |
Ofast-pr50414.f90 | Loading commit data... | |
cost-model-pr34445.f | Loading commit data... | |
cost-model-pr34445a.f | Loading commit data... | |
fast-math-mgrid-resid.f | Loading commit data... | |
fast-math-pr33299.f90 | Loading commit data... | |
fast-math-pr37021.f90 | Loading commit data... | |
fast-math-pr38968.f90 | Loading commit data... | |
fast-math-real8-pr40801.f90 | Loading commit data... | |
fast-math-rnflow-trs2a2.f90 | Loading commit data... | |
fast-math-vect-8.f90 | Loading commit data... | |
mask-store-1.f90 | Loading commit data... | |
no-fre-no-copy-prop-O3-pr51704.f90 | Loading commit data... | |
no-vfa-pr32377.f90 | Loading commit data... | |
no-vfa-pr32457.f90 | Loading commit data... | |
pr19049.f90 | Loading commit data... | |
pr32377.f90 | Loading commit data... | |
pr32380.f | Loading commit data... | |
pr33301.f | Loading commit data... | |
pr39318.f90 | Loading commit data... | |
pr45714-a.f | Loading commit data... | |
pr45714-b.f | Loading commit data... | |
pr46213.f90 | Loading commit data... | |
pr48329.f90 | Loading commit data... | |
pr50178.f90 | Loading commit data... | |
pr50412.f90 | Loading commit data... | |
pr51058-2.f90 | Loading commit data... | |
pr51058.f90 | Loading commit data... | |
pr51285.f90 | Loading commit data... | |
pr52580.f | Loading commit data... | |
pr60510.f | Loading commit data... | |
pr61171.f | Loading commit data... | |
pr62283-2.f | Loading commit data... | |
pr62283.f | Loading commit data... | |
pr69466.f90 | Loading commit data... | |
pr69882.f90 | Loading commit data... | |
pr69980.f90 | Loading commit data... | |
pr70043.f90 | Loading commit data... | |
pr77848.f | Loading commit data... | |
pr81303.f | Loading commit data... | |
pr83232.f90 | Loading commit data... | |
pr84913.f90 | Loading commit data... | |
pr85853.f90 | Loading commit data... | |
pr86421.f90 | Loading commit data... | |
pr89535.f90 | Loading commit data... | |
pr90681.f | Loading commit data... | |
pr90913.f90 | Loading commit data... | |
vect-1.f90 | Loading commit data... | |
vect-2.f90 | Loading commit data... | |
vect-3.f90 | Loading commit data... | |
vect-4.f90 | Loading commit data... | |
vect-5.f90 | Loading commit data... | |
vect-6.f | Loading commit data... | |
vect-7.f90 | Loading commit data... | |
vect-8-epilogue.F90 | Loading commit data... | |
vect-8.f90 | Loading commit data... | |
vect-9.f90 | Loading commit data... | |
vect-alias-check-1.F90 | Loading commit data... | |
vect-do-concurrent-1.f90 | Loading commit data... | |
vect-gems.f90 | Loading commit data... | |
vect.exp | Loading commit data... |