summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorMisha Brukman <brukman+llvm@gmail.com>2003-05-30 20:32:45 +0000
committerMisha Brukman <brukman+llvm@gmail.com>2003-05-30 20:32:45 +0000
commit94908b010e1e39723c323fd6e56f160c6dbb7fd9 (patch)
tree1bfb9cac08b2930fd3d81023046400de99c4463c /llvm
parent027b3d899fea2716f20adc7d9761df794b826dab (diff)
downloadbcm5719-llvm-94908b010e1e39723c323fd6e56f160c6dbb7fd9.tar.gz
bcm5719-llvm-94908b010e1e39723c323fd6e56f160c6dbb7fd9.zip
Added saveBBreferences() for BasicBlock resolution.
llvm-svn: 6451
Diffstat (limited to 'llvm')
-rw-r--r--llvm/include/llvm/CodeGen/MachineCodeEmitter.h8
-rw-r--r--llvm/lib/CodeGen/MachineCodeEmitter.cpp12
2 files changed, 16 insertions, 4 deletions
diff --git a/llvm/include/llvm/CodeGen/MachineCodeEmitter.h b/llvm/include/llvm/CodeGen/MachineCodeEmitter.h
index ba70b18d185..1db7183131a 100644
--- a/llvm/include/llvm/CodeGen/MachineCodeEmitter.h
+++ b/llvm/include/llvm/CodeGen/MachineCodeEmitter.h
@@ -10,7 +10,10 @@
#ifndef LLVM_CODEGEN_MACHINE_CODE_EMITTER_H
#define LLVM_CODEGEN_MACHINE_CODE_EMITTER_H
+#include <iostream>
#include <string>
+class BasicBlock;
+class MachineInstr;
class MachineFunction;
class MachineBasicBlock;
class MachineConstantPool;
@@ -91,6 +94,11 @@ struct MachineCodeEmitter {
///
static MachineCodeEmitter*
createFilePrinterMachineCodeEmitter(MachineCodeEmitter&);
+
+ ///
+ virtual void saveBBreference(BasicBlock* BB, MachineInstr &MI) {
+ std::cerr << "Save BB reference unimplemented\n";
+ }
};
#endif
diff --git a/llvm/lib/CodeGen/MachineCodeEmitter.cpp b/llvm/lib/CodeGen/MachineCodeEmitter.cpp
index e67b4aaa021..607480c75df 100644
--- a/llvm/lib/CodeGen/MachineCodeEmitter.cpp
+++ b/llvm/lib/CodeGen/MachineCodeEmitter.cpp
@@ -158,9 +158,7 @@ namespace {
}
}
void emitPCRelativeDisp(Value *V) {
- // put block in mapping BB -> { instr, address }. when BB is beginning to
- // output, find instr, set disp, overwrite instr at addr using the
- // unsigned value gotten from emitter
+ if (MCE) MCE->emitPCRelativeDisp(V);
}
void emitGlobalAddress(GlobalValue *V, bool isPCRelative) {
@@ -173,9 +171,15 @@ namespace {
void emitFunctionConstantValueAddress(unsigned ConstantNum, int Offset) {
if (MCE) MCE->emitFunctionConstantValueAddress(ConstantNum, Offset);
}
+
+ virtual void saveBBreference(BasicBlock* BB, MachineInstr &MI) {
+ if (MCE) MCE->saveBBreference(BB, MI);
+ }
+
};
}
-MachineCodeEmitter *MachineCodeEmitter::createFilePrinterMachineCodeEmitter(MachineCodeEmitter &MCE) {
+MachineCodeEmitter *MachineCodeEmitter::createFilePrinterMachineCodeEmitter
+(MachineCodeEmitter &MCE) {
return new FilePrinterMachineCodeEmitter(MCE, std::cerr);
}
OpenPOWER on IntegriCloud