mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Implement a simple FIXME: if we are emitting a basic block address that has
already been emitted, we don't have to remember it and deal with it later, just emit it directly. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@17868 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
16fe6f5f24
commit
f2d552eca6
@ -278,9 +278,19 @@ void Emitter::emitBasicBlock(const MachineBasicBlock &MBB) {
|
||||
/// necessary to resolve this address later (and emits a dummy value).
|
||||
///
|
||||
void Emitter::emitPCRelativeBlockAddress(const MachineBasicBlock *MBB) {
|
||||
// FIXME: Emit backward branches directly
|
||||
BBRefs.push_back(std::make_pair(MBB, MCE.getCurrentPCValue()));
|
||||
MCE.emitWord(0);
|
||||
// If this is a backwards branch, we already know the address of the target,
|
||||
// so just emit the value.
|
||||
std::map<const MachineBasicBlock*, unsigned>::iterator I =
|
||||
BasicBlockAddrs.find(MBB);
|
||||
if (I != BasicBlockAddrs.end()) {
|
||||
unsigned Location = I->second;
|
||||
MCE.emitWord(Location-MCE.getCurrentPCValue()-4);
|
||||
} else {
|
||||
// Otherwise, remember where this reference was and where it is to so we can
|
||||
// deal with it later.
|
||||
BBRefs.push_back(std::make_pair(MBB, MCE.getCurrentPCValue()));
|
||||
MCE.emitWord(0);
|
||||
}
|
||||
}
|
||||
|
||||
/// emitPCRelativeValue - Emit a 32-bit PC relative address.
|
||||
|
Loading…
x
Reference in New Issue
Block a user