Viewing file: gimple-range.h (2.94 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* Header file for the GIMPLE range interface. Copyright (C) 2019-2022 Free Software Foundation, Inc. Contributed by Andrew MacLeod <amacleod@redhat.com> and Aldy Hernandez <aldyh@redhat.com>.
This file is part of GCC.
GCC is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version.
GCC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with GCC; see the file COPYING3. If not see <http://www.gnu.org/licenses/>. */
#ifndef GCC_GIMPLE_RANGE_H #define GCC_GIMPLE_RANGE_H
#include "range.h" #include "value-query.h" #include "range-op.h" #include "gimple-range-trace.h" #include "gimple-range-edge.h" #include "gimple-range-fold.h" #include "gimple-range-gori.h" #include "gimple-range-cache.h"
// This is the basic range generator interface. // // This base class provides all the API entry points, but only provides // functionality at the statement level. Ie, it can calculate ranges on // statements, but does no additonal lookup. // // All the range_of_* methods will return a range if the types is // supported by the range engine. It may be the full range for the // type, AKA varying_p or it may be a refined range. If the range // type is not supported, then false is returned. Non-statement // related methods return whatever the current global value is.
class gimple_ranger : public range_query { public: gimple_ranger (); ~gimple_ranger (); virtual bool range_of_stmt (irange &r, gimple *, tree name = NULL) OVERRIDE; virtual bool range_of_expr (irange &r, tree name, gimple * = NULL) OVERRIDE; virtual bool range_on_edge (irange &r, edge e, tree name) OVERRIDE; void range_on_entry (irange &r, basic_block bb, tree name); void range_on_exit (irange &r, basic_block bb, tree name); void export_global_ranges (); inline gori_compute &gori () { return m_cache.m_gori; } virtual void dump (FILE *f) OVERRIDE; void debug (); void dump_bb (FILE *f, basic_block bb); auto_edge_flag non_executable_edge_flag; bool fold_stmt (gimple_stmt_iterator *gsi, tree (*) (tree)); void register_side_effects (gimple *s); protected: bool fold_range_internal (irange &r, gimple *s, tree name); void prefill_name (irange &r, tree name); void prefill_stmt_dependencies (tree ssa); ranger_cache m_cache; range_tracer tracer; basic_block current_bb; vec<tree> m_stmt_list; };
/* Create a new ranger instance and associate it with a function. Each call must be paired with a call to disable_ranger to release resources. */ extern gimple_ranger *enable_ranger (struct function *); extern void disable_ranger (struct function *);
#endif // GCC_GIMPLE_RANGE_H
|