mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-23 02:32:11 +00:00
Change the prototype for TargetLowering::isOperandValidForConstraint
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31318 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
cbea67f55b
commit
dba1aeedd8
@ -694,9 +694,12 @@ public:
|
|||||||
MVT::ValueType VT) const;
|
MVT::ValueType VT) const;
|
||||||
|
|
||||||
|
|
||||||
/// isOperandValidForConstraint - Return true if the specified SDOperand is
|
/// isOperandValidForConstraint - Return the specified operand (possibly
|
||||||
/// valid for the specified target constraint letter.
|
/// modified) if the specified SDOperand is valid for the specified target
|
||||||
virtual bool isOperandValidForConstraint(SDOperand Op, char ConstraintLetter);
|
/// constraint letter, otherwise return null.
|
||||||
|
virtual SDOperand
|
||||||
|
isOperandValidForConstraint(SDOperand Op, char ConstraintLetter,
|
||||||
|
SelectionDAG &DAG);
|
||||||
|
|
||||||
//===--------------------------------------------------------------------===//
|
//===--------------------------------------------------------------------===//
|
||||||
// Scheduler hooks
|
// Scheduler hooks
|
||||||
|
@ -1300,18 +1300,21 @@ TargetLowering::getConstraintType(char ConstraintLetter) const {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool TargetLowering::isOperandValidForConstraint(SDOperand Op,
|
/// isOperandValidForConstraint - Return the specified operand (possibly
|
||||||
char ConstraintLetter) {
|
/// modified) if the specified SDOperand is valid for the specified target
|
||||||
|
/// constraint letter, otherwise return null.
|
||||||
|
SDOperand TargetLowering::isOperandValidForConstraint(SDOperand Op,
|
||||||
|
char ConstraintLetter,
|
||||||
|
SelectionDAG &DAG) {
|
||||||
switch (ConstraintLetter) {
|
switch (ConstraintLetter) {
|
||||||
default: return false;
|
default: return SDOperand(0,0);
|
||||||
case 'i': // Simple Integer or Relocatable Constant
|
case 'i': // Simple Integer or Relocatable Constant
|
||||||
case 'n': // Simple Integer
|
case 'n': // Simple Integer
|
||||||
case 's': // Relocatable Constant
|
case 's': // Relocatable Constant
|
||||||
return true; // FIXME: not right.
|
return Op; // FIXME: not right.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
std::vector<unsigned> TargetLowering::
|
std::vector<unsigned> TargetLowering::
|
||||||
getRegClassForInlineAsmConstraint(const std::string &Constraint,
|
getRegClassForInlineAsmConstraint(const std::string &Constraint,
|
||||||
MVT::ValueType VT) const {
|
MVT::ValueType VT) const {
|
||||||
|
@ -2658,8 +2658,8 @@ getRegClassForInlineAsmConstraint(const std::string &Constraint,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// isOperandValidForConstraint
|
// isOperandValidForConstraint
|
||||||
bool PPCTargetLowering::
|
SDOperand PPCTargetLowering::
|
||||||
isOperandValidForConstraint(SDOperand Op, char Letter) {
|
isOperandValidForConstraint(SDOperand Op, char Letter, SelectionDAG &DAG) {
|
||||||
switch (Letter) {
|
switch (Letter) {
|
||||||
default: break;
|
default: break;
|
||||||
case 'I':
|
case 'I':
|
||||||
@ -2670,32 +2670,39 @@ isOperandValidForConstraint(SDOperand Op, char Letter) {
|
|||||||
case 'N':
|
case 'N':
|
||||||
case 'O':
|
case 'O':
|
||||||
case 'P': {
|
case 'P': {
|
||||||
if (!isa<ConstantSDNode>(Op)) return false; // Must be an immediate.
|
if (!isa<ConstantSDNode>(Op)) return SDOperand(0,0);// Must be an immediate.
|
||||||
unsigned Value = cast<ConstantSDNode>(Op)->getValue();
|
unsigned Value = cast<ConstantSDNode>(Op)->getValue();
|
||||||
switch (Letter) {
|
switch (Letter) {
|
||||||
default: assert(0 && "Unknown constraint letter!");
|
default: assert(0 && "Unknown constraint letter!");
|
||||||
case 'I': // "I" is a signed 16-bit constant.
|
case 'I': // "I" is a signed 16-bit constant.
|
||||||
return (short)Value == (int)Value;
|
if ((short)Value == (int)Value) return Op;
|
||||||
|
break;
|
||||||
case 'J': // "J" is a constant with only the high-order 16 bits nonzero.
|
case 'J': // "J" is a constant with only the high-order 16 bits nonzero.
|
||||||
case 'L': // "L" is a signed 16-bit constant shifted left 16 bits.
|
case 'L': // "L" is a signed 16-bit constant shifted left 16 bits.
|
||||||
return (short)Value == 0;
|
if ((short)Value == 0) return Op;
|
||||||
|
break;
|
||||||
case 'K': // "K" is a constant with only the low-order 16 bits nonzero.
|
case 'K': // "K" is a constant with only the low-order 16 bits nonzero.
|
||||||
return (Value >> 16) == 0;
|
if ((Value >> 16) == 0) return Op;
|
||||||
|
break;
|
||||||
case 'M': // "M" is a constant that is greater than 31.
|
case 'M': // "M" is a constant that is greater than 31.
|
||||||
return Value > 31;
|
if (Value > 31) return Op;
|
||||||
|
break;
|
||||||
case 'N': // "N" is a positive constant that is an exact power of two.
|
case 'N': // "N" is a positive constant that is an exact power of two.
|
||||||
return (int)Value > 0 && isPowerOf2_32(Value);
|
if ((int)Value > 0 && isPowerOf2_32(Value)) return Op;
|
||||||
|
break;
|
||||||
case 'O': // "O" is the constant zero.
|
case 'O': // "O" is the constant zero.
|
||||||
return Value == 0;
|
if (Value == 0) return Op;
|
||||||
|
break;
|
||||||
case 'P': // "P" is a constant whose negation is a signed 16-bit constant.
|
case 'P': // "P" is a constant whose negation is a signed 16-bit constant.
|
||||||
return (short)-Value == (int)-Value;
|
if ((short)-Value == (int)-Value) return Op;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Handle standard constraint letters.
|
// Handle standard constraint letters.
|
||||||
return TargetLowering::isOperandValidForConstraint(Op, Letter);
|
return TargetLowering::isOperandValidForConstraint(Op, Letter, DAG);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// isLegalAddressImmediate - Return true if the integer value can be used
|
/// isLegalAddressImmediate - Return true if the integer value can be used
|
||||||
|
@ -194,7 +194,8 @@ namespace llvm {
|
|||||||
std::vector<unsigned>
|
std::vector<unsigned>
|
||||||
getRegClassForInlineAsmConstraint(const std::string &Constraint,
|
getRegClassForInlineAsmConstraint(const std::string &Constraint,
|
||||||
MVT::ValueType VT) const;
|
MVT::ValueType VT) const;
|
||||||
bool isOperandValidForConstraint(SDOperand Op, char ConstraintLetter);
|
SDOperand isOperandValidForConstraint(SDOperand Op, char ConstraintLetter,
|
||||||
|
SelectionDAG &DAG);
|
||||||
|
|
||||||
/// isLegalAddressImmediate - Return true if the integer value can be used
|
/// isLegalAddressImmediate - Return true if the integer value can be used
|
||||||
/// as the offset of the target addressing mode.
|
/// as the offset of the target addressing mode.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user