annotate gcc/gimple-ssa-evrp-analyze.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
131
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
1 /* Support routines for Value Range Propagation (VRP).
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
2 Copyright (C) 2005-2018 Free Software Foundation, Inc.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
3
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
4 This file is part of GCC.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
5
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
6 GCC is free software; you can redistribute it and/or modify
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
7 it under the terms of the GNU General Public License as published by
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
8 the Free Software Foundation; either version 3, or (at your option)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
9 any later version.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
10
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
11 GCC is distributed in the hope that it will be useful,
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
14 GNU General Public License for more details.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
15
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
17 along with GCC; see the file COPYING3. If not see
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
18 <http://www.gnu.org/licenses/>. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
19
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
20 #include "config.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
21 #include "system.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
22 #include "coretypes.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
23 #include "backend.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
24 #include "tree.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
25 #include "gimple.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
26 #include "tree-pass.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
27 #include "ssa.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
28 #include "gimple-pretty-print.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
29 #include "cfganal.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
30 #include "gimple-fold.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
31 #include "tree-eh.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
32 #include "gimple-iterator.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
33 #include "tree-cfg.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
34 #include "tree-ssa-loop-manip.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
35 #include "tree-ssa-loop.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
36 #include "cfgloop.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
37 #include "tree-scalar-evolution.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
38 #include "tree-ssa-propagate.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
39 #include "alloc-pool.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
40 #include "domwalk.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
41 #include "tree-cfgcleanup.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
42 #include "vr-values.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
43 #include "gimple-ssa-evrp-analyze.h"
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
44
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
45 evrp_range_analyzer::evrp_range_analyzer () : stack (10)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
46 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
47 edge e;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
48 edge_iterator ei;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
49 basic_block bb;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
50 FOR_EACH_BB_FN (bb, cfun)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
51 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
52 bb->flags &= ~BB_VISITED;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
53 FOR_EACH_EDGE (e, ei, bb->preds)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
54 e->flags |= EDGE_EXECUTABLE;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
55 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
56 vr_values = new class vr_values;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
57 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
58
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
59 /* Push an unwinding marker onto the unwinding stack. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
60
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
61 void
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
62 evrp_range_analyzer::push_marker ()
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
63 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
64 stack.safe_push (std::make_pair (NULL_TREE, (value_range *)NULL));
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
65 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
66
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
67 /* Analyze ranges as we enter basic block BB. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
68
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
69 void
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
70 evrp_range_analyzer::enter (basic_block bb)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
71 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
72 if (!optimize)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
73 return;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
74 push_marker ();
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
75 record_ranges_from_incoming_edge (bb);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
76 record_ranges_from_phis (bb);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
77 bb->flags |= BB_VISITED;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
78 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
79
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
80 /* Find new range for NAME such that (OP CODE LIMIT) is true. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
81 value_range *
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
82 evrp_range_analyzer::try_find_new_range (tree name,
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
83 tree op, tree_code code, tree limit)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
84 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
85 value_range vr;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
86 value_range *old_vr = get_value_range (name);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
87
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
88 /* Discover VR when condition is true. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
89 vr_values->extract_range_for_var_from_comparison_expr (name, code, op,
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
90 limit, &vr);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
91 /* If we found any usable VR, set the VR to ssa_name and create a
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
92 PUSH old value in the stack with the old VR. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
93 if (!vr.undefined_p () && !vr.varying_p ())
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
94 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
95 if (old_vr->kind () == vr.kind ()
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
96 && vrp_operand_equal_p (old_vr->min (), vr.min ())
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
97 && vrp_operand_equal_p (old_vr->max (), vr.max ()))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
98 return NULL;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
99 value_range *new_vr = vr_values->allocate_value_range ();
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
100 *new_vr = vr;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
101 return new_vr;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
102 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
103 return NULL;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
104 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
105
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
106 /* For LHS record VR in the SSA info. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
107 void
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
108 evrp_range_analyzer::set_ssa_range_info (tree lhs, value_range *vr)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
109 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
110 /* Set the SSA with the value range. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
111 if (INTEGRAL_TYPE_P (TREE_TYPE (lhs)))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
112 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
113 if (vr->constant_p ())
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
114 set_range_info (lhs, vr->kind (),
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
115 wi::to_wide (vr->min ()),
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
116 wi::to_wide (vr->max ()));
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
117 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
118 else if (POINTER_TYPE_P (TREE_TYPE (lhs))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
119 && range_includes_zero_p (vr) == 0)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
120 set_ptr_nonnull (lhs);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
121 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
122
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
123 /* Return true if all uses of NAME are dominated by STMT or feed STMT
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
124 via a chain of single immediate uses. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
125
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
126 static bool
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
127 all_uses_feed_or_dominated_by_stmt (tree name, gimple *stmt)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
128 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
129 use_operand_p use_p, use2_p;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
130 imm_use_iterator iter;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
131 basic_block stmt_bb = gimple_bb (stmt);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
132
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
133 FOR_EACH_IMM_USE_FAST (use_p, iter, name)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
134 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
135 gimple *use_stmt = USE_STMT (use_p), *use_stmt2;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
136 if (use_stmt == stmt
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
137 || is_gimple_debug (use_stmt)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
138 || (gimple_bb (use_stmt) != stmt_bb
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
139 && dominated_by_p (CDI_DOMINATORS,
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
140 gimple_bb (use_stmt), stmt_bb)))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
141 continue;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
142 while (use_stmt != stmt
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
143 && is_gimple_assign (use_stmt)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
144 && TREE_CODE (gimple_assign_lhs (use_stmt)) == SSA_NAME
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
145 && single_imm_use (gimple_assign_lhs (use_stmt),
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
146 &use2_p, &use_stmt2))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
147 use_stmt = use_stmt2;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
148 if (use_stmt != stmt)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
149 return false;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
150 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
151 return true;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
152 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
153
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
154 void
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
155 evrp_range_analyzer::record_ranges_from_incoming_edge (basic_block bb)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
156 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
157 edge pred_e = single_pred_edge_ignoring_loop_edges (bb, false);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
158 if (pred_e)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
159 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
160 gimple *stmt = last_stmt (pred_e->src);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
161 tree op0 = NULL_TREE;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
162
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
163 if (stmt
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
164 && gimple_code (stmt) == GIMPLE_COND
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
165 && (op0 = gimple_cond_lhs (stmt))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
166 && TREE_CODE (op0) == SSA_NAME
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
167 && (INTEGRAL_TYPE_P (TREE_TYPE (gimple_cond_lhs (stmt)))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
168 || POINTER_TYPE_P (TREE_TYPE (gimple_cond_lhs (stmt)))))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
169 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
170 if (dump_file && (dump_flags & TDF_DETAILS))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
171 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
172 fprintf (dump_file, "Visiting controlling predicate ");
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
173 print_gimple_stmt (dump_file, stmt, 0);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
174 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
175 /* Entering a new scope. Try to see if we can find a VR
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
176 here. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
177 tree op1 = gimple_cond_rhs (stmt);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
178 if (TREE_OVERFLOW_P (op1))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
179 op1 = drop_tree_overflow (op1);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
180 tree_code code = gimple_cond_code (stmt);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
181
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
182 auto_vec<assert_info, 8> asserts;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
183 register_edge_assert_for (op0, pred_e, code, op0, op1, asserts);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
184 if (TREE_CODE (op1) == SSA_NAME)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
185 register_edge_assert_for (op1, pred_e, code, op0, op1, asserts);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
186
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
187 auto_vec<std::pair<tree, value_range *>, 8> vrs;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
188 for (unsigned i = 0; i < asserts.length (); ++i)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
189 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
190 value_range *vr = try_find_new_range (asserts[i].name,
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
191 asserts[i].expr,
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
192 asserts[i].comp_code,
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
193 asserts[i].val);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
194 if (vr)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
195 vrs.safe_push (std::make_pair (asserts[i].name, vr));
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
196 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
197
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
198 /* If pred_e is really a fallthru we can record value ranges
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
199 in SSA names as well. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
200 bool is_fallthru = assert_unreachable_fallthru_edge_p (pred_e);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
201
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
202 /* Push updated ranges only after finding all of them to avoid
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
203 ordering issues that can lead to worse ranges. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
204 for (unsigned i = 0; i < vrs.length (); ++i)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
205 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
206 /* But make sure we do not weaken ranges like when
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
207 getting first [64, +INF] and then ~[0, 0] from
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
208 conditions like (s & 0x3cc0) == 0). */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
209 value_range *old_vr = get_value_range (vrs[i].first);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
210 value_range tem (old_vr->kind (), old_vr->min (), old_vr->max ());
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
211 tem.intersect (vrs[i].second);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
212 if (tem.ignore_equivs_equal_p (*old_vr))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
213 continue;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
214 push_value_range (vrs[i].first, vrs[i].second);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
215 if (is_fallthru
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
216 && all_uses_feed_or_dominated_by_stmt (vrs[i].first, stmt))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
217 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
218 set_ssa_range_info (vrs[i].first, vrs[i].second);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
219 maybe_set_nonzero_bits (pred_e, vrs[i].first);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
220 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
221 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
222 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
223 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
224 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
225
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
226 void
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
227 evrp_range_analyzer::record_ranges_from_phis (basic_block bb)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
228 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
229 /* Visit PHI stmts and discover any new VRs possible. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
230 bool has_unvisited_preds = false;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
231 edge_iterator ei;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
232 edge e;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
233 FOR_EACH_EDGE (e, ei, bb->preds)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
234 if (e->flags & EDGE_EXECUTABLE
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
235 && !(e->src->flags & BB_VISITED))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
236 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
237 has_unvisited_preds = true;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
238 break;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
239 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
240
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
241 for (gphi_iterator gpi = gsi_start_phis (bb);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
242 !gsi_end_p (gpi); gsi_next (&gpi))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
243 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
244 gphi *phi = gpi.phi ();
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
245 tree lhs = PHI_RESULT (phi);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
246 if (virtual_operand_p (lhs))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
247 continue;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
248
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
249 value_range vr_result;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
250 bool interesting = stmt_interesting_for_vrp (phi);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
251 if (!has_unvisited_preds && interesting)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
252 vr_values->extract_range_from_phi_node (phi, &vr_result);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
253 else
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
254 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
255 set_value_range_to_varying (&vr_result);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
256 /* When we have an unvisited executable predecessor we can't
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
257 use PHI arg ranges which may be still UNDEFINED but have
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
258 to use VARYING for them. But we can still resort to
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
259 SCEV for loop header PHIs. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
260 struct loop *l;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
261 if (scev_initialized_p ()
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
262 && interesting
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
263 && (l = loop_containing_stmt (phi))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
264 && l->header == gimple_bb (phi))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
265 vr_values->adjust_range_with_scev (&vr_result, l, phi, lhs);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
266 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
267 vr_values->update_value_range (lhs, &vr_result);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
268
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
269 /* Set the SSA with the value range. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
270 set_ssa_range_info (lhs, &vr_result);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
271 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
272 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
273
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
274 /* Record ranges from STMT into our VR_VALUES class. If TEMPORARY is
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
275 true, then this is a temporary equivalence and should be recorded
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
276 into the unwind table. Othewise record the equivalence into the
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
277 global table. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
278
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
279 void
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
280 evrp_range_analyzer::record_ranges_from_stmt (gimple *stmt, bool temporary)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
281 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
282 tree output = NULL_TREE;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
283
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
284 if (!optimize)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
285 return;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
286
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
287 if (dyn_cast <gcond *> (stmt))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
288 ;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
289 else if (stmt_interesting_for_vrp (stmt))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
290 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
291 edge taken_edge;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
292 value_range vr;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
293 vr_values->extract_range_from_stmt (stmt, &taken_edge, &output, &vr);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
294 if (output)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
295 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
296 /* Set the SSA with the value range. There are two cases to
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
297 consider. First (the the most common) is we are processing
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
298 STMT in a context where its resulting range globally holds
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
299 and thus it can be reflected into the global ranges and need
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
300 not be unwound as we leave scope.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
301
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
302 The second case occurs if we are processing a statement in
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
303 a context where the resulting range must not be reflected
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
304 into the global tables and must be unwound as we leave
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
305 the current context. This happens in jump threading for
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
306 example. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
307 if (!temporary)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
308 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
309 /* Case one. We can just update the underlying range
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
310 information as well as the global information. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
311 vr_values->update_value_range (output, &vr);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
312 set_ssa_range_info (output, &vr);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
313 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
314 else
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
315 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
316 /* We're going to need to unwind this range. We can
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
317 not use VR as that's a stack object. We have to allocate
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
318 a new range and push the old range onto the stack. We
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
319 also have to be very careful about sharing the underlying
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
320 bitmaps. Ugh. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
321 value_range *new_vr = vr_values->allocate_value_range ();
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
322 *new_vr = vr;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
323 new_vr->equiv_clear ();
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
324 push_value_range (output, new_vr);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
325 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
326 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
327 else
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
328 vr_values->set_defs_to_varying (stmt);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
329 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
330 else
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
331 vr_values->set_defs_to_varying (stmt);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
332
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
333 /* See if we can derive a range for any of STMT's operands. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
334 tree op;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
335 ssa_op_iter i;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
336 FOR_EACH_SSA_TREE_OPERAND (op, stmt, i, SSA_OP_USE)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
337 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
338 tree value;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
339 enum tree_code comp_code;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
340
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
341 /* If OP is used in such a way that we can infer a value
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
342 range for it, and we don't find a previous assertion for
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
343 it, create a new assertion location node for OP. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
344 if (infer_value_range (stmt, op, &comp_code, &value))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
345 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
346 /* If we are able to infer a nonzero value range for OP,
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
347 then walk backwards through the use-def chain to see if OP
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
348 was set via a typecast.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
349 If so, then we can also infer a nonzero value range
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
350 for the operand of the NOP_EXPR. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
351 if (comp_code == NE_EXPR && integer_zerop (value))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
352 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
353 tree t = op;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
354 gimple *def_stmt = SSA_NAME_DEF_STMT (t);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
355 while (is_gimple_assign (def_stmt)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
356 && CONVERT_EXPR_CODE_P (gimple_assign_rhs_code (def_stmt))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
357 && TREE_CODE
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
358 (gimple_assign_rhs1 (def_stmt)) == SSA_NAME
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
359 && POINTER_TYPE_P
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
360 (TREE_TYPE (gimple_assign_rhs1 (def_stmt))))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
361 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
362 t = gimple_assign_rhs1 (def_stmt);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
363 def_stmt = SSA_NAME_DEF_STMT (t);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
364
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
365 /* Add VR when (T COMP_CODE value) condition is
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
366 true. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
367 value_range *op_range
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
368 = try_find_new_range (t, t, comp_code, value);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
369 if (op_range)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
370 push_value_range (t, op_range);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
371 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
372 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
373 /* Add VR when (OP COMP_CODE value) condition is true. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
374 value_range *op_range = try_find_new_range (op, op,
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
375 comp_code, value);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
376 if (op_range)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
377 push_value_range (op, op_range);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
378 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
379 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
380 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
381
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
382 /* Unwind recorded ranges to their most recent state. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
383
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
384 void
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
385 evrp_range_analyzer::pop_to_marker (void)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
386 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
387 gcc_checking_assert (!stack.is_empty ());
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
388 while (stack.last ().first != NULL_TREE)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
389 pop_value_range (stack.last ().first);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
390 stack.pop ();
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
391 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
392
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
393 /* Restore/pop VRs valid only for BB when we leave BB. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
394
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
395 void
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
396 evrp_range_analyzer::leave (basic_block bb ATTRIBUTE_UNUSED)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
397 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
398 if (!optimize)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
399 return;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
400 pop_to_marker ();
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
401 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
402
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
403
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
404 /* Push the Value Range of VAR to the stack and update it with new VR. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
405
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
406 void
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
407 evrp_range_analyzer::push_value_range (tree var, value_range *vr)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
408 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
409 if (dump_file && (dump_flags & TDF_DETAILS))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
410 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
411 fprintf (dump_file, "pushing new range for ");
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
412 print_generic_expr (dump_file, var);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
413 fprintf (dump_file, ": ");
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
414 dump_value_range (dump_file, vr);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
415 fprintf (dump_file, "\n");
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
416 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
417 stack.safe_push (std::make_pair (var, get_value_range (var)));
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
418 vr_values->set_vr_value (var, vr);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
419 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
420
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
421 /* Pop the Value Range from the vrp_stack and update VAR with it. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
422
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
423 value_range *
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
424 evrp_range_analyzer::pop_value_range (tree var)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
425 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
426 value_range *vr = stack.last ().second;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
427 gcc_checking_assert (var == stack.last ().first);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
428 if (dump_file && (dump_flags & TDF_DETAILS))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
429 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
430 fprintf (dump_file, "popping range for ");
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
431 print_generic_expr (dump_file, var);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
432 fprintf (dump_file, ", restoring ");
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
433 dump_value_range (dump_file, vr);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
434 fprintf (dump_file, "\n");
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
435 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
436 vr_values->set_vr_value (var, vr);
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
437 stack.pop ();
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
438 return vr;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
439 }