mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-03 02:31:26 +00:00
Fix definition for Mips16 pc relative load word instructions.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@194126 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
8458f371b8
commit
7851bc1871
@ -614,12 +614,13 @@ initializeFunctionInfo(const std::vector<MachineInstr*> &CPEMIs) {
|
||||
llvm_unreachable("Unknown addressing mode for CP reference!");
|
||||
case Mips::LwRxPcTcp16:
|
||||
Bits = 8;
|
||||
Scale = 2;
|
||||
Scale = 4;
|
||||
LongFormOpcode = Mips::LwRxPcTcpX16;
|
||||
break;
|
||||
case Mips::LwRxPcTcpX16:
|
||||
Bits = 16;
|
||||
Scale = 2;
|
||||
Scale = 1;
|
||||
NegOk = true;
|
||||
break;
|
||||
}
|
||||
// Remember that this is a user of a CP entry.
|
||||
@ -782,9 +783,6 @@ MachineBasicBlock *MipsConstantIslands::splitBlockBeforeInstr
|
||||
/// isOffsetInRange - Checks whether UserOffset (the location of a constant pool
|
||||
/// reference) is within MaxDisp of TrialOffset (a proposed location of a
|
||||
/// constant pool entry).
|
||||
/// UserOffset is computed by getUserOffset above to include PC adjustments. If
|
||||
/// the mod 4 alignment of UserOffset is not known, the uncertainty must be
|
||||
/// subtracted from MaxDisp instead. CPUser::getMaxDisp() does that.
|
||||
bool MipsConstantIslands::isOffsetInRange(unsigned UserOffset,
|
||||
unsigned TrialOffset, unsigned MaxDisp,
|
||||
bool NegativeOK) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user