summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/SparcV9/MachineInstrAnnot.h95
1 files changed, 95 insertions, 0 deletions
diff --git a/llvm/lib/Target/SparcV9/MachineInstrAnnot.h b/llvm/lib/Target/SparcV9/MachineInstrAnnot.h
new file mode 100644
index 00000000000..19d93ab56ad
--- /dev/null
+++ b/llvm/lib/Target/SparcV9/MachineInstrAnnot.h
@@ -0,0 +1,95 @@
+//===-- llvm/CodeGen/MachineInstrAnnot.h ------------------------*- C++ -*-===//
+//
+// 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.
+//
+//===----------------------------------------------------------------------===//
+//
+// Annotations used to pass information between code generation phases.
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef MACHINE_INSTR_ANNOT_h
+#define MACHINE_INSTR_ANNOT_h
+
+#include "llvm/CodeGen/MachineInstr.h"
+#include "llvm/Target/TargetRegInfo.h"
+
+namespace llvm {
+
+class Value;
+class TmpInstruction;
+class CallInst;
+
+class CallArgInfo {
+ // Flag values for different argument passing methods
+ static const unsigned char IntArgReg = 0x1;
+ static const unsigned char FPArgReg = 0x2;
+ static const unsigned char StackSlot = 0x4;
+
+ Value* argVal; // this argument
+ int argCopyReg; // register used for second copy of arg. when
+ // multiple copies must be passed in registers
+ unsigned char passingMethod; // flags recording passing methods
+
+public:
+ // Constructors
+ CallArgInfo(Value* _argVal)
+ : argVal(_argVal), argCopyReg(TargetRegInfo::getInvalidRegNum()),
+ passingMethod(0x0) {}
+
+ CallArgInfo(const CallArgInfo& obj)
+ : argVal(obj.argVal), argCopyReg(obj.argCopyReg),
+ passingMethod(obj.passingMethod) {}
+
+ // Accessor methods
+ Value* getArgVal() { return argVal; }
+ int getArgCopy() { return argCopyReg; }
+ bool usesIntArgReg() { return (bool) (passingMethod & IntArgReg);}
+ bool usesFPArgReg() { return (bool) (passingMethod & FPArgReg); }
+ bool usesStackSlot() { return (bool) (passingMethod & StackSlot);}
+
+ // Modifier methods
+ void replaceArgVal(Value* newVal) { argVal = newVal; }
+ void setUseIntArgReg() { passingMethod |= IntArgReg; }
+ void setUseFPArgReg() { passingMethod |= FPArgReg; }
+ void setUseStackSlot() { passingMethod |= StackSlot; }
+ void setArgCopy(int copyReg) { argCopyReg = copyReg; }
+};
+
+
+class CallArgsDescriptor {
+
+ std::vector<CallArgInfo> argInfoVec; // Descriptor for each argument
+ CallInst* callInstr; // The call instruction == result value
+ Value* funcPtr; // Pointer for indirect calls
+ TmpInstruction* retAddrReg; // Tmp value for return address reg.
+ bool isVarArgs; // Is this a varargs call?
+ bool noPrototype; // Is this a call with no prototype?
+
+public:
+ CallArgsDescriptor(CallInst* _callInstr, TmpInstruction* _retAddrReg,
+ bool _isVarArgs, bool _noPrototype);
+
+ // Accessor methods to retrieve information about the call
+ // Note that operands are numbered 1..#CallArgs
+ unsigned int getNumArgs() const { return argInfoVec.size(); }
+ CallArgInfo& getArgInfo(unsigned int op) { assert(op < argInfoVec.size());
+ return argInfoVec[op]; }
+ CallInst* getCallInst() const { return callInstr; }
+ CallInst* getReturnValue() const;
+ Value* getIndirectFuncPtr() const { return funcPtr; }
+ TmpInstruction* getReturnAddrReg() const { return retAddrReg; }
+ bool isVarArgsFunc() const { return isVarArgs; }
+ bool hasNoPrototype() const { return noPrototype; }
+
+ // Mechanism to get the descriptor for a CALL MachineInstr.
+ //
+ static CallArgsDescriptor *get(const MachineInstr* MI);
+};
+
+} // End llvm namespace
+
+#endif
OpenPOWER on IntegriCloud