|  | ; RUN: opt -passes='require<profile-summary>,function(codegenprepare)' -S -mtriple=x86_64-linux < %s | FileCheck %s | 
|  |  | 
|  | declare void @llvm.assume(i1 noundef) nounwind willreturn | 
|  |  | 
|  | ; Recursively deleting dead operands of assume() may result in its next | 
|  | ; instruction deleted and the iterator pointing to the next instruction | 
|  | ; invalidated. This prevents the following simple loop in | 
|  | ; CodeGenPrepare::optimizeBlock() unless CurInstIterator is fixed: | 
|  | ; | 
|  | ;   CurInstIterator = BB.begin(); | 
|  | ;   while (CurInstIterator != BB.end()) | 
|  | ;     optimizeInst(&*CurInstIterator++, ModifiedDT); | 
|  | ; | 
|  | define i32 @test_assume_in_loop(i1 %cond1, i1 %cond2) { | 
|  | ; CHECK-LABEL: @test_assume_in_loop( | 
|  | ; CHECK-NEXT:  entry: | 
|  | entry: | 
|  | br label %loop | 
|  |  | 
|  | ; CHECK: loop: | 
|  | ; CHECK-NEXT:  br label %loop | 
|  | loop: | 
|  | %cond3 = phi i1 [%cond1, %entry], [%cond4, %loop] | 
|  | call void @llvm.assume(i1 %cond3) | 
|  | %cond4 = icmp ult i1 %cond1, %cond2 | 
|  | br label %loop | 
|  | } |