diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2011-06-12 18:01:31 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2011-06-12 18:01:31 +0000 | 
| commit | bd5abe19687421cb3ad4dca066732ed0b437531b (patch) | |
| tree | a9b264321873e7d25e69b8671c9f705ebc6d30ee /contrib/llvm/lib/CodeGen/MachineInstr.cpp | |
| parent | 74d92904a6e0f2d301cdeec3f8af4fbe4a968146 (diff) | |
| parent | 56fe8f14099930935e3870e3e823c322a85c1c89 (diff) | |
Notes
Diffstat (limited to 'contrib/llvm/lib/CodeGen/MachineInstr.cpp')
| -rw-r--r-- | contrib/llvm/lib/CodeGen/MachineInstr.cpp | 33 | 
1 files changed, 25 insertions, 8 deletions
diff --git a/contrib/llvm/lib/CodeGen/MachineInstr.cpp b/contrib/llvm/lib/CodeGen/MachineInstr.cpp index 71df6f8b7701..36b0b8330a86 100644 --- a/contrib/llvm/lib/CodeGen/MachineInstr.cpp +++ b/contrib/llvm/lib/CodeGen/MachineInstr.cpp @@ -125,7 +125,8 @@ void MachineOperand::substPhysReg(unsigned Reg, const TargetRegisterInfo &TRI) {    assert(TargetRegisterInfo::isPhysicalRegister(Reg));    if (getSubReg()) {      Reg = TRI.getSubReg(Reg, getSubReg()); -    assert(Reg && "Invalid SubReg for physical register"); +    // Note that getSubReg() may return 0 if the sub-register doesn't exist. +    // That won't happen in legal code.      setSubReg(0);    }    setReg(Reg); @@ -763,19 +764,35 @@ bool MachineInstr::isIdenticalTo(const MachineInstr *Other,    for (unsigned i = 0, e = getNumOperands(); i != e; ++i) {      const MachineOperand &MO = getOperand(i);      const MachineOperand &OMO = Other->getOperand(i); +    if (!MO.isReg()) { +      if (!MO.isIdenticalTo(OMO)) +        return false; +      continue; +    } +      // Clients may or may not want to ignore defs when testing for equality.      // For example, machine CSE pass only cares about finding common      // subexpressions, so it's safe to ignore virtual register defs. -    if (Check != CheckDefs && MO.isReg() && MO.isDef()) { +    if (MO.isDef()) {        if (Check == IgnoreDefs)          continue; -      // Check == IgnoreVRegDefs -      if (TargetRegisterInfo::isPhysicalRegister(MO.getReg()) || -          TargetRegisterInfo::isPhysicalRegister(OMO.getReg())) -        if (MO.getReg() != OMO.getReg()) +      else if (Check == IgnoreVRegDefs) { +        if (TargetRegisterInfo::isPhysicalRegister(MO.getReg()) || +            TargetRegisterInfo::isPhysicalRegister(OMO.getReg())) +          if (MO.getReg() != OMO.getReg()) +            return false; +      } else { +        if (!MO.isIdenticalTo(OMO))            return false; -    } else if (!MO.isIdenticalTo(OMO)) -      return false; +        if (Check == CheckKillDead && MO.isDead() != OMO.isDead()) +          return false; +      } +    } else { +      if (!MO.isIdenticalTo(OMO)) +        return false; +      if (Check == CheckKillDead && MO.isKill() != OMO.isKill()) +        return false; +    }    }    return true;  }  | 
