From: Guozhi Wei Date: Wed, 22 Oct 2014 15:56:59 +0000 (+0000) Subject: re PR tree-optimization/63530 (GCC generates incorrect aligned store on ARM after... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=417dfefbdbc78eef2b6e9a2f70f153547c73b6e3;p=gcc.git re PR tree-optimization/63530 (GCC generates incorrect aligned store on ARM after the loop is unrolled.) PR tree-optimization/63530 tree-vect-data-refs.c (vect_create_addr_base_for_vector_ref): Set pointer alignment according to DR_MISALIGNMENT. gcc.dg/vect/pr63530.c: New testcase. From-SVN: r216562 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 1a460237294..3687418c5b0 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2014-10-22 Guozhi Wei + + PR tree-optimization/63530 + tree-vect-data-refs.c (vect_create_addr_base_for_vector_ref): Set + pointer alignment according to DR_MISALIGNMENT. + 2014-10-22 David Malcolm * ipa-icf.c (ipa_icf_driver): Set optimizer to NULL when done. diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 964037a1e96..5762e8fa608 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2014-10-22 Guozhi Wei + + PR tree-optimization/63530 + gcc.dg/vect/pr63530.c: New testcase. + 2014-10-22 Richard Sandiford * gcc.target/i386/conversion-2.c: New test. diff --git a/gcc/testsuite/gcc.dg/vect/pr63530.c b/gcc/testsuite/gcc.dg/vect/pr63530.c new file mode 100644 index 00000000000..b583b9b3550 --- /dev/null +++ b/gcc/testsuite/gcc.dg/vect/pr63530.c @@ -0,0 +1,30 @@ +/* { dg-options "-O2 -ftree-vectorize -funroll-loops --param \"max-completely-peeled-insns=400\"" } */ + +/* PR tree-optimization/63530 */ +/* On armv7 hardware, following options cause run time failure */ +/* -march=armv7-a -mfloat-abi=hard -mfpu=neon -marm -O2 -ftree-vectorize */ +/* -funroll-loops --param "max-completely-peeled-insns=400" */ + +#include + +typedef struct { + unsigned char map[256]; + int i; +} A, *AP; + +AP __attribute__ ((noinline)) +foo (int n) +{ + AP b = (AP)calloc (1, sizeof (A)); + int i; + for (i = n; i < 256; i++) + b->map[i] = i; + return b; +} + +int +main() +{ + AP p = foo(3); + return p->map[30] - p->map[20] - p->map[10]; +} diff --git a/gcc/tree-vect-data-refs.c b/gcc/tree-vect-data-refs.c index 0807b95099d..66ba70a5855 100644 --- a/gcc/tree-vect-data-refs.c +++ b/gcc/tree-vect-data-refs.c @@ -3960,8 +3960,12 @@ vect_create_addr_base_for_vector_ref (gimple stmt, && TREE_CODE (addr_base) == SSA_NAME) { duplicate_ssa_name_ptr_info (addr_base, DR_PTR_INFO (dr)); - if (offset) + unsigned int align = TYPE_ALIGN_UNIT (STMT_VINFO_VECTYPE (stmt_info)); + int misalign = DR_MISALIGNMENT (dr); + if (offset || byte_offset || (misalign == -1)) mark_ptr_info_alignment_unknown (SSA_NAME_PTR_INFO (addr_base)); + else + set_ptr_info_alignment (SSA_NAME_PTR_INFO (addr_base), align, misalign); } if (dump_enabled_p ())