mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-05 13:26:55 +00:00
- Fix a small bug while handling target constant pools (one param was missing).
- Add a smarter constant pool loading, instead of: lui $2, %hi($CPI1_0) addiu $2, $2, %lo($CPI1_0) lwc1 $f0, 0($2) Generate: lui $2, %hi($CPI1_0) lwc1 $f0, %lo($CPI1_0)($2) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@88886 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -170,6 +170,27 @@ SelectAddr(SDValue Op, SDValue Addr, SDValue &Offset, SDValue &Base)
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
// When loading from constant pools, load the lower address part in
|
||||
// the instruction itself. Instead of:
|
||||
// lui $2, %hi($CPI1_0)
|
||||
// addiu $2, $2, %lo($CPI1_0)
|
||||
// lwc1 $f0, 0($2)
|
||||
// Generate:
|
||||
// lui $2, %hi($CPI1_0)
|
||||
// lwc1 $f0, %lo($CPI1_0)($2)
|
||||
if (Addr.getOperand(0).getOpcode() == MipsISD::Hi &&
|
||||
Addr.getOperand(1).getOpcode() == MipsISD::Lo) {
|
||||
SDValue LoVal = Addr.getOperand(1);
|
||||
if (ConstantPoolSDNode *CP = dyn_cast<ConstantPoolSDNode>(
|
||||
LoVal.getOperand(0))) {
|
||||
if (!CP->getOffset()) {
|
||||
Base = Addr.getOperand(0);
|
||||
Offset = LoVal.getOperand(0);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Base = Addr;
|
||||
|
@@ -568,7 +568,7 @@ LowerConstantPool(SDValue Op, SelectionDAG &DAG)
|
||||
ConstantPoolSDNode *N = cast<ConstantPoolSDNode>(Op);
|
||||
Constant *C = N->getConstVal();
|
||||
SDValue CP = DAG.getTargetConstantPool(C, MVT::i32, N->getAlignment(),
|
||||
MipsII::MO_ABS_HILO);
|
||||
N->getOffset(), MipsII::MO_ABS_HILO);
|
||||
// FIXME there isn't actually debug info here
|
||||
DebugLoc dl = Op.getDebugLoc();
|
||||
|
||||
|
Reference in New Issue
Block a user