mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
emit TIED_TO correctly
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31484 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d9a7f4db5f
commit
29434364dd
@ -297,7 +297,7 @@ static std::string ParseConstraint(const std::string &CStr,
|
||||
throw "Illegal tied-to operand constraint '" + CStr + "'";
|
||||
|
||||
// Build the string.
|
||||
return "((" + utostr(TIdx) + " << 16) | TargetInstrInfo::TIED_TO)";
|
||||
return "((" + utostr(TIdx) + " << 16) | (1 << TargetInstrInfo::TIED_TO))";
|
||||
}
|
||||
|
||||
static void ParseConstraints(const std::string &CStr, CodeGenInstruction *I) {
|
||||
@ -408,7 +408,7 @@ CodeGenInstruction::CodeGenInstruction(Record *R, const std::string &AsmStr)
|
||||
// For backward compatibility: isTwoAddress means operand 1 is tied to
|
||||
// operand 0.
|
||||
if (isTwoAddress && OperandList[1].Constraint.empty())
|
||||
OperandList[1].Constraint = "((0 << 16) | TargetInstrInfo::TIED_TO)";
|
||||
OperandList[1].Constraint = "((0 << 16) | (1 << TargetInstrInfo::TIED_TO))";
|
||||
|
||||
// Any operands with unset constraints get 0 as their constraint.
|
||||
for (unsigned op = 0, e = OperandList.size(); op != e; ++op)
|
||||
|
Loading…
x
Reference in New Issue
Block a user