Index: lib/Analysis/AliasSetTracker.cpp =================================================================== --- lib/Analysis/AliasSetTracker.cpp +++ lib/Analysis/AliasSetTracker.cpp @@ -123,6 +123,12 @@ TotalMayAliasSetSize -= AS->size(); AliasSets.erase(AS); + // If we've removed the saturated alias set, set saturated marker back to + // nullptr and ensure this tracker is empty. + if (AS == AliasAnyAS) { + AliasAnyAS = nullptr; + assert(AliasSets.empty() && "Tracker not empty"); + } } void AliasSet::removeFromTracker(AliasSetTracker &AST) { Index: test/Transforms/LICM/pr38513.ll =================================================================== --- /dev/null +++ test/Transforms/LICM/pr38513.ll @@ -0,0 +1,26 @@ +; RUN: opt -enable-mssa-loop-dependency=false -disable-basicaa -alias-set-saturation-threshold=2 -licm -S %s | FileCheck %s +; REQUIRES: asserts + +define void @f1() { + %lc1.10 = alloca [3 x i16] + br label %bb1 + +bb1: ; preds = %bb6, %0 + store i16 undef, i16* undef + br label %bb2 + +bb2: ; preds = %bb8, %bb1 + %_tmp18.fca.0.gep = getelementptr inbounds [3 x i16], [3 x i16]* %lc1.10, i32 0, i32 0 + %_tmp18.fca.0.load = load i16, i16* %_tmp18.fca.0.gep + %_tmp18.fca.1.gep = getelementptr inbounds [3 x i16], [3 x i16]* %lc1.10, i32 0, i32 1 + %_tmp18.fca.1.load = load i16, i16* %_tmp18.fca.1.gep + %_tmp18.fca.2.gep = getelementptr inbounds [3 x i16], [3 x i16]* %lc1.10, i32 0, i32 2 + %_tmp18.fca.2.load = load i16, i16* %_tmp18.fca.2.gep + br label %bb8 + +bb8: ; preds = %bb2 + br i1 undef, label %bb2, label %bb6 + +bb6: ; preds = %bb8 + br label %bb1 +}