Skip to content

Commit

Permalink
LiveRegUnits: Do not use phys_regs_and_masks
Browse files Browse the repository at this point in the history
Somehow DeadMachineInstructionElim is about 3x slower when using it.
Hopefully this reverses the compile time regression reported for
b504152.
  • Loading branch information
arsenm committed Sep 12, 2022
1 parent ab56719 commit d90f7cb
Showing 1 changed file with 15 additions and 8 deletions.
23 changes: 15 additions & 8 deletions llvm/lib/CodeGen/LiveRegUnits.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -39,34 +39,41 @@ void LiveRegUnits::addRegsInMask(const uint32_t *RegMask) {

void LiveRegUnits::stepBackward(const MachineInstr &MI) {
// Remove defined registers and regmask kills from the set.
for (const MachineOperand &MOP : phys_regs_and_masks(MI)) {
for (const MachineOperand &MOP : MI.operands()) {
if (MOP.isRegMask()) {
removeRegsNotPreserved(MOP.getRegMask());
continue;
}

if (MOP.isDef())
if (MOP.isReg() && MOP.isDef() && MOP.getReg().isPhysical())
removeReg(MOP.getReg());
}

// Add uses to the set.
for (const MachineOperand &MOP : phys_regs_and_masks(MI)) {
for (const MachineOperand &MOP : MI.operands()) {
if (!MOP.isReg() || !MOP.readsReg())
continue;
addReg(MOP.getReg());

if (MOP.getReg() && MOP.getReg().isPhysical())
addReg(MOP.getReg());
}
}

void LiveRegUnits::accumulate(const MachineInstr &MI) {
// Add defs, uses and regmask clobbers to the set.
for (const MachineOperand &MOP : phys_regs_and_masks(MI)) {
for (const MachineOperand &MOP : MI.operands()) {
if (MOP.isReg()) {
if (!MOP.getReg().isPhysical())
continue;
if (MOP.isDef() || MOP.readsReg())
addReg(MOP.getReg());
continue;
}

if (MOP.isRegMask()) {
addRegsInMask(MOP.getRegMask());
continue;
}
if (!MOP.isDef() && !MOP.readsReg())
continue;
addReg(MOP.getReg());
}
}

Expand Down

0 comments on commit d90f7cb

Please sign in to comment.