arm: Fix mult autovectorization patterm for iwmmxt (PR target/99786)
authorChristophe Lyon <christophe.lyon@linaro.org>
Mon, 29 Mar 2021 12:41:08 +0000 (12:41 +0000)
committerChristophe Lyon <christophe.lyon@linaro.org>
Wed, 31 Mar 2021 13:50:22 +0000 (13:50 +0000)
commit7c1d6e89994109e1b6efb5f13890be5586edeb75
tree51868249600926baafe5e35747b2c2d40a65805b
parentbf24f4ec73b65454ea0edcd6ab5616f04958d41e
arm: Fix mult autovectorization patterm for iwmmxt (PR target/99786)

Similarly to other recently-added autovectorization patterns, mult has
been erroneously enabled for iwmmxt. However, V4HI and V2SI modes are
supported, so we make an exception for them.

The new testcase is derived from gcc.dg/ubsan/pr79904.c, with
additional modes added.

I kept dg-do compile because 'assemble' results in error messages from
the assembler, which are not related to this PR:

Error: selected processor does not support `tmcrr wr0,r4,r5' in ARM mode
Error: selected processor does not support `wstrd wr0,[r0]' in ARM mode
Error: selected processor does not support `wldrd wr0,[r0]' in ARM mode
Error: selected processor does not support `wldrd wr2,.L5' in ARM mode
Error: selected processor does not support `wmulul wr0,wr0,wr2' in ARM mode
Error: selected processor does not support `wstrd wr0,[r0]' in ARM mode
Error: selected processor does not support `wldrd wr0,[r0]' in ARM mode
Error: selected processor does not support `wldrd wr2,.L8' in ARM mode
Error: selected processor does not support `wmulwl wr0,wr0,wr2' in ARM mode
Error: selected processor does not support `wstrd wr0,[r0]' in ARM mode

2021-03-29  Christophe Lyon  <christophe.lyon@linaro.org>

PR target/99786

gcc/
* config/arm/vec-common.md (mul<mode>3): Disable on iwMMXT, expect
for V4HI and V2SI.

gcc/testsuite/
* gcc.target/arm/pr99786.c: New test.
gcc/config/arm/vec-common.md
gcc/testsuite/gcc.target/arm/pr99786.c [new file with mode: 0644]