annotate gcc/gimple-ssa-evrp-analyze.c @ 158:494b0b89df80 default tip

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