The following fixes PR77450. Bootstrapped and tested on x86_64-unknown-linux-gnu, applied to trunk.
Richard. 2016-09-06 Richard Biener <rguent...@suse.de> PR c/77450 c-family/ * c-common.c (c_common_mark_addressable_vec): Handle COMPOUND_LITERAL_EXPR. * c-c++-common/vector-subscript-7.c: Adjust. * c-c++-common/vector-subscript-8.c: New testcase. Index: gcc/c-family/c-common.c =================================================================== --- gcc/c-family/c-common.c (revision 240004) +++ gcc/c-family/c-common.c (working copy) @@ -10918,7 +10918,9 @@ c_common_mark_addressable_vec (tree t) { while (handled_component_p (t)) t = TREE_OPERAND (t, 0); - if (!VAR_P (t) && TREE_CODE (t) != PARM_DECL) + if (!VAR_P (t) + && TREE_CODE (t) != PARM_DECL + && TREE_CODE (t) != COMPOUND_LITERAL_EXPR) return; TREE_ADDRESSABLE (t) = 1; } Index: gcc/testsuite/c-c++-common/vector-subscript-7.c =================================================================== --- gcc/testsuite/c-c++-common/vector-subscript-7.c (revision 240004) +++ gcc/testsuite/c-c++-common/vector-subscript-7.c (working copy) @@ -1,5 +1,5 @@ /* { dg-do compile } */ -/* { dg-options "-O -fdump-tree-ccp1" } */ +/* { dg-options "-O -fdump-tree-fre1" } */ typedef int v4si __attribute__ ((vector_size (16))); @@ -11,4 +11,4 @@ main (int argc, char** argv) return ((v4si){1, 2, 42, 0})[j]; } -/* { dg-final { scan-tree-dump "return 42;" "ccp1" } } */ +/* { dg-final { scan-tree-dump "return 42;" "fre1" } } */ Index: gcc/testsuite/c-c++-common/vector-subscript-8.c =================================================================== --- gcc/testsuite/c-c++-common/vector-subscript-8.c (revision 0) +++ gcc/testsuite/c-c++-common/vector-subscript-8.c (working copy) @@ -0,0 +1,9 @@ +/* { dg-do compile } */ + +typedef int V __attribute__((vector_size(4))); + +void +foo(void) +{ + (V){ 0 }[0] = 0; +}