diff options
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/Target/SparcV9/SparcV9.burg.in | 2 | ||||
| -rw-r--r-- | llvm/lib/Target/SparcV9/SparcV9InstrForest.h | 134 | 
2 files changed, 135 insertions, 1 deletions
| diff --git a/llvm/lib/Target/SparcV9/SparcV9.burg.in b/llvm/lib/Target/SparcV9/SparcV9.burg.in index b466b1f3765..6986828b392 100644 --- a/llvm/lib/Target/SparcV9/SparcV9.burg.in +++ b/llvm/lib/Target/SparcV9/SparcV9.burg.in @@ -9,7 +9,7 @@  //===----------------------------------------------------------------------===*/  Xinclude <cstdio> -Xinclude <llvm/CodeGen/InstrForest.h> +Xinclude "SparcV9InstrForest.h"  typedef llvm::InstrTreeNode* NODEPTR_TYPE;  Xdefine OP_LABEL(p)	((p)->opLabel) diff --git a/llvm/lib/Target/SparcV9/SparcV9InstrForest.h b/llvm/lib/Target/SparcV9/SparcV9InstrForest.h new file mode 100644 index 00000000000..ec2cc1d7e86 --- /dev/null +++ b/llvm/lib/Target/SparcV9/SparcV9InstrForest.h @@ -0,0 +1,134 @@ +//===- SparcV9InstrForest.cpp - SparcV9 BURG Instruction Selector Trees ---===// +//  +//                     The LLVM Compiler Infrastructure +// +// This file was developed by the LLVM research group and is distributed under +// the University of Illinois Open Source License. See LICENSE.TXT for details. +//  +//===----------------------------------------------------------------------===// +// +// A forest of BURG instruction trees (class InstrForest) which represents +// a function to the BURG-based instruction selector, and a bunch of constants +// and declarations used by the generated BURG code. +//	 +//===----------------------------------------------------------------------===// + +#ifndef SPARCV9INSTRFOREST_H +#define SPARCV9INSTRFOREST_H + +#include "llvm/Instruction.h" +using namespace llvm; + +/// OpLabel values for special-case nodes created for instruction selection. +/// All op-labels not defined here are identical to the instruction +/// opcode returned by Instruction::getOpcode(). +/// +static const int + InvalidOp	= -1, + VRegListOp     = 97, + VRegNodeOp	= 98, + ConstantNodeOp = 99, + LabelNodeOp	= 100, + RetValueOp	= 100 + Instruction::Ret,               // 101 + BrCondOp	= 100 + Instruction::Br,                // 102 + BAndOp         = 100 + Instruction::And,               // 111 + BOrOp          = 100 + Instruction::Or,                // 112 + BXorOp         = 100 + Instruction::Xor,               // 113 + BNotOp         = 200 + Instruction::Xor,               // 213 +  NotOp         = 300 + Instruction::Xor,               // 313 + SetCCOp	= 100 + Instruction::SetEQ,             // 114 + AllocaN	= 100 + Instruction::Alloca,		// 122 + LoadIdx	= 100 + Instruction::Load,		// 123 + GetElemPtrIdx  = 100 + Instruction::GetElementPtr,	// 125 + ToBoolTy	= 100 + Instruction::Cast;		// 127 +static const int + ToUByteTy	= ToBoolTy +  1, + ToSByteTy	= ToBoolTy +  2, + ToUShortTy	= ToBoolTy +  3, + ToShortTy	= ToBoolTy +  4, + ToUIntTy	= ToBoolTy +  5, + ToIntTy	= ToBoolTy +  6, + ToULongTy	= ToBoolTy +  7, + ToLongTy	= ToBoolTy +  8, + ToFloatTy	= ToBoolTy +  9, + ToDoubleTy	= ToBoolTy + 10, + ToArrayTy	= ToBoolTy + 11, + ToPointerTy	= ToBoolTy + 12; + +/// Data types needed by BURG +/// +typedef int OpLabel; +typedef int StateLabel; + +/// Declarations of data and functions created by BURG +/// +namespace llvm {  +  class InstrTreeNode; +}; +extern short*		burm_nts[]; +extern StateLabel	burm_label	(InstrTreeNode* p); +extern StateLabel	burm_state	(OpLabel op, StateLabel leftState, +					 StateLabel rightState); +extern StateLabel	burm_rule	(StateLabel state, int goalNT); +extern InstrTreeNode**  burm_kids	(InstrTreeNode* p, int eruleno, +					 InstrTreeNode* kids[]); +extern void		printcover	(InstrTreeNode*, int, int); +extern void		printtree	(InstrTreeNode*); +extern int		treecost	(InstrTreeNode*, int, int); +extern void		printMatches	(InstrTreeNode*); + +namespace llvm { + +/// InstrTreeNode - A single tree node in the instruction tree used for +/// instruction selection via BURG. +/// +class InstrTreeNode { +  InstrTreeNode(const InstrTreeNode &);   // DO NOT IMPLEMENT +  void operator=(const InstrTreeNode &);  // DO NOT IMPLEMENT +public: +  enum InstrTreeNodeType { NTInstructionNode, +			   NTVRegListNode, +			   NTVRegNode, +			   NTConstNode, +			   NTLabelNode }; +  InstrTreeNode* LeftChild; +  InstrTreeNode* RightChild; +  InstrTreeNode* Parent; +  OpLabel        opLabel; +  StateLabel     state; + +protected: +  InstrTreeNodeType treeNodeType; +  Value*	   val; +   +public: +  InstrTreeNode(InstrTreeNodeType nodeType, Value* _val) +    : treeNodeType(nodeType), val(_val) { +    LeftChild = RightChild = Parent = 0; +    opLabel   = InvalidOp; +  } +  virtual ~InstrTreeNode() { +    delete LeftChild; +    delete RightChild; +  } +  InstrTreeNodeType	getNodeType	() const { return treeNodeType; } +  Value*		getValue	() const { return val; } +  inline OpLabel	getOpLabel	() const { return opLabel; } +  inline InstrTreeNode *leftChild       () const { return LeftChild; } +  inline InstrTreeNode *parent          () const { return Parent; } +   +  // If right child is a list node, recursively get its *left* child +  inline InstrTreeNode* rightChild() const { +    return (!RightChild ? 0 :  +	    (RightChild->getOpLabel() == VRegListOp +	     ? RightChild->LeftChild : RightChild)); +  } +  void dump(int dumpChildren, int indent) const; +protected: +  virtual void dumpNode(int indent) const = 0; +  friend class InstrForest; +}; + +} // end namespace llvm. + +#endif | 

