From: Aldy Hernandez Date: Tue, 25 May 2021 15:44:51 +0000 (+0200) Subject: Convert evrp pass to get_range_query. X-Git-Tag: basepoints/gcc-13~7236 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=57bf37515;p=thirdparty%2Fgcc.git Convert evrp pass to get_range_query. gcc/ChangeLog: * gimple-ssa-evrp.c (rvrp_folder::rvrp_folder): Call enable_ranger. (rvrp_folder::~rvrp_folder): Call disable_ranger. (hybrid_folder::hybrid_folder): Call enable_ranger. (hybrid_folder::~hybrid_folder): Call disable_ranger. --- diff --git a/gcc/gimple-ssa-evrp.c b/gcc/gimple-ssa-evrp.c index 829fdcdaef2a..118d10365a00 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