mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-23 17:32:49 +00:00
Fix some latent bugs if the nodes are unschedulable. We'd gotten away
with this before since none of the register tracking or nightly tests had unschedulable nodes. This should probably be refixed with a special default Node that just returns some "don't touch me" values. Fixes PR9427 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@127263 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4cdcb36289
commit
29449448b0
@ -1785,7 +1785,7 @@ int RegReductionPQBase::RegPressureDiff(SUnit *SU, unsigned &LiveUses) const {
|
|||||||
}
|
}
|
||||||
const SDNode *N = SU->getNode();
|
const SDNode *N = SU->getNode();
|
||||||
|
|
||||||
if (!N->isMachineOpcode() || !SU->NumSuccs)
|
if (!N || !N->isMachineOpcode() || !SU->NumSuccs)
|
||||||
return PDiff;
|
return PDiff;
|
||||||
|
|
||||||
unsigned NumDefs = TII->get(N->getMachineOpcode()).getNumDefs();
|
unsigned NumDefs = TII->get(N->getMachineOpcode()).getNumDefs();
|
||||||
@ -1804,6 +1804,9 @@ void RegReductionPQBase::ScheduledNode(SUnit *SU) {
|
|||||||
if (!TracksRegPressure)
|
if (!TracksRegPressure)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (!SU->getNode())
|
||||||
|
return;
|
||||||
|
|
||||||
for (SUnit::pred_iterator I = SU->Preds.begin(), E = SU->Preds.end();
|
for (SUnit::pred_iterator I = SU->Preds.begin(), E = SU->Preds.end();
|
||||||
I != E; ++I) {
|
I != E; ++I) {
|
||||||
if (I->isCtrl())
|
if (I->isCtrl())
|
||||||
@ -1870,6 +1873,8 @@ void RegReductionPQBase::UnscheduledNode(SUnit *SU) {
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
const SDNode *N = SU->getNode();
|
const SDNode *N = SU->getNode();
|
||||||
|
if (!N) return;
|
||||||
|
|
||||||
if (!N->isMachineOpcode()) {
|
if (!N->isMachineOpcode()) {
|
||||||
if (N->getOpcode() != ISD::CopyToReg)
|
if (N->getOpcode() != ISD::CopyToReg)
|
||||||
return;
|
return;
|
||||||
|
@ -446,6 +446,10 @@ void ScheduleDAGSDNodes::BuildSchedGraph(AliasAnalysis *AA) {
|
|||||||
|
|
||||||
// Initialize NumNodeDefs for the current Node's opcode.
|
// Initialize NumNodeDefs for the current Node's opcode.
|
||||||
void ScheduleDAGSDNodes::RegDefIter::InitNodeNumDefs() {
|
void ScheduleDAGSDNodes::RegDefIter::InitNodeNumDefs() {
|
||||||
|
// Check for phys reg copy.
|
||||||
|
if (!Node)
|
||||||
|
return;
|
||||||
|
|
||||||
if (!Node->isMachineOpcode()) {
|
if (!Node->isMachineOpcode()) {
|
||||||
if (Node->getOpcode() == ISD::CopyFromReg)
|
if (Node->getOpcode() == ISD::CopyFromReg)
|
||||||
NodeNumDefs = 1;
|
NodeNumDefs = 1;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user