mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-26 18:20:39 +00:00 
			
		
		
		
	can move instructions within the instruction list. If the instruction just happens to be the one the basic block iterator is pointing to, and it is moved to a different basic block, then we get into an infinite loop due to the iterator running off the end of the basic block (for some reason this doesn't fire any assertions). Original commit message: Grab-bag of reassociate tweaks. Unify handling of dead instructions and instructions to reoptimize. Exploit this to more systematically eliminate dead instructions (this isn't very useful in practice but is convenient for analysing some testcase I am working on). No need for WeakVH any more: use an AssertingVH instead. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@158199 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			22 lines
		
	
	
		
			631 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			22 lines
		
	
	
		
			631 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; RUN: opt < %s -reassociate -disable-output
 | |
| ; PR13041
 | |
| 
 | |
| define void @foo() {
 | |
| entry:
 | |
|   br label %while.cond
 | |
| 
 | |
| while.cond:                                       ; preds = %while.body, %entry
 | |
|   %b.0 = phi i32 [ undef, %entry ], [ %sub2, %while.body ]
 | |
|   %c.0 = phi i32 [ undef, %entry ], [ %sub3, %while.body ]
 | |
|   br i1 undef, label %while.end, label %while.body
 | |
| 
 | |
| while.body:                                       ; preds = %while.cond
 | |
|   %sub = sub nsw i32 0, %b.0
 | |
|   %sub2 = sub nsw i32 %sub, %c.0
 | |
|   %sub3 = sub nsw i32 0, %c.0
 | |
|   br label %while.cond
 | |
| 
 | |
| while.end:                                        ; preds = %while.cond
 | |
|   ret void
 | |
| }
 |