From: ebotcazou Date: Wed, 18 Nov 2015 18:19:57 +0000 (+0000) Subject: * gcc-interface/trans.c (fold_constant_decl_in_expr) : If X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=f20739b0e1303794f5b1c8b81530c91f7af02032;p=thirdparty%2Fgcc.git * gcc-interface/trans.c (fold_constant_decl_in_expr) : If the index is not itself constant then bail out. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@230558 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog index 2b9eed4cbe98..3ffb45e7114c 100644 --- a/gcc/ada/ChangeLog +++ b/gcc/ada/ChangeLog @@ -1,3 +1,8 @@ +2015-11-18 Eric Botcazou + + * gcc-interface/trans.c (fold_constant_decl_in_expr) : If + the index is not itself constant then bail out. + 2015-11-18 Ed Schonberg * sem_ch4.adb (Try_Container_Indexing): When constructing the diff --git a/gcc/ada/gcc-interface/trans.c b/gcc/ada/gcc-interface/trans.c index eeb2aaca5cff..0d100193baa6 100644 --- a/gcc/ada/gcc-interface/trans.c +++ b/gcc/ada/gcc-interface/trans.c @@ -975,6 +975,9 @@ fold_constant_decl_in_expr (tree exp) case ARRAY_REF: case ARRAY_RANGE_REF: + /* If the index is not itself constant, then nothing can be folded. */ + if (!TREE_CONSTANT (TREE_OPERAND (exp, 1))) + return exp; op0 = fold_constant_decl_in_expr (TREE_OPERAND (exp, 0)); if (op0 == TREE_OPERAND (exp, 0)) return exp;