Commit ba4698e1 by Francois-Xavier Coudert Committed by François-Xavier Coudert

re PR fortran/34956 (-fbounds-check: bounds_check_9.f90: Use of uninitialized memory)

	PR fortran/34956
	* trans-array.c (gfc_conv_ss_startstride): Fix the logic to avoid
	checking bounds of absent optional arguments.

From-SVN: r133037
parent 9e94c78f
2008-03-08 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org>
PR fortran/34956
* trans-array.c (gfc_conv_ss_startstride): Fix the logic to avoid
checking bounds of absent optional arguments.
2008-03-06 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org> 2008-03-06 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org>
PR fortran/33197 PR fortran/33197
......
...@@ -2924,9 +2924,13 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop) ...@@ -2924,9 +2924,13 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop)
for (ss = loop->ss; ss != gfc_ss_terminator; ss = ss->loop_chain) for (ss = loop->ss; ss != gfc_ss_terminator; ss = ss->loop_chain)
{ {
stmtblock_t inner;
if (ss->type != GFC_SS_SECTION) if (ss->type != GFC_SS_SECTION)
continue; continue;
gfc_start_block (&inner);
/* TODO: range checking for mapped dimensions. */ /* TODO: range checking for mapped dimensions. */
info = &ss->data.info; info = &ss->data.info;
...@@ -2953,7 +2957,7 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop) ...@@ -2953,7 +2957,7 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop)
asprintf (&msg, "Zero stride is not allowed, for dimension %d " asprintf (&msg, "Zero stride is not allowed, for dimension %d "
"of array '%s'", info->dim[n]+1, "of array '%s'", info->dim[n]+1,
ss->expr->symtree->name); ss->expr->symtree->name);
gfc_trans_runtime_check (tmp, &block, &ss->expr->where, msg); gfc_trans_runtime_check (tmp, &inner, &ss->expr->where, msg);
gfc_free (msg); gfc_free (msg);
desc = ss->data.info.descriptor; desc = ss->data.info.descriptor;
...@@ -2995,7 +2999,7 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop) ...@@ -2995,7 +2999,7 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop)
asprintf (&msg, "%s, lower bound of dimension %d of array '%s'" asprintf (&msg, "%s, lower bound of dimension %d of array '%s'"
" exceeded (%%ld < %%ld)", gfc_msg_fault, " exceeded (%%ld < %%ld)", gfc_msg_fault,
info->dim[n]+1, ss->expr->symtree->name); info->dim[n]+1, ss->expr->symtree->name);
gfc_trans_runtime_check (tmp, &block, &ss->expr->where, msg, gfc_trans_runtime_check (tmp, &inner, &ss->expr->where, msg,
fold_convert (long_integer_type_node, fold_convert (long_integer_type_node,
info->start[n]), info->start[n]),
fold_convert (long_integer_type_node, fold_convert (long_integer_type_node,
...@@ -3011,7 +3015,7 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop) ...@@ -3011,7 +3015,7 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop)
asprintf (&msg, "%s, upper bound of dimension %d of array " asprintf (&msg, "%s, upper bound of dimension %d of array "
"'%s' exceeded (%%ld > %%ld)", gfc_msg_fault, "'%s' exceeded (%%ld > %%ld)", gfc_msg_fault,
info->dim[n]+1, ss->expr->symtree->name); info->dim[n]+1, ss->expr->symtree->name);
gfc_trans_runtime_check (tmp, &block, &ss->expr->where, msg, gfc_trans_runtime_check (tmp, &inner, &ss->expr->where, msg,
fold_convert (long_integer_type_node, info->start[n]), fold_convert (long_integer_type_node, info->start[n]),
fold_convert (long_integer_type_node, ubound)); fold_convert (long_integer_type_node, ubound));
gfc_free (msg); gfc_free (msg);
...@@ -3033,7 +3037,7 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop) ...@@ -3033,7 +3037,7 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop)
asprintf (&msg, "%s, lower bound of dimension %d of array '%s'" asprintf (&msg, "%s, lower bound of dimension %d of array '%s'"
" exceeded (%%ld < %%ld)", gfc_msg_fault, " exceeded (%%ld < %%ld)", gfc_msg_fault,
info->dim[n]+1, ss->expr->symtree->name); info->dim[n]+1, ss->expr->symtree->name);
gfc_trans_runtime_check (tmp, &block, &ss->expr->where, msg, gfc_trans_runtime_check (tmp, &inner, &ss->expr->where, msg,
fold_convert (long_integer_type_node, fold_convert (long_integer_type_node,
tmp2), tmp2),
fold_convert (long_integer_type_node, fold_convert (long_integer_type_node,
...@@ -3048,7 +3052,7 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop) ...@@ -3048,7 +3052,7 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop)
asprintf (&msg, "%s, upper bound of dimension %d of array " asprintf (&msg, "%s, upper bound of dimension %d of array "
"'%s' exceeded (%%ld > %%ld)", gfc_msg_fault, "'%s' exceeded (%%ld > %%ld)", gfc_msg_fault,
info->dim[n]+1, ss->expr->symtree->name); info->dim[n]+1, ss->expr->symtree->name);
gfc_trans_runtime_check (tmp, &block, &ss->expr->where, msg, gfc_trans_runtime_check (tmp, &inner, &ss->expr->where, msg,
fold_convert (long_integer_type_node, tmp2), fold_convert (long_integer_type_node, tmp2),
fold_convert (long_integer_type_node, ubound)); fold_convert (long_integer_type_node, ubound));
gfc_free (msg); gfc_free (msg);
...@@ -3066,30 +3070,30 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop) ...@@ -3066,30 +3070,30 @@ gfc_conv_ss_startstride (gfc_loopinfo * loop)
tree tmp3; tree tmp3;
tmp3 = fold_build2 (NE_EXPR, boolean_type_node, tmp, size[n]); tmp3 = fold_build2 (NE_EXPR, boolean_type_node, tmp, size[n]);
/* For optional arguments, only check bounds if the
argument is present. */
if (ss->expr->symtree->n.sym->attr.optional
|| ss->expr->symtree->n.sym->attr.not_always_present)
{
tree cond;
cond = gfc_conv_expr_present (ss->expr->symtree->n.sym);
tmp3 = fold_build2 (TRUTH_AND_EXPR, boolean_type_node,
cond, tmp3);
}
asprintf (&msg, "%s, size mismatch for dimension %d " asprintf (&msg, "%s, size mismatch for dimension %d "
"of array '%s' (%%ld/%%ld)", gfc_msg_bounds, "of array '%s' (%%ld/%%ld)", gfc_msg_bounds,
info->dim[n]+1, ss->expr->symtree->name); info->dim[n]+1, ss->expr->symtree->name);
gfc_trans_runtime_check (tmp3, &block, &ss->expr->where, msg, gfc_trans_runtime_check (tmp3, &inner, &ss->expr->where, msg,
fold_convert (long_integer_type_node, tmp), fold_convert (long_integer_type_node, tmp),
fold_convert (long_integer_type_node, size[n])); fold_convert (long_integer_type_node, size[n]));
gfc_free (msg); gfc_free (msg);
} }
else else
size[n] = gfc_evaluate_now (tmp, &block); size[n] = gfc_evaluate_now (tmp, &inner);
} }
tmp = gfc_finish_block (&inner);
/* For optional arguments, only check bounds if the argument is
present. */
if (ss->expr->symtree->n.sym->attr.optional
|| ss->expr->symtree->n.sym->attr.not_always_present)
tmp = build3_v (COND_EXPR,
gfc_conv_expr_present (ss->expr->symtree->n.sym),
tmp, build_empty_stmt ());
gfc_add_expr_to_block (&block, tmp);
} }
tmp = gfc_finish_block (&block); tmp = gfc_finish_block (&block);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment