diff options
Diffstat (limited to 'lib/CodeGen')
| -rw-r--r-- | lib/CodeGen/ExecutionDepsFix.cpp | 24 | 
1 files changed, 9 insertions, 15 deletions
| diff --git a/lib/CodeGen/ExecutionDepsFix.cpp b/lib/CodeGen/ExecutionDepsFix.cpp index e7c6b03f1a49..32c57e3e3705 100644 --- a/lib/CodeGen/ExecutionDepsFix.cpp +++ b/lib/CodeGen/ExecutionDepsFix.cpp @@ -707,9 +707,8 @@ void ExeDepsFix::visitSoftInstr(MachineInstr *mi, unsigned mask) {    // Kill off any remaining uses that don't match available, and build a list of    // incoming DomainValues that we want to merge. -  SmallVector<LiveReg, 4> Regs; -  for (SmallVectorImpl<int>::iterator i=used.begin(), e=used.end(); i!=e; ++i) { -    int rx = *i; +  SmallVector<const LiveReg *, 4> Regs; +  for (int rx : used) {      assert(LiveRegs && "no space allocated for live registers");      const LiveReg &LR = LiveRegs[rx];      // This useless DomainValue could have been missed above. @@ -718,16 +717,11 @@ void ExeDepsFix::visitSoftInstr(MachineInstr *mi, unsigned mask) {        continue;      }      // Sorted insertion. -    bool Inserted = false; -    for (SmallVectorImpl<LiveReg>::iterator i = Regs.begin(), e = Regs.end(); -           i != e && !Inserted; ++i) { -      if (LR.Def < i->Def) { -        Inserted = true; -        Regs.insert(i, LR); -      } -    } -    if (!Inserted) -      Regs.push_back(LR); +    auto I = std::upper_bound(Regs.begin(), Regs.end(), &LR, +                              [](const LiveReg *LHS, const LiveReg *RHS) { +                                return LHS->Def < RHS->Def; +                              }); +    Regs.insert(I, &LR);    }    // doms are now sorted in order of appearance. Try to merge them all, giving @@ -735,14 +729,14 @@ void ExeDepsFix::visitSoftInstr(MachineInstr *mi, unsigned mask) {    DomainValue *dv = nullptr;    while (!Regs.empty()) {      if (!dv) { -      dv = Regs.pop_back_val().Value; +      dv = Regs.pop_back_val()->Value;        // Force the first dv to match the current instruction.        dv->AvailableDomains = dv->getCommonDomains(available);        assert(dv->AvailableDomains && "Domain should have been filtered");        continue;      } -    DomainValue *Latest = Regs.pop_back_val().Value; +    DomainValue *Latest = Regs.pop_back_val()->Value;      // Skip already merged values.      if (Latest == dv || Latest->Next)        continue; | 
