15#ifndef LLVM_LIB_CODEGEN_SELECTIONDAG_INSTREMITTER_H 
   16#define LLVM_LIB_CODEGEN_SELECTIONDAG_INSTREMITTER_H 
   47  bool EmitDebugInstrRefs;
 
   57                              bool IsClone, 
bool IsCloned,
 
   72                          bool IsDebug, 
bool IsClone, 
bool IsCloned);
 
   83                  bool IsDebug, 
bool IsClone, 
bool IsCloned);
 
  144    if (
Node->isMachineOpcode())
 
  145      EmitMachineNode(
Node, IsClone, IsCloned, VRBaseMap);
 
  147      EmitSpecialNode(
Node, IsClone, IsCloned, VRBaseMap);
 
 
  162  void EmitMachineNode(
SDNode *
Node, 
bool IsClone, 
bool IsCloned,
 
  163                       VRBaseMapType &VRBaseMap);
 
  164  void EmitSpecialNode(
SDNode *
Node, 
bool IsClone, 
bool IsCloned,
 
  165                       VRBaseMapType &VRBaseMap);
 
 
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
#define LLVM_LIBRARY_VISIBILITY
This file defines the DenseMap class.
uint64_t IntrinsicInst * II
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
MachineBasicBlock * getBlock()
getBlock - Return the current basic block.
MachineInstr * EmitDbgValue(SDDbgValue *SD, VRBaseMapType &VRBaseMap)
EmitDbgValue - Generate machine instruction for a dbg_value node.
MachineInstr * EmitDbgInstrRef(SDDbgValue *SD, VRBaseMapType &VRBaseMap)
Emit a dbg_value as a DBG_INSTR_REF.
SmallDenseMap< SDValue, Register, 16 > VRBaseMapType
MachineInstr * EmitDbgLabel(SDDbgLabel *SD)
Generate machine instruction for a dbg_label node.
void EmitNode(SDNode *Node, bool IsClone, bool IsCloned, VRBaseMapType &VRBaseMap)
EmitNode - Generate machine code for a node and needed dependencies.
MachineInstr * EmitDbgNoLocation(SDDbgValue *SD)
Emit a DBG_VALUE $noreg, indicating a variable has no location.
static unsigned CountResults(SDNode *Node)
CountResults - The results of target nodes have register or immediate operands first,...
MachineInstr * EmitDbgValueList(SDDbgValue *SD, VRBaseMapType &VRBaseMap)
Emit a DBG_VALUE_LIST from the operands to SDDbgValue.
InstrEmitter(const TargetMachine &TM, MachineBasicBlock *mbb, MachineBasicBlock::iterator insertpos)
InstrEmitter - Construct an InstrEmitter and set it to start inserting at the given position in the g...
void AddDbgValueLocationOps(MachineInstrBuilder &MIB, const MCInstrDesc &DbgValDesc, ArrayRef< SDDbgOperand > Locations, VRBaseMapType &VRBaseMap)
MachineInstr * EmitDbgValueFromSingleOp(SDDbgValue *SD, VRBaseMapType &VRBaseMap)
Emit a DBG_VALUE from the operands to SDDbgValue.
MachineBasicBlock::iterator getInsertPos()
getInsertPos - Return the current insertion position.
Describe properties that are true of each instruction in the target description file.
MachineInstrBundleIterator< MachineInstr > iterator
Representation of each machine instruction.
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
Wrapper class representing virtual and physical registers.
Holds the information from a dbg_label node through SDISel.
Holds the information for a single machine location through SDISel; either an SDNode,...
Holds the information from a dbg_value node through SDISel.
Represents one node in the SelectionDAG.
Unlike LLVM values, Selection DAG nodes may return multiple values as the result of a computation.
TargetInstrInfo - Interface to description of machine instruction set.
This class defines information used to lower LLVM code to legal SelectionDAG operators that the targe...
Primary interface to the complete machine description for the target machine.
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
This is an optimization pass for GlobalISel generic memory operations.
DWARFExpression::Operation Op