From: Eric Botcazou Date: Wed, 18 Nov 2015 18:19:57 +0000 (+0000) Subject: trans.c (fold_constant_decl_in_expr): If the index is not itself constant then bail... X-Git-Tag: upstream/12.2.0~50706 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=a239279ee574a15ed79d27b48f835c3db45a593f;p=platform%2Fupstream%2Fgcc.git trans.c (fold_constant_decl_in_expr): If the index is not itself constant then bail out. * gcc-interface/trans.c (fold_constant_decl_in_expr) : If the index is not itself constant then bail out. From-SVN: r230558 --- diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog index 2b9eed4..3ffb45e 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 eeb2aac..0d10019 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;