Fix code order in tree-sra.c:create_access
authorRichard Sandiford <richard.sandiford@arm.com>
Fri, 8 Nov 2019 11:58:45 +0000 (11:58 +0000)
committerRichard Sandiford <rsandifo@gcc.gnu.org>
Fri, 8 Nov 2019 11:58:45 +0000 (11:58 +0000)
commit93ace3af2c44fa019f5141243be198fb2233c7f8
tree30b41e500b3c8d0bda47f2bd6a66bb0c8dd9ec78
parentb602712b3ea2a0729a2eda61bd9ee795aba6138f
Fix code order in tree-sra.c:create_access

If get_ref_base_and_extent returns poly_int offsets or sizes,
tree-sra.c:create_access prevents SRA from being applied to the base.
However, we haven't verified by that point that we have a valid base
to disqualify.

This originally led to an ICE on the attached testcase, but it
no longer triggers there after the introduction of IPA SRA.

2019-11-08  Richard Sandiford  <richard.sandiford@arm.com>

gcc/
* tree-sra.c (create_access): Delay disqualifying the base
for poly_int values until we know we have a base.

gcc/testsuite/
* gcc.target/aarch64/sve/acle/general/inline_2.c: New test.

From-SVN: r277965
gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/aarch64/sve/acle/general/inline_2.c [new file with mode: 0644]
gcc/tree-sra.c