mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-21 03:32:21 +00:00
pre-RA-sched: fix TargetOpcode usage
TargetOpcodes need to be treaded as Machine- and not ISD-Opcodes. Signed-off-by: Christian König <christian.koenig@amd.com> git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@177518 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
fd060a94a4
commit
06091513c2
@ -1894,12 +1894,15 @@ unsigned RegReductionPQBase::getNodePriority(const SUnit *SU) const {
|
|||||||
// CopyToReg should be close to its uses to facilitate coalescing and
|
// CopyToReg should be close to its uses to facilitate coalescing and
|
||||||
// avoid spilling.
|
// avoid spilling.
|
||||||
return 0;
|
return 0;
|
||||||
if (Opc == TargetOpcode::EXTRACT_SUBREG ||
|
if (SU->getNode() && SU->getNode()->isMachineOpcode()) {
|
||||||
Opc == TargetOpcode::SUBREG_TO_REG ||
|
Opc = SU->getNode()->getMachineOpcode();
|
||||||
Opc == TargetOpcode::INSERT_SUBREG)
|
if (Opc == TargetOpcode::EXTRACT_SUBREG ||
|
||||||
// EXTRACT_SUBREG, INSERT_SUBREG, and SUBREG_TO_REG nodes should be
|
Opc == TargetOpcode::SUBREG_TO_REG ||
|
||||||
// close to their uses to facilitate coalescing.
|
Opc == TargetOpcode::INSERT_SUBREG)
|
||||||
return 0;
|
// EXTRACT_SUBREG, INSERT_SUBREG, and SUBREG_TO_REG nodes should be
|
||||||
|
// close to their uses to facilitate coalescing.
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
if (SU->NumSuccs == 0 && SU->NumPreds != 0)
|
if (SU->NumSuccs == 0 && SU->NumPreds != 0)
|
||||||
// If SU does not have a register use, i.e. it doesn't produce a value
|
// If SU does not have a register use, i.e. it doesn't produce a value
|
||||||
// that would be consumed (e.g. store), then it terminates a chain of
|
// that would be consumed (e.g. store), then it terminates a chain of
|
||||||
@ -2585,12 +2588,15 @@ static bool canEnableCoalescing(SUnit *SU) {
|
|||||||
// avoid spilling.
|
// avoid spilling.
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
if (Opc == TargetOpcode::EXTRACT_SUBREG ||
|
if (SU->getNode() && SU->getNode()->isMachineOpcode()) {
|
||||||
Opc == TargetOpcode::SUBREG_TO_REG ||
|
Opc = SU->getNode()->getMachineOpcode();
|
||||||
Opc == TargetOpcode::INSERT_SUBREG)
|
if (Opc == TargetOpcode::EXTRACT_SUBREG ||
|
||||||
// EXTRACT_SUBREG, INSERT_SUBREG, and SUBREG_TO_REG nodes should be
|
Opc == TargetOpcode::SUBREG_TO_REG ||
|
||||||
// close to their uses to facilitate coalescing.
|
Opc == TargetOpcode::INSERT_SUBREG)
|
||||||
return true;
|
// EXTRACT_SUBREG, INSERT_SUBREG, and SUBREG_TO_REG nodes should be
|
||||||
|
// close to their uses to facilitate coalescing.
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
if (SU->NumPreds == 0 && SU->NumSuccs != 0)
|
if (SU->NumPreds == 0 && SU->NumSuccs != 0)
|
||||||
// If SU does not have a register def, schedule it close to its uses
|
// If SU does not have a register def, schedule it close to its uses
|
||||||
|
Loading…
x
Reference in New Issue
Block a user