Fix incorrect TARGET_MEM_REF alignment (PR 84419)
authorRichard Sandiford <richard.sandiford@linaro.org>
Tue, 20 Feb 2018 14:44:24 +0000 (14:44 +0000)
committerRichard Sandiford <rsandifo@gcc.gnu.org>
Tue, 20 Feb 2018 14:44:24 +0000 (14:44 +0000)
commit9bd958c5f361337b15958be8641d59ad38bd0a2b
tree4876fe452ae7607c88e5357f95da7f998ac00588
parentef7866a3f1395f16872a0d61e111660e302a674d
Fix incorrect TARGET_MEM_REF alignment (PR 84419)

expand_call_mem_ref checks for TARGET_MEM_REFs that have compatible
type, but it didn't then go on to install the specific type we need,
which might have different alignment due to:

  if (TYPE_ALIGN (type) != align)
    type = build_aligned_type (type, align);

This was causing masked stores to be incorrectly marked as
aligned on AVX512.

2018-02-20  Richard Sandiford  <richard.sandiford@linaro.org>

gcc/
PR tree-optimization/84419
* internal-fn.c (expand_call_mem_ref): Create a TARGET_MEM_REF
with the required type if its current type is compatible but
different.

gcc/testsuite/
PR tree-optimization/84419
* gcc.dg/vect/pr84419.c: New test.

From-SVN: r257847
gcc/ChangeLog
gcc/internal-fn.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/vect/pr84419.c [new file with mode: 0644]