[llvm-commits] CVS: llvm/utils/TableGen/CodeGenIntrinsics.h CodeGenTarget.cpp CodeGenTarget.h

Chris Lattner lattner at cs.uiuc.edu
Mon Mar 27 14:48:30 PST 2006



Changes in directory llvm/utils/TableGen:

CodeGenIntrinsics.h updated: 1.7 -> 1.8
CodeGenTarget.cpp updated: 1.59 -> 1.60
CodeGenTarget.h updated: 1.24 -> 1.25
---
Log message:

Add support for decoding iPTR to the right pointer type.


---
Diffs of the changes:  (+19 -7)

 CodeGenIntrinsics.h |    3 ++-
 CodeGenTarget.cpp   |   20 +++++++++++++++-----
 CodeGenTarget.h     |    3 ++-
 3 files changed, 19 insertions(+), 7 deletions(-)


Index: llvm/utils/TableGen/CodeGenIntrinsics.h
diff -u llvm/utils/TableGen/CodeGenIntrinsics.h:1.7 llvm/utils/TableGen/CodeGenIntrinsics.h:1.8
--- llvm/utils/TableGen/CodeGenIntrinsics.h:1.7	Fri Mar 24 13:49:31 2006
+++ llvm/utils/TableGen/CodeGenIntrinsics.h	Mon Mar 27 16:48:18 2006
@@ -21,6 +21,7 @@
 namespace llvm {
   class Record;
   class RecordKeeper;
+  class CodeGenTarget;
 
   struct CodeGenIntrinsic {
     Record *TheDef;            // The actual record defining this instruction.
@@ -45,7 +46,7 @@
       NoMem, ReadArgMem, ReadMem, WriteArgMem, WriteMem
     } ModRef;
 
-    CodeGenIntrinsic(Record *R);
+    CodeGenIntrinsic(Record *R, CodeGenTarget &CGT);
   };
 
   /// LoadIntrinsics - Read all of the intrinsics defined in the specified


Index: llvm/utils/TableGen/CodeGenTarget.cpp
diff -u llvm/utils/TableGen/CodeGenTarget.cpp:1.59 llvm/utils/TableGen/CodeGenTarget.cpp:1.60
--- llvm/utils/TableGen/CodeGenTarget.cpp:1.59	Fri Mar 24 14:25:01 2006
+++ llvm/utils/TableGen/CodeGenTarget.cpp	Mon Mar 27 16:48:18 2006
@@ -29,8 +29,13 @@
 
 /// getValueType - Return the MCV::ValueType that the specified TableGen record
 /// corresponds to.
-MVT::ValueType llvm::getValueType(Record *Rec) {
-  return (MVT::ValueType)Rec->getValueAsInt("Value");
+MVT::ValueType llvm::getValueType(Record *Rec, const CodeGenTarget *CGT) {
+  MVT::ValueType VT = (MVT::ValueType)Rec->getValueAsInt("Value");
+  if (VT == MVT::iPTR) {
+    assert(CGT && "Use a pointer type in a place that isn't supported yet!");
+    VT = CGT->getPointerType();
+  }
+  return VT;
 }
 
 std::string llvm::getName(MVT::ValueType T) {
@@ -355,10 +360,15 @@
 
 std::vector<CodeGenIntrinsic> llvm::LoadIntrinsics(const RecordKeeper &RC) {
   std::vector<Record*> I = RC.getAllDerivedDefinitions("Intrinsic");
-  return std::vector<CodeGenIntrinsic>(I.begin(), I.end());
+  
+  std::vector<CodeGenIntrinsic> Result;
+  CodeGenTarget CGT;
+  for (unsigned i = 0, e = I.size(); i != e; ++i)
+    Result.push_back(CodeGenIntrinsic(I[i], CGT));
+  return Result;
 }
 
-CodeGenIntrinsic::CodeGenIntrinsic(Record *R) {
+CodeGenIntrinsic::CodeGenIntrinsic(Record *R, CodeGenTarget &CGT) {
   TheDef = R;
   std::string DefName = R->getName();
   ModRef = WriteMem;
@@ -405,7 +415,7 @@
     assert(TyEl->isSubClassOf("LLVMType") && "Expected a type!");
     ArgTypes.push_back(TyEl->getValueAsString("TypeVal"));
     
-    ArgVTs.push_back(getValueType(TyEl->getValueAsDef("VT")));
+    ArgVTs.push_back(getValueType(TyEl->getValueAsDef("VT"), &CGT));
     ArgTypeDefs.push_back(TyEl);
   }
   if (ArgTypes.size() == 0)


Index: llvm/utils/TableGen/CodeGenTarget.h
diff -u llvm/utils/TableGen/CodeGenTarget.h:1.24 llvm/utils/TableGen/CodeGenTarget.h:1.25
--- llvm/utils/TableGen/CodeGenTarget.h:1.24	Thu Jan 26 19:45:06 2006
+++ llvm/utils/TableGen/CodeGenTarget.h	Mon Mar 27 16:48:18 2006
@@ -27,10 +27,11 @@
 class Record;
 class RecordKeeper;
 struct CodeGenRegister;
+class CodeGenTarget;
 
 /// getValueType - Return the MVT::ValueType that the specified TableGen record
 /// corresponds to.
-MVT::ValueType getValueType(Record *Rec);
+MVT::ValueType getValueType(Record *Rec, const CodeGenTarget *CGT = 0);
 
 std::ostream &operator<<(std::ostream &OS, MVT::ValueType T);
 std::string getName(MVT::ValueType T);






More information about the llvm-commits mailing list