mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-15 09:33:39 +00:00
Implement two virtual functions in SPUTargetLowering.
Before the implementation of isLegalAddressingMode, some rare cases of code were miscompiled if optimized with the LoopStrengthReduce pass. It is unclear (to me) if LSR is "allowed" to produce wrong code with a bad TargetLowering, or if the bug is elsewhere and this patch just hides it. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@115919 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
86c3647ddf
commit
8a52fa674b
@ -3088,3 +3088,29 @@ SPUTargetLowering::isOffsetFoldingLegal(const GlobalAddressSDNode *GA) const {
|
||||
// The SPU target isn't yet aware of offsets.
|
||||
return false;
|
||||
}
|
||||
|
||||
// can we compare to Imm without writing it into a register?
|
||||
bool SPUTargetLowering::isLegalICmpImmediate(int64_t Imm) const {
|
||||
//ceqi, cgti, etc. all take s10 operand
|
||||
return isInt<10>(Imm);
|
||||
}
|
||||
|
||||
bool
|
||||
SPUTargetLowering::isLegalAddressingMode(const AddrMode &AM,
|
||||
const Type * ) const{
|
||||
|
||||
// A-form: 18bit absolute address.
|
||||
if (AM.BaseGV && !AM.HasBaseReg && AM.Scale == 0 && AM.BaseOffs == 0)
|
||||
return true;
|
||||
|
||||
// D-form: reg + 14bit offset
|
||||
if (AM.BaseGV ==0 && AM.HasBaseReg && AM.Scale == 0 && isInt<14>(AM.BaseOffs))
|
||||
return true;
|
||||
|
||||
// X-form: reg+reg
|
||||
if (AM.BaseGV == 0 && AM.HasBaseReg && AM.Scale == 1 && AM.BaseOffs ==0)
|
||||
return true;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -170,6 +170,11 @@ namespace llvm {
|
||||
const SmallVectorImpl<ISD::OutputArg> &Outs,
|
||||
const SmallVectorImpl<SDValue> &OutVals,
|
||||
DebugLoc dl, SelectionDAG &DAG) const;
|
||||
|
||||
virtual bool isLegalICmpImmediate(int64_t Imm) const;
|
||||
|
||||
virtual bool isLegalAddressingMode(const AddrMode &AM,
|
||||
const Type *Ty) const;
|
||||
};
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user