mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
Fix emission of instructions that directly reference MBBs
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7771 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
175724f2d3
commit
42f3372742
@ -1205,15 +1205,21 @@ void InstrSelectorEmitter::run(std::ostream &OS) {
|
|||||||
if (P->getResult()) OS << ", NewReg";
|
if (P->getResult()) OS << ", NewReg";
|
||||||
OS << ")";
|
OS << ")";
|
||||||
|
|
||||||
for (unsigned i = 0, e = Operands.size(); i != e; ++i)
|
for (unsigned i = 0, e = Operands.size(); i != e; ++i) {
|
||||||
if (Operands[i].first->isLeaf()) {
|
TreePatternNode *Op = Operands[i].first;
|
||||||
Record *RV = Operands[i].first->getValueRecord();
|
if (Op->isLeaf()) {
|
||||||
|
Record *RV = Op->getValueRecord();
|
||||||
assert(RV->isSubClassOf("RegisterClass") &&
|
assert(RV->isSubClassOf("RegisterClass") &&
|
||||||
"Only handles registers here so far!");
|
"Only handles registers here so far!");
|
||||||
OS << ".addReg(" << Operands[i].second << "->Val)";
|
OS << ".addReg(" << Operands[i].second << "->Val)";
|
||||||
} else {
|
} else if (Op->getOperator()->getName() == "imm") {
|
||||||
OS << ".addZImm(" << Operands[i].second << "->Val)";
|
OS << ".addZImm(" << Operands[i].second << "->Val)";
|
||||||
|
} else if (Op->getOperator()->getName() == "basicblock") {
|
||||||
|
OS << ".addMBB(" << Operands[i].second << "->Val)";
|
||||||
|
} else {
|
||||||
|
assert(0 && "Unknown value type!");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
OS << ";\n";
|
OS << ";\n";
|
||||||
break;
|
break;
|
||||||
case Pattern::Expander: {
|
case Pattern::Expander: {
|
||||||
|
@ -1205,15 +1205,21 @@ void InstrSelectorEmitter::run(std::ostream &OS) {
|
|||||||
if (P->getResult()) OS << ", NewReg";
|
if (P->getResult()) OS << ", NewReg";
|
||||||
OS << ")";
|
OS << ")";
|
||||||
|
|
||||||
for (unsigned i = 0, e = Operands.size(); i != e; ++i)
|
for (unsigned i = 0, e = Operands.size(); i != e; ++i) {
|
||||||
if (Operands[i].first->isLeaf()) {
|
TreePatternNode *Op = Operands[i].first;
|
||||||
Record *RV = Operands[i].first->getValueRecord();
|
if (Op->isLeaf()) {
|
||||||
|
Record *RV = Op->getValueRecord();
|
||||||
assert(RV->isSubClassOf("RegisterClass") &&
|
assert(RV->isSubClassOf("RegisterClass") &&
|
||||||
"Only handles registers here so far!");
|
"Only handles registers here so far!");
|
||||||
OS << ".addReg(" << Operands[i].second << "->Val)";
|
OS << ".addReg(" << Operands[i].second << "->Val)";
|
||||||
} else {
|
} else if (Op->getOperator()->getName() == "imm") {
|
||||||
OS << ".addZImm(" << Operands[i].second << "->Val)";
|
OS << ".addZImm(" << Operands[i].second << "->Val)";
|
||||||
|
} else if (Op->getOperator()->getName() == "basicblock") {
|
||||||
|
OS << ".addMBB(" << Operands[i].second << "->Val)";
|
||||||
|
} else {
|
||||||
|
assert(0 && "Unknown value type!");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
OS << ";\n";
|
OS << ";\n";
|
||||||
break;
|
break;
|
||||||
case Pattern::Expander: {
|
case Pattern::Expander: {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user