mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-22 10:24:26 +00:00
Add support for the 'x' constraint.
Patch by Jack Carter. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@156295 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -3001,7 +3001,8 @@ getConstraintType(const std::string &Constraint) const
|
|||||||
// backwards compatibility.
|
// backwards compatibility.
|
||||||
// 'c' : A register suitable for use in an indirect
|
// 'c' : A register suitable for use in an indirect
|
||||||
// jump. This will always be $25 for -mabicalls.
|
// jump. This will always be $25 for -mabicalls.
|
||||||
// 'l' : The lo register.
|
// 'l' : The lo register. 1 word storage.
|
||||||
|
// 'x' : The hilo register pair. Double word storage.
|
||||||
if (Constraint.size() == 1) {
|
if (Constraint.size() == 1) {
|
||||||
switch (Constraint[0]) {
|
switch (Constraint[0]) {
|
||||||
default : break;
|
default : break;
|
||||||
@ -3010,6 +3011,7 @@ getConstraintType(const std::string &Constraint) const
|
|||||||
case 'f':
|
case 'f':
|
||||||
case 'c':
|
case 'c':
|
||||||
case 'l':
|
case 'l':
|
||||||
|
case 'x':
|
||||||
return C_RegisterClass;
|
return C_RegisterClass;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3045,6 +3047,7 @@ MipsTargetLowering::getSingleConstraintMatchWeight(
|
|||||||
break;
|
break;
|
||||||
case 'c': // $25 for indirect jumps
|
case 'c': // $25 for indirect jumps
|
||||||
case 'l': // lo register
|
case 'l': // lo register
|
||||||
|
case 'x': // hilo register pair
|
||||||
if (type->isIntegerTy())
|
if (type->isIntegerTy())
|
||||||
weight = CW_SpecificReg;
|
weight = CW_SpecificReg;
|
||||||
break;
|
break;
|
||||||
@ -3097,6 +3100,10 @@ getRegForInlineAsmConstraint(const std::string &Constraint, EVT VT) const
|
|||||||
if (VT == MVT::i32)
|
if (VT == MVT::i32)
|
||||||
return std::make_pair((unsigned)Mips::LO, &Mips::HILORegClass);
|
return std::make_pair((unsigned)Mips::LO, &Mips::HILORegClass);
|
||||||
return std::make_pair((unsigned)Mips::LO64, &Mips::HILO64RegClass);
|
return std::make_pair((unsigned)Mips::LO64, &Mips::HILO64RegClass);
|
||||||
|
case 'x': // register suitable for indirect jump
|
||||||
|
// Fixme: Not triggering the use of both hi and low
|
||||||
|
// This will generate an error message
|
||||||
|
return std::make_pair(0u, static_cast<const TargetRegisterClass*>(0));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return TargetLowering::getRegForInlineAsmConstraint(Constraint, VT);
|
return TargetLowering::getRegForInlineAsmConstraint(Constraint, VT);
|
||||||
|
Reference in New Issue
Block a user