summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew MacLeod <amacleod@redhat.com>2022-08-08 15:13:51 -0400
committerAndrew MacLeod <amacleod@redhat.com>2022-08-08 16:08:51 -0400
commitef623bb58594958a7959f8f031f65a50eb0e5890 (patch)
tree857027e0fbb693afd507c6c34169a3802ba036c8
parent053876cdbe8057210e6f4da4eec2df58f92ccd4c (diff)
Processing of a cond_expr requires that a range of the correct type for the operands of the cond_expr is passed in. PR tree-optimization/106556 gcc/ * gimple-range-gori.cc (gori_compute::condexpr_adjust): Use the type of the cond_expr operands being evaluted. gcc/testsuite/ * gfortran.dg/pr106556.f90: New.
-rw-r--r--gcc/gimple-range-gori.cc11
-rw-r--r--gcc/testsuite/gfortran.dg/pr106556.f9010
2 files changed, 16 insertions, 5 deletions
diff --git a/gcc/gimple-range-gori.cc b/gcc/gimple-range-gori.cc
index a43e44c841e..8879e44cba1 100644
--- a/gcc/gimple-range-gori.cc
+++ b/gcc/gimple-range-gori.cc
@@ -1398,16 +1398,17 @@ gori_compute::condexpr_adjust (vrange &r1, vrange &r2, gimple *, tree cond,
}
// Now solve for SSA1 or SSA2 if they are in the dependency chain.
- Value_Range tmp (type);
if (ssa1 && in_chain_p (ssa1, cond_name))
{
- if (compute_operand_range (tmp, def_stmt, cond_true, ssa1, src))
- r1.intersect (tmp);
+ Value_Range tmp1 (TREE_TYPE (ssa1));
+ if (compute_operand_range (tmp1, def_stmt, cond_true, ssa1, src))
+ r1.intersect (tmp1);
}
if (ssa2 && in_chain_p (ssa2, cond_name))
{
- if (compute_operand_range (tmp, def_stmt, cond_false, ssa2, src))
- r2.intersect (tmp);
+ Value_Range tmp2 (TREE_TYPE (ssa2));
+ if (compute_operand_range (tmp2, def_stmt, cond_false, ssa2, src))
+ r2.intersect (tmp2);
}
if (idx)
{
diff --git a/gcc/testsuite/gfortran.dg/pr106556.f90 b/gcc/testsuite/gfortran.dg/pr106556.f90
new file mode 100644
index 00000000000..01b89a8eee2
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/pr106556.f90
@@ -0,0 +1,10 @@
+! { dg-do compile }
+! { dg-options "-O1 -fnon-call-exceptions -ftree-loop-if-convert" }
+
+
+program p
+ real :: a(2)
+
+ a(:) = 1.0
+ if (minloc (a, dim = 1).ne.1) STOP 1
+end