aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
Diffstat (limited to 'gcc')
-rw-r--r--gcc/gimple-ssa-evrp.c20
1 files changed, 9 insertions, 11 deletions
diff --git a/gcc/gimple-ssa-evrp.c b/gcc/gimple-ssa-evrp.c
index 829fdcd..118d103 100644
--- a/gcc/gimple-ssa-evrp.c
+++ b/gcc/gimple-ssa-evrp.c
@@ -117,11 +117,8 @@ class rvrp_folder : public substitute_and_fold_engine
public:
rvrp_folder () : substitute_and_fold_engine (), m_simplifier ()
- {
- if (param_evrp_mode & EVRP_MODE_TRACE)
- m_ranger = new trace_ranger ();
- else
- m_ranger = new gimple_ranger ();
+ {
+ m_ranger = enable_ranger (cfun);
m_simplifier.set_range_query (m_ranger);
}
@@ -129,7 +126,9 @@ public:
{
if (dump_file && (dump_flags & TDF_DETAILS))
m_ranger->dump (dump_file);
- delete m_ranger;
+
+ m_ranger->export_global_ranges ();
+ disable_ranger (cfun);
}
tree value_of_expr (tree name, gimple *s = NULL) OVERRIDE
@@ -175,10 +174,7 @@ class hybrid_folder : public evrp_folder
public:
hybrid_folder (bool evrp_first)
{
- if (param_evrp_mode & EVRP_MODE_TRACE)
- m_ranger = new trace_ranger ();
- else
- m_ranger = new gimple_ranger ();
+ m_ranger = enable_ranger (cfun);
if (evrp_first)
{
@@ -196,7 +192,9 @@ public:
{
if (dump_file && (dump_flags & TDF_DETAILS))
m_ranger->dump (dump_file);
- delete m_ranger;
+
+ m_ranger->export_global_ranges ();
+ disable_ranger (cfun);
}
bool fold_stmt (gimple_stmt_iterator *gsi) OVERRIDE