mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-03 13:31:05 +00:00
Fixed a bunch of test cases in test/Regression/Jello which could not get the
address of a floating-point (allocated via ConstantPool) correctly. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6647 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
302de59001
commit
de07be3b78
@ -22,7 +22,7 @@
|
||||
bool UltraSparc::addPassesToEmitMachineCode(PassManager &PM,
|
||||
MachineCodeEmitter &MCE) {
|
||||
MachineCodeEmitter *M = &MCE;
|
||||
DEBUG(MachineCodeEmitter::createFilePrinterEmitter(MCE));
|
||||
DEBUG(M = MachineCodeEmitter::createFilePrinterEmitter(MCE));
|
||||
PM.add(new SparcV9CodeEmitter(*this, *M));
|
||||
PM.add(createMachineCodeDestructionPass()); // Free stuff no longer needed
|
||||
return false;
|
||||
@ -443,8 +443,19 @@ int64_t SparcV9CodeEmitter::getMachineOpValue(MachineInstr &MI,
|
||||
DEBUG(std::cerr << "already generated: 0x" << std::hex << rv << "\n");
|
||||
}
|
||||
} else {
|
||||
DEBUG(std::cerr << "not a function: " << *GV << "\n");
|
||||
rv = (int64_t)MCE.getGlobalValueAddress(GV);
|
||||
if (rv == 0) {
|
||||
if (Constant *C = ConstantPointerRef::get(GV)) {
|
||||
if (ConstantMap.find(C) != ConstantMap.end()) {
|
||||
rv = MCE.getConstantPoolEntryAddress(ConstantMap[C]);
|
||||
} else {
|
||||
std::cerr << "Constant: 0x" << std::hex << &*C << std::dec
|
||||
<< ", " << *V << " not found in ConstantMap!\n";
|
||||
abort();
|
||||
}
|
||||
}
|
||||
}
|
||||
DEBUG(std::cerr << "Global addr: " << rv << "\n");
|
||||
}
|
||||
// The real target of the call is Addr = PC + (rv * 4)
|
||||
// So undo that: give the instruction (Addr - PC) / 4
|
||||
|
Loading…
Reference in New Issue
Block a user