diff options
Diffstat (limited to 'llvm/lib/Transforms/AggressiveInstCombine')
| -rw-r--r-- | llvm/lib/Transforms/AggressiveInstCombine/AggressiveInstCombine.cpp | 12 | 
1 files changed, 11 insertions, 1 deletions
| diff --git a/llvm/lib/Transforms/AggressiveInstCombine/AggressiveInstCombine.cpp b/llvm/lib/Transforms/AggressiveInstCombine/AggressiveInstCombine.cpp index bbbac45..7a95df4 100644 --- a/llvm/lib/Transforms/AggressiveInstCombine/AggressiveInstCombine.cpp +++ b/llvm/lib/Transforms/AggressiveInstCombine/AggressiveInstCombine.cpp @@ -907,10 +907,20 @@ static bool mergeConsecutivePartStores(ArrayRef<PartStore> Parts,    StoreInst *Store = Builder.CreateAlignedStore(        Val, First.Store->getPointerOperand(), First.Store->getAlign()); +  // Merge various metadata onto the new store.    AAMDNodes AATags = First.Store->getAAMetadata(); -  for (const PartStore &Part : drop_begin(Parts)) +  SmallVector<Instruction *> Stores = {First.Store}; +  Stores.reserve(Parts.size()); +  SmallVector<DebugLoc> DbgLocs = {First.Store->getDebugLoc()}; +  DbgLocs.reserve(Parts.size()); +  for (const PartStore &Part : drop_begin(Parts)) {      AATags = AATags.concat(Part.Store->getAAMetadata()); +    Stores.push_back(Part.Store); +    DbgLocs.push_back(Part.Store->getDebugLoc()); +  }    Store->setAAMetadata(AATags); +  Store->mergeDIAssignID(Stores); +  Store->setDebugLoc(DebugLoc::getMergedLocations(DbgLocs));    // Remove the old stores.    for (const PartStore &Part : Parts) | 
