GCC Middle and Back End API Reference
pcom_worker Class Reference
Collaboration diagram for pcom_worker:

Public Member Functions

 pcom_worker (loop_p l)
 
 ~pcom_worker ()
 
 pcom_worker (const pcom_worker &)=delete
 
pcom_workeroperator= (const pcom_worker &)=delete
 
unsigned tree_predictive_commoning_loop (bool allow_unroll_p)
 
void execute_pred_commoning (bitmap tmp_vars)
 

Private Types

typedef hash_map< tree, name_expansion * > tree_expand_map_t
 

Private Member Functions

struct componentsplit_data_refs_to_components ()
 
struct componentfilter_suitable_components (struct component *comps)
 
void determine_roots (struct component *comps)
 
void prepare_initializers ()
 
bool prepare_finalizers ()
 
void try_combine_chains ()
 
void release_chains ()
 
void release_chain (chain_p chain)
 
bool prepare_initializers_chain (chain_p chain)
 
bool prepare_finalizers_chain (chain_p chain)
 
void aff_combination_dr_offset (struct data_reference *dr, aff_tree *offset)
 
bool determine_offset (struct data_reference *a, struct data_reference *b, poly_widest_int *off)
 
bool suitable_component_p (struct component *comp)
 
bool valid_initializer_p (struct data_reference *ref, unsigned distance, struct data_reference *root)
 
gphifind_looparound_phi (dref ref, dref root)
 
void determine_roots_comp (struct component *comp)
 
void add_looparound_copies (chain_p chain)
 
gimplesingle_nonlooparound_use (tree name)
 
void remove_stmt (gimple *stmt)
 
void execute_pred_commoning_chain (chain_p chain, bitmap tmp_vars)
 
gimplefind_use_stmt (tree *name)
 
gimplefind_associative_operation_root (gimple *stmt, unsigned *distance)
 
gimplefind_common_use_stmt (tree *name1, tree *name2)
 
bool combinable_refs_p (dref r1, dref r2, enum tree_code *code, bool *swap, tree *rslt_type)
 
gimplereassociate_to_the_same_stmt (tree name1, tree name2)
 
gimplestmt_combining_refs (dref r1, dref r2)
 
chain_p combine_chains (chain_p ch1, chain_p ch2)
 

Private Attributes

loop_p m_loop
 
auto_vec< data_reference_p, 10 > m_datarefs
 
auto_vec< ddr_p, 10 > m_dependences
 
auto_vec< chain_pm_chains
 
auto_bitmap m_looparound_phis
 
tree_expand_map_tm_cache
 

Detailed Description

A class to encapsulate the global states used for predictive
commoning work on top of one given LOOP.   

Member Typedef Documentation

◆ tree_expand_map_t

Constructor & Destructor Documentation

◆ pcom_worker() [1/2]

pcom_worker::pcom_worker ( loop_p l)
inline

◆ ~pcom_worker()

◆ pcom_worker() [2/2]

pcom_worker::pcom_worker ( const pcom_worker & )
delete

Member Function Documentation

◆ add_looparound_copies()

void pcom_worker::add_looparound_copies ( chain_p chain)
private
For references in CHAIN that are copied around the loop (created previously
by PRE, or by user), add the results of such copies to the chain.  This
enables us to remove the copies by unrolling, and may need less registers
(also, it may allow us to combine chains together).   

References bitmap_set_bit, CT_STORE_STORE, find_looparound_phi(), FOR_EACH_VEC_ELT, get_chain_root(), i, insert_looparound_copy(), m_looparound_phis, PHI_RESULT, chain::refs, SSA_NAME_VERSION, and chain::type.

Referenced by determine_roots_comp().

◆ aff_combination_dr_offset()

void pcom_worker::aff_combination_dr_offset ( struct data_reference * dr,
aff_tree * offset )
private

◆ combinable_refs_p()

bool pcom_worker::combinable_refs_p ( dref r1,
dref r2,
enum tree_code * code,
bool * swap,
tree * rslt_type )
private
Checks whether R1 and R2 are combined together using CODE, with the result
in RSLT_TYPE, in order R1 CODE R2 if SWAP is false and in order R2 CODE R1
if it is true.  If CODE is ERROR_MARK, set these values instead.   

References commutative_tree_code(), find_common_use_stmt(), gcc_assert, gimple_assign_lhs(), gimple_assign_rhs1(), gimple_assign_rhs_code(), gimple_bb(), name_for_ref(), NULL_TREE, and TREE_TYPE.

Referenced by combine_chains().

◆ combine_chains()

chain_p pcom_worker::combine_chains ( chain_p ch1,
chain_p ch2 )
private
Tries to combine chains CH1 and CH2 together.  If this succeeds, the
description of the new chain is returned, otherwise we return NULL.   

References chain::ch1, chain::ch2, combinable_refs_p(), chain::combined, i, chain::length, NULL, NULL_TREE, chain::op, chain::refs, and chain::rslt_type.

Referenced by try_combine_chains().

◆ determine_offset()

bool pcom_worker::determine_offset ( struct data_reference * a,
struct data_reference * b,
poly_widest_int * off )
private
Determines number of iterations of the innermost enclosing loop before B
refers to exactly the same location as A and stores it to OFF.  If A and
B do not have the same step, they never meet, or anything else fails,
returns false, otherwise returns true.  Both A and B are assumed to
satisfy suitable_reference_p.   

References a, aff_combination_add(), aff_combination_constant_multiple_p(), aff_combination_dr_offset(), aff_combination_scale(), b, DR_BASE_ADDRESS, DR_INIT, DR_OFFSET, DR_REF, DR_STEP, integer_zerop(), m_cache, operand_equal_p(), tree_to_aff_combination_expand(), TREE_TYPE, and useless_type_conversion_p().

Referenced by split_data_refs_to_components(), and suitable_component_p().

◆ determine_roots()

void pcom_worker::determine_roots ( struct component * comps)
private
Find roots of the values and determine distances in components COMPS, and
separates the references to chains.   

References comp, and determine_roots_comp().

Referenced by tree_predictive_commoning_loop().

◆ determine_roots_comp()

void pcom_worker::determine_roots_comp ( struct component * comp)
private
Find roots of the values and determine distances in the component COMP.
The references are redistributed into chains.   

References a, add_looparound_copies(), add_ref_to_chain(), comp, CT_LOAD, CT_STORE_LOAD, DR_IS_READ, DR_IS_WRITE, FOR_EACH_VEC_ELT, free(), i, wi::leu_p(), m_chains, make_invariant_chain(), make_rooted_chain(), MAX_DISTANCE, nontrivial_chain_p(), NULL, order_drefs(), release_chain(), RS_INVARIANT, chain::type, and type().

Referenced by determine_roots().

◆ execute_pred_commoning()

void pcom_worker::execute_pred_commoning ( bitmap tmp_vars)
Perform the predictive commoning optimization for chains.
Uids of the newly created temporary variables are marked in TMP_VARS.   

References a, chain::combined, CT_INVARIANT, execute_load_motion(), execute_pred_commoning_chain(), FOR_EACH_VEC_ELT, i, m_chains, m_loop, chain::refs, remove_stmt(), and chain::type.

Referenced by execute_pred_commoning_cbck(), and tree_predictive_commoning_loop().

◆ execute_pred_commoning_chain()

void pcom_worker::execute_pred_commoning_chain ( chain_p chain,
bitmap tmp_vars )
private

◆ filter_suitable_components()

struct component * pcom_worker::filter_suitable_components ( struct component * comps)
private
Check the conditions on references inside each of components COMPS,
and remove the unsuitable components from the list.  The new list
of components is returned.  The conditions are described in 2) at
the beginning of this file.   

References comp, FOR_EACH_VEC_ELT, free(), i, component::next, component::refs, and suitable_component_p().

Referenced by tree_predictive_commoning_loop().

◆ find_associative_operation_root()

gimple * pcom_worker::find_associative_operation_root ( gimple * stmt,
unsigned * distance )
private
If the operation used in STMT is associative and commutative, go through the
tree of the same operations and returns its root.  Distance to the root
is stored in DISTANCE.   

References find_use_stmt(), gcc_assert, gimple_assign_lhs(), gimple_assign_rhs_code(), may_reassociate_p(), NULL, TREE_CODE, and TREE_TYPE.

Referenced by find_common_use_stmt(), and reassociate_to_the_same_stmt().

◆ find_common_use_stmt()

gimple * pcom_worker::find_common_use_stmt ( tree * name1,
tree * name2 )
private
Returns the common statement in that NAME1 and NAME2 have a use.  If there
is no such statement, returns NULL_TREE.  In case the operation used on
NAME1 and NAME2 is associative and commutative, returns the root of the
tree formed by this operation instead of the statement that uses NAME1 or
NAME2.   

References find_associative_operation_root(), find_use_stmt(), and NULL.

Referenced by combinable_refs_p().

◆ find_looparound_phi()

gphi * pcom_worker::find_looparound_phi ( dref ref,
dref root )
private
Finds looparound phi node of loop that copies the value of REF, and if its
initial value is correct (equal to initial value of REF shifted by one
iteration), returns the phi node.  Otherwise, NULL_TREE is returned.  ROOT
is the root of the current chain.   

References ao_ref_init(), DECL_P, dr_analyze_innermost(), DR_INNERMOST, DR_IS_READ, DR_REF, DR_STMT, gcc_assert, gimple_assign_lhs(), gimple_assign_rhs1(), gimple_phi_result(), gimple_vuse(), gsi_end_p(), gsi_next(), gsi_start_phis(), is_gimple_assign(), loop_latch_edge(), loop_preheader_edge(), m_loop, NULL, NULL_TREE, PHI_ARG_DEF_FROM_EDGE, PHI_RESULT, data_reference::ref, REFERENCE_CLASS_P, SSA_NAME_DEF_STMT, stmt_may_clobber_ref_p_1(), TREE_CODE, valid_initializer_p(), and virtual_operand_p().

Referenced by add_looparound_copies().

◆ find_use_stmt()

gimple * pcom_worker::find_use_stmt ( tree * name)
private
Returns the modify statement that uses NAME.  Skips over assignment
statements, NAME is replaced with the actual name used in the returned
statement.   

References get_gimple_rhs_class(), gimple_assign_copy_p(), gimple_assign_lhs(), gimple_assign_rhs1(), gimple_assign_rhs_code(), GIMPLE_BINARY_RHS, NULL, single_nonlooparound_use(), and TREE_CODE.

Referenced by find_associative_operation_root(), find_common_use_stmt(), reassociate_to_the_same_stmt(), and stmt_combining_refs().

◆ operator=()

pcom_worker & pcom_worker::operator= ( const pcom_worker & )
delete

◆ prepare_finalizers()

bool pcom_worker::prepare_finalizers ( )
private
Generates finalizer memory reference for chains.  Returns true if
finalizer code generation for chains breaks loop closed ssa form.   

References CT_STORE_STORE, i, chain::length, m_chains, prepare_finalizers_chain(), release_chain(), and chain::type.

Referenced by tree_predictive_commoning_loop().

◆ prepare_finalizers_chain()

bool pcom_worker::prepare_finalizers_chain ( chain_p chain)
private
Generates finalizer memory references for CHAIN.  Returns true
if finalizer code for CHAIN can be generated, otherwise false.   

References chain::all_always_accessed, chain::fini_seq, chain::finis, force_gimple_operand(), gcc_assert, get_chain_root(), gimple_seq_add_seq_without_update(), i, chain::length, m_loop, NULL, NULL_TREE, number_of_latch_executions(), data_reference::ref, ref_at_iteration(), TREE_CODE, and unshare_expr().

Referenced by prepare_finalizers().

◆ prepare_initializers()

void pcom_worker::prepare_initializers ( )
private
Prepare initializers for chains, and free chains that cannot
be used because the initializers might trap.   

References i, m_chains, prepare_initializers_chain(), and release_chain().

Referenced by tree_predictive_commoning_loop().

◆ prepare_initializers_chain()

◆ reassociate_to_the_same_stmt()

gimple * pcom_worker::reassociate_to_the_same_stmt ( tree name1,
tree name2 )
private

◆ release_chain()

void pcom_worker::release_chain ( chain_p chain)
private

◆ release_chains()

void pcom_worker::release_chains ( )
private
Frees CHAINS.   

References FOR_EACH_VEC_ELT, i, m_chains, and release_chain().

Referenced by ~pcom_worker().

◆ remove_stmt()

◆ single_nonlooparound_use()

gimple * pcom_worker::single_nonlooparound_use ( tree name)
private
Returns the single statement in that NAME is used, excepting
the looparound phi nodes contained in one of the chains.  If there is no
such statement, or more statements, NULL is returned.   

References bitmap_bit_p, FOR_EACH_IMM_USE_FAST, is_gimple_debug(), m_looparound_phis, NULL, PHI_RESULT, SSA_NAME_VERSION, and USE_STMT.

Referenced by find_use_stmt(), and remove_stmt().

◆ split_data_refs_to_components()

◆ stmt_combining_refs()

gimple * pcom_worker::stmt_combining_refs ( dref r1,
dref r2 )
private
Returns the statement that combines references R1 and R2.  In case R1
and R2 are not used in the same statement, but they are used with an
associative and commutative operation in the same expression, reassociate
the expression so that they are used in the same statement.   

References find_use_stmt(), name_for_ref(), and reassociate_to_the_same_stmt().

◆ suitable_component_p()

bool pcom_worker::suitable_component_p ( struct component * comp)
private

◆ tree_predictive_commoning_loop()

◆ try_combine_chains()

◆ valid_initializer_p()

bool pcom_worker::valid_initializer_p ( struct data_reference * ref,
unsigned distance,
struct data_reference * root )
private
Returns true if REF is a valid initializer for ROOT with given DISTANCE (in
iterations of the innermost enclosing loop).   

References aff_combination_add(), aff_combination_constant_multiple_p(), aff_combination_dr_offset(), aff_combination_scale(), DR_BASE_ADDRESS, DR_INIT, DR_OFFSET, DR_STEP, gcc_assert, integer_zerop(), m_cache, operand_equal_p(), tree_to_aff_combination_expand(), and TREE_TYPE.

Referenced by find_looparound_phi().

Field Documentation

◆ m_cache

◆ m_chains

◆ m_datarefs

◆ m_dependences

auto_vec<ddr_p, 10> pcom_worker::m_dependences
private

◆ m_loop

◆ m_looparound_phis

auto_bitmap pcom_worker::m_looparound_phis
private

The documentation for this class was generated from the following file: