[llvm-commits] CVS: llvm/tools/jello/Emitter.cpp VM.cpp

Chris Lattner lattner at cs.uiuc.edu
Thu Dec 12 23:41:01 PST 2002


Changes in directory llvm/tools/jello:

Emitter.cpp updated: 1.3 -> 1.4
VM.cpp updated: 1.4 -> 1.5

---
Log message:

Implement branches


---
Diffs of the changes:

Index: llvm/tools/jello/Emitter.cpp
diff -u llvm/tools/jello/Emitter.cpp:1.3 llvm/tools/jello/Emitter.cpp:1.4
--- llvm/tools/jello/Emitter.cpp:1.3	Wed Dec  4 00:45:40 2002
+++ llvm/tools/jello/Emitter.cpp	Thu Dec 12 23:40:28 2002
@@ -8,6 +8,7 @@
 #include "VM.h"
 #include "llvm/CodeGen/MachineCodeEmitter.h"
 #include "llvm/CodeGen/MachineFunction.h"
+#include "llvm/Function.h"
 
 namespace {
   class Emitter : public MachineCodeEmitter {
@@ -15,12 +16,15 @@
 
     unsigned char *CurBlock;
     unsigned char *CurByte;
+    
+    std::vector<std::pair<BasicBlock*, unsigned *> > BBRefs;
+    std::map<BasicBlock*, unsigned> BBLocations;
   public:
     Emitter(VM &vm) : TheVM(vm) {}
 
     virtual void startFunction(MachineFunction &F);
     virtual void finishFunction(MachineFunction &F);
-    virtual void startBasicBlock(MachineBasicBlock &BB) {}
+    virtual void startBasicBlock(MachineBasicBlock &BB);
     virtual void emitByte(unsigned char B);
     virtual void emitPCRelativeDisp(Value *V);
     virtual void emitGlobalAddress(GlobalValue *V);
@@ -48,15 +52,23 @@
   TheVM.addGlobalMapping(F.getFunction(), CurBlock);
 }
 
-#include <iostream>
-#include "llvm/Function.h"
-
 void Emitter::finishFunction(MachineFunction &F) {
+  for (unsigned i = 0, e = BBRefs.size(); i != e; ++i) {
+    unsigned Location = BBLocations[BBRefs[i].first];
+    unsigned *Ref = BBRefs[i].second;
+    *Ref = Location-(unsigned)Ref-4;
+  }
+  BBRefs.clear();
+  BBLocations.clear();
+
   std::cerr << "Finished Code Generation of Function: "
             << F.getFunction()->getName() << ": " << CurByte-CurBlock
             << " bytes of text\n";
 }
 
+void Emitter::startBasicBlock(MachineBasicBlock &BB) {
+  BBLocations[BB.getBasicBlock()] = (unsigned)CurByte;
+}
 
 
 void Emitter::emitByte(unsigned char B) {
@@ -64,16 +76,24 @@
 }
 
 
-// emitPCRelativeDisp - Just output a displacement that will cause a reference
-// to the zero page, which will cause a seg-fault, causing things to get
-// resolved on demand.  Keep track of these markers.
+// emitPCRelativeDisp - For functions, just output a displacement that will
+// cause a reference to the zero page, which will cause a seg-fault, causing
+// things to get resolved on demand.  Keep track of these markers.
+//
+// For basic block references, keep track of where the references are so they
+// may be patched up when the basic block is defined.
 //
 void Emitter::emitPCRelativeDisp(Value *V) {
-  TheVM.addFunctionRef(CurByte, cast<Function>(V));
-
-  unsigned ZeroAddr = -(unsigned)CurByte-4; // Calculate displacement to null
-  *(unsigned*)CurByte = ZeroAddr;   // 4 byte offset
-  CurByte += 4;
+  if (Function *F = dyn_cast<Function>(V)) {
+    TheVM.addFunctionRef(CurByte, F);
+    unsigned ZeroAddr = -(unsigned)CurByte-4; // Calculate displacement to null
+    *(unsigned*)CurByte = ZeroAddr;           // 4 byte offset
+    CurByte += 4;
+  } else {
+    BasicBlock *BB = cast<BasicBlock>(V);     // Keep track of reference...
+    BBRefs.push_back(std::make_pair(BB, (unsigned*)CurByte));
+    CurByte += 4;
+  }
 }
 
 void Emitter::emitGlobalAddress(GlobalValue *V) {


Index: llvm/tools/jello/VM.cpp
diff -u llvm/tools/jello/VM.cpp:1.4 llvm/tools/jello/VM.cpp:1.5
--- llvm/tools/jello/VM.cpp:1.4	Wed Dec  4 00:45:40 2002
+++ llvm/tools/jello/VM.cpp	Thu Dec 12 23:40:28 2002
@@ -9,7 +9,6 @@
 #include "llvm/Target/TargetMachine.h"
 #include "llvm/CodeGen/MachineCodeEmitter.h"
 #include "llvm/Function.h"
-#include <iostream>
 #include <dlfcn.h>    // dlsym access
 
 





More information about the llvm-commits mailing list