21#ifndef _TREE_SSA_THREADUPDATE_H
22#define _TREE_SSA_THREADUPDATE_H 1
95 bool update_cfg (
bool peel_loop_headers)
override;
100 bool may_peel_loop_headers);
116 bool update_cfg (
bool peel_loop_headers)
override;
119 unsigned n_region,
unsigned current_path_no);
129 static hashval_t
hash (
edge e) {
return htab_hash_pointer (e); }
bool duplicate_thread_path(edge entry, edge exit, basic_block *region, unsigned n_region, unsigned current_path_no)
Definition tree-ssa-threadupdate.cc:2387
void adjust_paths_after_duplication(unsigned curr_path_num)
Definition tree-ssa-threadupdate.cc:2290
bool rewire_first_differing_edge(unsigned path_num, unsigned edge_num)
Definition tree-ssa-threadupdate.cc:2244
bool update_cfg(bool peel_loop_headers) override
Definition tree-ssa-threadupdate.cc:2604
back_jt_path_registry()
Definition tree-ssa-threadupdate.cc:194
fwd_jt_path_registry()
Definition tree-ssa-threadupdate.cc:182
~fwd_jt_path_registry()
Definition tree-ssa-threadupdate.cc:189
bool thread_block_1(basic_block, bool noloop_only, bool joiners)
Definition tree-ssa-threadupdate.cc:1422
hash_table< struct removed_edges > * m_removed_edges
Definition tree-ssa-threadupdate.h:103
hash_table< redirection_data > * m_redirection_data
Definition tree-ssa-threadupdate.h:106
class redirection_data * lookup_redirection_data(edge e, enum insert_option)
Definition tree-ssa-threadupdate.cc:456
bool thread_block(basic_block, bool noloop_only)
Definition tree-ssa-threadupdate.cc:1616
bool thread_through_loop_header(class loop *loop, bool may_peel_loop_headers)
Definition tree-ssa-threadupdate.cc:1697
bool update_cfg(bool peel_loop_headers) override
Definition tree-ssa-threadupdate.cc:2660
void mark_threaded_blocks(bitmap threaded_blocks)
Definition tree-ssa-threadupdate.cc:1953
void remove_jump_threads_including(edge)
Definition tree-ssa-threadupdate.cc:2560
Definition hash-table.h:375
unsigned long m_num_threaded_edges
Definition tree-ssa-threadupdate.h:75
bool cancel_invalid_paths(vec< jump_thread_edge * > &path)
Definition tree-ssa-threadupdate.cc:2753
bool thread_through_all_blocks(bool peel_loop_headers)
Definition tree-ssa-threadupdate.cc:2581
jump_thread_path_allocator m_allocator
Definition tree-ssa-threadupdate.h:79
virtual bool update_cfg(bool peel_loop_headers)=0
virtual ~jt_path_registry()
Definition tree-ssa-threadupdate.cc:177
void debug_path(FILE *, int pathno)
Definition tree-ssa-threadupdate.cc:2218
bool m_backedge_threads
Definition tree-ssa-threadupdate.h:82
DISABLE_COPY_AND_ASSIGN(jt_path_registry)
bool register_jump_thread(vec< jump_thread_edge * > *)
Definition tree-ssa-threadupdate.cc:2857
vec< jump_thread_edge * > * allocate_thread_path()
Definition tree-ssa-threadupdate.cc:208
void debug()
Definition tree-ssa-threadupdate.cc:2229
jt_path_registry(bool backedge_threads)
Definition tree-ssa-threadupdate.cc:170
void push_edge(vec< jump_thread_edge * > *path, edge, jump_thread_edge_type)
Definition tree-ssa-threadupdate.cc:200
vec< vec< jump_thread_edge * > * > m_paths
Definition tree-ssa-threadupdate.h:74
Definition tree-ssa-threadupdate.h:36
jump_thread_edge_type type
Definition tree-ssa-threadupdate.h:41
edge e
Definition tree-ssa-threadupdate.h:40
jump_thread_edge(edge e, jump_thread_edge_type t)
Definition tree-ssa-threadupdate.h:38
Definition tree-ssa-threadupdate.h:45
obstack m_obstack
Definition tree-ssa-threadupdate.h:53
jump_thread_edge * allocate_thread_edge(edge, jump_thread_edge_type)
Definition tree-ssa-threadupdate.cc:154
DISABLE_COPY_AND_ASSIGN(jump_thread_path_allocator)
~jump_thread_path_allocator()
Definition tree-ssa-threadupdate.cc:148
jump_thread_path_allocator()
Definition tree-ssa-threadupdate.cc:143
vec< jump_thread_edge * > * allocate_thread_path()
Definition tree-ssa-threadupdate.cc:162
static struct path_prefix cpath path
Definition collect2.cc:514
struct basic_block_def * basic_block
Definition coretypes.h:355
class edge_def * edge
Definition coretypes.h:352
class bitmap_head * bitmap
Definition coretypes.h:51
static struct obstack obstack
Definition gcc.cc:360
Definition hash-traits.h:303
Definition tree-ssa-threadupdate.cc:116
Definition tree-ssa-threadupdate.h:128
static bool equal(edge e1, edge e2)
Definition tree-ssa-threadupdate.h:130
static hashval_t hash(edge e)
Definition tree-ssa-threadupdate.h:129
void free_dom_edge_info(edge)
Definition tree-ssa-dom.cc:400
bb_dom_status
Definition tree-ssa-threadupdate.h:136
@ DOMST_DOMINATING
Definition tree-ssa-threadupdate.h:142
@ DOMST_LOOP_BROKEN
Definition tree-ssa-threadupdate.h:140
@ DOMST_NONDOMINATING
Definition tree-ssa-threadupdate.h:138
jump_thread_edge_type
Definition tree-ssa-threadupdate.h:25
@ EDGE_START_JUMP_THREAD
Definition tree-ssa-threadupdate.h:26
@ EDGE_COPY_SRC_JOINER_BLOCK
Definition tree-ssa-threadupdate.h:28
@ EDGE_NO_COPY_SRC_BLOCK
Definition tree-ssa-threadupdate.h:29
@ EDGE_COPY_SRC_BLOCK
Definition tree-ssa-threadupdate.h:27
enum bb_dom_status determine_bb_domination_status(class loop *, basic_block)
Definition tree-ssa-threadupdate.cc:1639
unsigned int estimate_threading_killed_stmts(basic_block)
Definition tree-ssa-threadupdate.cc:2916