C-Breeze
C Compiler Infrastructure

[ Project home page]
Main Page   Modules   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Namespace Members   Compound Members   File Members   Related Pages  

copyPropChanger Class Reference
[phases defined in c-breeze (some of which are available from the command line).]

Performs global (intraprocedural) copy propagation. More...

#include <copyprop.h>

Inheritance diagram for copyPropChanger:

Changer List of all members.

Public Types

typedef set< threeAddrNode * > threeAddr_set
typedef threeAddr_set::iterator threeAddr_set_p
typedef set< declNode * > decl_set
typedef decl_set::iterator decl_set_p
enum  Order { Preorder, Postorder, Both }
enum  Depth { Subtree, NodeOnly }

Public Member Functions

Accessors
Methods to get and set fields in the class.

Order order () const
 Return the order in which Nodes of an AST should be visited.

Depth depth () const
 Return which Nodes of an AST should be visited.

bool delete_old () const
 Return whether this Changer deletes Nodes which are removed from the AST by "at_" methods.

"at_" methods
These methods define the functions that should be performed when different classes of Nodes are encountered in the AST. The most specific "at_" method that matches a given Node's class will be called.

virtual Nodeat_node (Node *the_node, Order ord)
virtual Nodeat_unit (unitNode *the_unit, Order ord)
virtual Nodeat_def (defNode *the_def, Order ord)
virtual Nodeat_decl (declNode *the_decl, Order ord)
virtual Nodeat_subdecl (subdeclNode *the_subdecl, Order ord)
virtual Nodeat_type (typeNode *the_type, Order ord)
virtual Nodeat_prim (primNode *the_prim, Order ord)
virtual Nodeat_tdef (tdefNode *the_tdef, Order ord)
virtual Nodeat_ptr (ptrNode *the_ptr, Order ord)
virtual Nodeat_array (arrayNode *the_array, Order ord)
virtual Nodeat_func (funcNode *the_func, Order ord)
virtual Nodeat_sue (sueNode *the_sue, Order ord)
virtual Nodeat_struct (structNode *the_struct, Order ord)
virtual Nodeat_union (unionNode *the_union, Order ord)
virtual Nodeat_enum (enumNode *the_enum, Order ord)
virtual Nodeat_suespec (suespecNode *the_suespec, Order ord)
virtual Nodeat_expr (exprNode *the_expr, Order ord)
virtual Nodeat_index (indexNode *the_index, Order ord)
virtual Nodeat_const (constNode *the_const, Order ord)
virtual Nodeat_id (idNode *the_id, Order ord)
virtual Nodeat_binary (binaryNode *the_binary, Order ord)
virtual Nodeat_unary (unaryNode *the_unary, Order ord)
virtual Nodeat_cast (castNode *the_cast, Order ord)
virtual Nodeat_comma (commaNode *the_comma, Order ord)
virtual Nodeat_ternary (ternaryNode *the_ternary, Order ord)
virtual Nodeat_call (callNode *the_call, Order ord)
virtual Nodeat_initializer (initializerNode *the_initializer, Order ord)
virtual Nodeat_stmt (stmtNode *the_stmt, Order ord)
virtual Nodeat_block (blockNode *the_block, Order ord)
virtual Nodeat_basicblock (basicblockNode *the_basicblock, Order ord)
virtual Nodeat_exprstmt (exprstmtNode *the_exprstmt, Order ord)
virtual Nodeat_target (targetNode *the_target, Order ord)
virtual Nodeat_label (labelNode *the_label, Order ord)
virtual Nodeat_case (caseNode *the_case, Order ord)
virtual Nodeat_selection (selectionNode *the_selection, Order ord)
virtual Nodeat_if (ifNode *the_if, Order ord)
virtual Nodeat_switch (switchNode *the_switch, Order ord)
virtual Nodeat_loop (loopNode *the_loop, Order ord)
virtual Nodeat_while (whileNode *the_while, Order ord)
virtual Nodeat_do (doNode *the_do, Order ord)
virtual Nodeat_for (forNode *the_for, Order ord)
virtual Nodeat_jump (jumpNode *the_jump, Order ord)
virtual Nodeat_goto (gotoNode *the_goto, Order ord)
virtual Nodeat_continue (continueNode *the_continue, Order ord)
virtual Nodeat_break (breakNode *the_break, Order ord)
virtual Nodeat_return (returnNode *the_return, Order ord)
virtual Nodeat_attrib (attribNode *the_attrib, Order ord)
virtual Nodeat_operand (operandNode *the_oper, Order ord)
virtual Nodeat_conditiongoto (conditiongotoNode *the_condgoto, Order ord)
virtual Nodeat_threeAddr (threeAddrNode *the_3addr, Order ord)
virtual Nodeat_text (textNode *the_text, Order ord)

Static Public Member Functions

void change ()
 Copy propagation on entire program.

void change (unitNode *)
 Copy propagation on one unit.

void change (procNode *)
 Copy propagation on one procedure.


Private Types

typedef pair< declNode *,
declNode * > 
Var_pair
typedef set< Var_pairACP

Private Member Functions

 copyPropChanger ()
 Constructor.

Nodeat_proc (procNode *, Order ord)
copyFlowValcreate_copy_set (basicblockNode *)
copyFlowValcreate_kill_set (basicblockNode *, stmt_list)
void solve_global_dataflow (stmt_list)
void local_copy_prop (basicblockNode *)
void copy_value (operandNode *opnd, const ACP &acp)
idNodecopy_value (idNode *opnd, const ACP &acp)

Static Private Member Functions

void remove_ACP (ACP &acp, declNode *v)

Private Attributes

threeAddr_set copies
threeAddr_set ambiguous
map< threeAddrNode *, declNode * > defines
copyFlowVal_top
copyFlowVal_bottom
map< basicblockNode *, copyFlowVal * > Gen
map< basicblockNode *, copyFlowVal * > Kill
map< basicblockNode *, copyFlowVal * > In
map< basicblockNode *, copyFlowVal * > Out

Detailed Description

Performs global (intraprocedural) copy propagation.

This class performs the constant propagation. The program must already be cfg'd. The three public static change() functions allow the optimization to be performed on the entire program, on one unit, or on a single procedure. The algorithm used is adopted from Muchnick chapter 12.5. Note that copy statements with casts are ignored. Also, the algorithm itself has limitation. For example.

      if(..)
        x = y;
      else
        x = y;
      z = x;   // <-- x not replaced by y.
    
To handle this case is left as future work.

Definition at line 64 of file copyprop.h.


Member Typedef Documentation

typedef set<Var_pair> copyPropChanger::ACP [private]
 

Definition at line 115 of file copyprop.h.

Referenced by local_copy_prop().

typedef set<declNode*> copyPropChanger::decl_set
 

Definition at line 68 of file copyprop.h.

Referenced by copy_value(), copyFlowVal::copyFlowVal(), and create_kill_set().

typedef decl_set::iterator copyPropChanger::decl_set_p
 

Definition at line 69 of file copyprop.h.

Referenced by copy_value(), and copyFlowVal::copyFlowVal().

typedef set<threeAddrNode*> copyPropChanger::threeAddr_set
 

Definition at line 66 of file copyprop.h.

Referenced by create_copy_set(), create_kill_set(), local_copy_prop(), and copyFlowVal::stmts().

typedef threeAddr_set::iterator copyPropChanger::threeAddr_set_p
 

Definition at line 67 of file copyprop.h.

Referenced by copyFlowVal::clear_dummies(), copyFlowVal::copyFlowVal(), create_copy_set(), create_kill_set(), and local_copy_prop().

typedef pair<declNode*,declNode*> copyPropChanger::Var_pair [private]
 

Definition at line 114 of file copyprop.h.

Referenced by local_copy_prop(), and remove_ACP().


Member Enumeration Documentation

enum Changer::Depth [inherited]
 

Enumeration values:
Subtree 
NodeOnly 

Definition at line 148 of file changer.h.

enum Changer::Order [inherited]
 

Enumeration values:
Preorder 
Postorder 
Both 

Definition at line 147 of file changer.h.

Referenced by whileNode::change(), unitNode::change(), unionNode::change(), unaryNode::change(), threeAddrNode::change(), textNode::change(), ternaryNode::change(), tdefNode::change(), switchNode::change(), suespecNode::change(), subdeclNode::change(), structNode::change(), returnNode::change(), ptrNode::change(), procNode::change(), primNode::change(), operandNode::change(), metastmtNode::change(), metaexprNode::change(), labelNode::change(), initializerNode::change(), ifNode::change(), idNode::change(), gotoNode::change(), funcNode::change(), forNode::change(), exprstmtNode::change(), enumNode::change(), doNode::change(), declNode::change(), continueNode::change(), constNode::change(), conditiongotoNode::change(), commaNode::change(), castNode::change(), caseNode::change(), callNode::change(), breakNode::change(), blockNode::change(), binaryNode::change(), basicblockNode::change(), attribNode::change(), and arrayNode::change().


Constructor & Destructor Documentation

copyPropChanger::copyPropChanger   [inline, private]
 

Constructor.

Definition at line 83 of file copyprop.h.

References Changer::Preorder, and Changer::Subtree.


Member Function Documentation

virtual Node* Changer::at_array arrayNode   the_array,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in AllocSizeChanger.

Definition at line 253 of file changer.h.

References Changer::at_type().

Referenced by arrayNode::change().

virtual Node* Changer::at_attrib attribNode   the_attrib,
Order    ord
[inline, virtual, inherited]
 

Definition at line 364 of file changer.h.

References Changer::at_stmt().

Referenced by attribNode::change().

virtual Node* Changer::at_basicblock basicblockNode   the_basicblock,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in constantFoldingChanger.

Definition at line 313 of file changer.h.

References Changer::at_block().

Referenced by basicblockNode::change().

virtual Node* Changer::at_binary binaryNode   the_binary,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in SelectionDismantle, ArrowDismantle, and ExpressionDismantle.

Definition at line 286 of file changer.h.

References Changer::at_expr().

Referenced by binaryNode::change().

virtual Node* Changer::at_block blockNode   the_block,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in StaticToGlobalDismantle, and InitializerDismantle.

Definition at line 310 of file changer.h.

References Changer::at_stmt().

Referenced by Changer::at_basicblock(), and blockNode::change().

virtual Node* Changer::at_break breakNode   the_break,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in BreakContinueChanger.

Definition at line 358 of file changer.h.

References Changer::at_jump().

Referenced by breakNode::change().

virtual Node* Changer::at_call callNode   the_call,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in ExpressionDismantle.

Definition at line 301 of file changer.h.

References Changer::at_expr().

Referenced by callNode::change().

virtual Node* Changer::at_case caseNode   the_case,
Order    ord
[inline, virtual, inherited]
 

Definition at line 325 of file changer.h.

References Changer::at_target().

Referenced by caseNode::change().

virtual Node* Changer::at_cast castNode   the_cast,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in ExpressionDismantle, and CastRemover.

Definition at line 292 of file changer.h.

References Changer::at_expr().

Referenced by castNode::change().

virtual Node* Changer::at_comma commaNode   the_comma,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in ExpressionDismantle.

Definition at line 295 of file changer.h.

References Changer::at_expr().

Referenced by commaNode::change().

virtual Node* Changer::at_conditiongoto conditiongotoNode   the_condgoto,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in constantPropChanger, constantFoldingChanger, and constantsChanger.

Definition at line 370 of file changer.h.

References Changer::at_goto().

Referenced by conditiongotoNode::change().

virtual Node* Changer::at_const constNode   the_const,
Order    ord
[inline, virtual, inherited]
 

Definition at line 280 of file changer.h.

References Changer::at_index().

Referenced by constNode::change().

virtual Node* Changer::at_continue continueNode   the_continue,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in BreakContinueChanger.

Definition at line 355 of file changer.h.

References Changer::at_jump().

Referenced by continueNode::change().

virtual Node* Changer::at_decl declNode   the_decl,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in AllocSizeChanger, StaticToGlobalDismantle, InitializerDismantle, FlattenDismantle, ref_clone_changer, and TreeFixer.

Definition at line 232 of file changer.h.

References Changer::at_def().

Referenced by Changer::at_subdecl(), and declNode::change().

virtual Node* Changer::at_def defNode   the_def,
Order    ord
[inline, virtual, inherited]
 

Definition at line 229 of file changer.h.

References Changer::at_node().

Referenced by Changer::at_decl(), and Changer::at_proc().

virtual Node* Changer::at_do doNode   the_do,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in LoopDismantle.

Definition at line 343 of file changer.h.

References Changer::at_loop().

Referenced by doNode::change().

virtual Node* Changer::at_enum enumNode   the_enum,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in AllocSizeChanger.

Definition at line 268 of file changer.h.

References Changer::at_sue().

Referenced by enumNode::change().

virtual Node* Changer::at_expr exprNode   the_expr,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in ipConstantsChanger.

Definition at line 274 of file changer.h.

References Changer::at_node().

Referenced by Changer::at_binary(), Changer::at_call(), Changer::at_cast(), Changer::at_comma(), Changer::at_index(), Changer::at_initializer(), Changer::at_operand(), Changer::at_ternary(), Changer::at_unary(), and metaexprNode::change().

virtual Node* Changer::at_exprstmt exprstmtNode   the_exprstmt,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in SelectionDismantle, ExpressionDismantle, and FlattenDismantle.

Definition at line 316 of file changer.h.

References Changer::at_stmt().

Referenced by exprstmtNode::change().

virtual Node* Changer::at_for forNode   the_for,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in LoopDismantle.

Definition at line 346 of file changer.h.

References Changer::at_loop().

Referenced by forNode::change().

virtual Node* Changer::at_func funcNode   the_func,
Order    ord
[inline, virtual, inherited]
 

Definition at line 256 of file changer.h.

References Changer::at_type().

Referenced by funcNode::change().

virtual Node* Changer::at_goto gotoNode   the_goto,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in FlattenDismantle.

Definition at line 352 of file changer.h.

References Changer::at_jump().

Referenced by Changer::at_conditiongoto(), and gotoNode::change().

virtual Node* Changer::at_id idNode   the_id,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in UnusedDeclarationCleanupChanger, and constantsChanger.

Definition at line 283 of file changer.h.

References Changer::at_index().

Referenced by idNode::change().

virtual Node* Changer::at_if ifNode   the_if,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in SelectionDismantle, and CFS_Changer.

Definition at line 331 of file changer.h.

References Changer::at_selection().

Referenced by ifNode::change().

virtual Node* Changer::at_index indexNode   the_index,
Order    ord
[inline, virtual, inherited]
 

Definition at line 277 of file changer.h.

References Changer::at_expr().

Referenced by Changer::at_const(), and Changer::at_id().

virtual Node* Changer::at_initializer initializerNode   the_initializer,
Order    ord
[inline, virtual, inherited]
 

Definition at line 304 of file changer.h.

References Changer::at_expr().

Referenced by initializerNode::change().

virtual Node* Changer::at_jump jumpNode   the_jump,
Order    ord
[inline, virtual, inherited]
 

Definition at line 349 of file changer.h.

References Changer::at_stmt().

Referenced by Changer::at_break(), Changer::at_continue(), Changer::at_goto(), and Changer::at_return().

virtual Node* Changer::at_label labelNode   the_label,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in LabelDismantle, FlattenDismantle, and ref_clone_changer.

Definition at line 322 of file changer.h.

References Changer::at_target().

Referenced by labelNode::change().

virtual Node* Changer::at_loop loopNode   the_loop,
Order    ord
[inline, virtual, inherited]
 

Definition at line 337 of file changer.h.

References Changer::at_stmt().

Referenced by Changer::at_do(), Changer::at_for(), and Changer::at_while().

virtual Node* Changer::at_node Node   the_node,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in ref_clone_changer.

Definition at line 223 of file changer.h.

Referenced by Changer::at_def(), Changer::at_expr(), Changer::at_stmt(), Changer::at_text(), Changer::at_type(), and Changer::at_unit().

virtual Node* Changer::at_operand operandNode   the_oper,
Order    ord
[inline, virtual, inherited]
 

Definition at line 367 of file changer.h.

References Changer::at_expr().

Referenced by operandNode::change().

virtual Node* Changer::at_prim primNode   the_prim,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in AllocSizeChanger.

Definition at line 244 of file changer.h.

References Changer::at_type().

Referenced by primNode::change().

Node * copyPropChanger::at_proc procNode  ,
Order    ord
[private, virtual]
 

Reimplemented from Changer.

Definition at line 215 of file copyprop.cc.

References _bottom, _top, ambiguous, Block, procNode::body(), copyFlowVal::clone(), stmtNode::comment(), copies, create_copy_set(), create_kill_set(), defines, Gen, In, Kill, Label, local_copy_prop(), Out, solve_global_dataflow(), stmt_list, stmt_list_p, blockNode::stmts(), basicblockNode::succs(), copyFlowVal::to_bottom(), and procNode::walk().

virtual Node* Changer::at_ptr ptrNode   the_ptr,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in AllocSizeChanger.

Definition at line 250 of file changer.h.

References Changer::at_type().

Referenced by ptrNode::change().

virtual Node* Changer::at_return returnNode   the_return,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in SelectionDismantle, ReturnDismantle, FlattenDismantle, and constantPropChanger.

Definition at line 361 of file changer.h.

References Changer::at_jump().

Referenced by returnNode::change().

virtual Node* Changer::at_selection selectionNode   the_selection,
Order    ord
[inline, virtual, inherited]
 

Definition at line 328 of file changer.h.

References Changer::at_stmt().

Referenced by Changer::at_if(), and Changer::at_switch().

virtual Node* Changer::at_stmt stmtNode   the_stmt,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in TernaryDismantle, and SelectionDismantle.

Definition at line 307 of file changer.h.

References Changer::at_node().

Referenced by Changer::at_attrib(), Changer::at_block(), Changer::at_exprstmt(), Changer::at_jump(), Changer::at_loop(), Changer::at_selection(), Changer::at_target(), Changer::at_threeAddr(), and metastmtNode::change().

virtual Node* Changer::at_struct structNode   the_struct,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in AllocSizeChanger.

Definition at line 262 of file changer.h.

References Changer::at_sue().

Referenced by structNode::change().

virtual Node* Changer::at_subdecl subdeclNode   the_subdecl,
Order    ord
[inline, virtual, inherited]
 

Definition at line 235 of file changer.h.

References Changer::at_decl().

Referenced by subdeclNode::change().

virtual Node* Changer::at_sue sueNode   the_sue,
Order    ord
[inline, virtual, inherited]
 

Definition at line 259 of file changer.h.

References Changer::at_type().

Referenced by Changer::at_enum(), Changer::at_struct(), and Changer::at_union().

virtual Node* Changer::at_suespec suespecNode   the_suespec,
Order    ord
[inline, virtual, inherited]
 

Definition at line 271 of file changer.h.

References Changer::at_type().

Referenced by suespecNode::change().

virtual Node* Changer::at_switch switchNode   the_switch,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in SelectionDismantle, and ref_clone_changer.

Definition at line 334 of file changer.h.

References Changer::at_selection().

Referenced by switchNode::change().

virtual Node* Changer::at_target targetNode   the_target,
Order    ord
[inline, virtual, inherited]
 

Definition at line 319 of file changer.h.

References Changer::at_stmt().

Referenced by Changer::at_case(), and Changer::at_label().

virtual Node* Changer::at_tdef tdefNode   the_tdef,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in AllocSizeChanger, and UpdateTdefChanger.

Definition at line 247 of file changer.h.

References Changer::at_type().

Referenced by tdefNode::change().

virtual Node* Changer::at_ternary ternaryNode   the_ternary,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in TernaryDismantle.

Definition at line 298 of file changer.h.

References Changer::at_expr().

Referenced by ternaryNode::change().

virtual Node* Changer::at_text textNode   the_text,
Order    ord
[inline, virtual, inherited]
 

Definition at line 376 of file changer.h.

References Changer::at_node().

Referenced by textNode::change().

virtual Node* Changer::at_threeAddr threeAddrNode   the_3addr,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in SizeofChanger, FlattenDismantle, function_inline, constantPropChanger, constantFoldingChanger, deadCodeEliminationChanger, constantsChanger, and deadcodeChanger.

Definition at line 373 of file changer.h.

References Changer::at_stmt().

Referenced by threeAddrNode::change().

virtual Node* Changer::at_type typeNode   the_type,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in TernaryDismantle, and ExpressionDismantle.

Definition at line 241 of file changer.h.

References Changer::at_node().

Referenced by Changer::at_array(), Changer::at_func(), Changer::at_prim(), Changer::at_ptr(), Changer::at_sue(), Changer::at_suespec(), and Changer::at_tdef().

virtual Node* Changer::at_unary unaryNode   the_unary,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in AllocSizeChanger, and ExpressionDismantle.

Definition at line 289 of file changer.h.

References Changer::at_expr().

Referenced by unaryNode::change().

virtual Node* Changer::at_union unionNode   the_union,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in AllocSizeChanger.

Definition at line 265 of file changer.h.

References Changer::at_sue().

Referenced by unionNode::change().

virtual Node* Changer::at_unit unitNode   the_unit,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in Dismantle, StaticToGlobalDismantle, and Optimizer.

Definition at line 226 of file changer.h.

References Changer::at_node().

Referenced by unitNode::change().

virtual Node* Changer::at_while whileNode   the_while,
Order    ord
[inline, virtual, inherited]
 

Reimplemented in LoopDismantle.

Definition at line 340 of file changer.h.

References Changer::at_loop().

Referenced by whileNode::change().

void copyPropChanger::change procNode   [static]
 

Copy propagation on one procedure.

Definition at line 557 of file copyprop.cc.

References procNode::change().

void copyPropChanger::change unitNode   [static]
 

Copy propagation on one unit.

Definition at line 551 of file copyprop.cc.

References change(), def_list_p, unitNode::defs(), and Proc.

void copyPropChanger::change   [static]
 

Copy propagation on entire program.

Definition at line 545 of file copyprop.cc.

References CBZ::Program, and unit_list_p.

Referenced by change(), and copypropphase::run().

idNode * copyPropChanger::copy_value idNode   opnd,
const ACP   acp
[private]
 

Definition at line 519 of file copyprop.cc.

References idNode::decl(), decl_set, and decl_set_p.

void copyPropChanger::copy_value operandNode   opnd,
const ACP   acp
[private]
 

Definition at line 503 of file copyprop.cc.

References operandNode::addr(), Id, operandNode::index(), LirUtil::new_id(), and operandNode::var().

Referenced by local_copy_prop().

copyPropChanger::copyFlowVal * copyPropChanger::create_copy_set basicblockNode   [private]
 

Definition at line 296 of file copyprop.cc.

References _top, ambiguous, copyFlowVal::clone(), copies, idNode::decl(), defines, copyFlowVal::insert(), stmt_list_p, blockNode::stmts(), ThreeAddr, threeAddr_set, and threeAddr_set_p.

Referenced by at_proc().

copyPropChanger::copyFlowVal * copyPropChanger::create_kill_set basicblockNode  ,
stmt_list   
[private]
 

Definition at line 333 of file copyprop.cc.

References _bottom, _top, ambiguous, copyFlowVal::clone(), decl_set, defines, Gen, copyFlowVal::insert(), stmt_list_p, blockNode::stmts(), ThreeAddr, threeAddr_set, and threeAddr_set_p.

Referenced by at_proc().

bool Changer::delete_old   const [inline, inherited]
 

Return whether this Changer deletes Nodes which are removed from the AST by "at_" methods.

Definition at line 209 of file changer.h.

Referenced by subdeclNode::change(), change_list(), and Changer::Changer().

Depth Changer::depth   const [inline, inherited]
 

Return which Nodes of an AST should be visited.

A value of SubTree specifies that the entire AST should be traversed. A value of NodeOnly specifies that only the root Node in the AST should be visited.

Definition at line 204 of file changer.h.

void copyPropChanger::local_copy_prop basicblockNode   [private]
 

Definition at line 411 of file copyprop.cc.

References ACP, ambiguous, threeAddrNode::arg_list(), Condition, copies, copy_value(), Expr, returnNode::expr(), operandNode::fields(), Goto, Id, In, operandNode::index(), Label, conditiongotoNode::left(), threeAddrNode::lhs(), LirUtil::new_id(), operand_list_p, remove_ACP(), Return, threeAddrNode::rhs1(), threeAddrNode::rhs2(), conditiongotoNode::right(), operandNode::star(), stmt_list_p, blockNode::stmts(), ThreeAddr, threeAddr_set, threeAddr_set_p, operandNode::var(), and Var_pair.

Referenced by at_proc().

Order Changer::order   const [inline, inherited]
 

Return the order in which Nodes of an AST should be visited.

Nodes can be visited before their children (Preorder), after their children (Postorder), or both (Both).

Definition at line 196 of file changer.h.

Referenced by whileNode::change(), unitNode::change(), unionNode::change(), unaryNode::change(), threeAddrNode::change(), textNode::change(), ternaryNode::change(), tdefNode::change(), switchNode::change(), suespecNode::change(), subdeclNode::change(), structNode::change(), returnNode::change(), ptrNode::change(), procNode::change(), primNode::change(), operandNode::change(), metastmtNode::change(), metaexprNode::change(), labelNode::change(), initializerNode::change(), ifNode::change(), idNode::change(), gotoNode::change(), funcNode::change(), forNode::change(), exprstmtNode::change(), enumNode::change(), doNode::change(), declNode::change(), continueNode::change(), constNode::change(), conditiongotoNode::change(), commaNode::change(), castNode::change(), caseNode::change(), callNode::change(), breakNode::change(), blockNode::change(), binaryNode::change(), basicblockNode::change(), attribNode::change(), and arrayNode::change().

void copyPropChanger::remove_ACP ACP   acp,
declNode   v
[static, private]
 

Definition at line 494 of file copyprop.cc.

References Var_pair.

Referenced by local_copy_prop().

void copyPropChanger::solve_global_dataflow stmt_list    [private]
 

Definition at line 370 of file copyprop.cc.

References _top, basicblock_list_p, copyFlowVal::clone(), copyFlowVal::copy(), copyFlowVal::diff(), copyFlowVal::Difference(), In, copyFlowVal::Intersect(), Out, basicblockNode::preds(), stmt_list, stmt_list_p, basicblockNode::succs(), copyFlowVal::to_top(), and copyFlowVal::Union().

Referenced by at_proc().


Member Data Documentation

copyFlowVal * copyPropChanger::_bottom [private]
 

Definition at line 101 of file copyprop.h.

Referenced by at_proc(), and create_kill_set().

copyFlowVal* copyPropChanger::_top [private]
 

Definition at line 101 of file copyprop.h.

Referenced by at_proc(), create_copy_set(), create_kill_set(), and solve_global_dataflow().

threeAddr_set copyPropChanger::ambiguous [private]
 

Definition at line 87 of file copyprop.h.

Referenced by at_proc(), GetDefsWalker::at_threeAddr(), create_copy_set(), create_kill_set(), and local_copy_prop().

threeAddr_set copyPropChanger::copies [private]
 

Definition at line 87 of file copyprop.h.

Referenced by at_proc(), create_copy_set(), and local_copy_prop().

map<threeAddrNode*,declNode*> copyPropChanger::defines [private]
 

Definition at line 90 of file copyprop.h.

Referenced by at_proc(), create_copy_set(), and create_kill_set().

map<basicblockNode*, copyFlowVal*> copyPropChanger::Gen [private]
 

Definition at line 103 of file copyprop.h.

Referenced by at_proc(), and create_kill_set().

map<basicblockNode*, copyFlowVal*> copyPropChanger::In [private]
 

Definition at line 103 of file copyprop.h.

Referenced by at_proc(), local_copy_prop(), and solve_global_dataflow().

map<basicblockNode*, copyFlowVal*> copyPropChanger::Kill [private]
 

Definition at line 103 of file copyprop.h.

Referenced by at_proc().

map<basicblockNode*, copyFlowVal*> copyPropChanger::Out [private]
 

Definition at line 103 of file copyprop.h.

Referenced by at_proc(), and solve_global_dataflow().


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

Generated on August 27, 2003
Back to the C-Breeze home page