You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			47 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; RUN: opt %loadPolly -polly-import-jscop -polly-import-jscop-postfix=transformed -polly-allow-nonaffine-loops -polly-simplify -analyze < %s | FileCheck %s -match-full-lines
 | |
| ;
 | |
| ; Do not remove the store in region_entry. It can be executed multiple times
 | |
| ; due to being part of a non-affine loop.
 | |
| ;
 | |
| define void @notredundant_region_loop(i32 %n, double* noalias nonnull %A) {
 | |
| entry:
 | |
|   br label %for
 | |
| 
 | |
| for:
 | |
|   %j = phi i32 [0, %entry], [%j.inc, %inc]
 | |
|   %j.cmp = icmp slt i32 %j, %n
 | |
|   br i1 %j.cmp, label %body, label %exit
 | |
| 
 | |
| 
 | |
|     body:
 | |
|       %val = fadd double 21.0, 21.0
 | |
|       br label %region_entry
 | |
| 
 | |
|     region_entry:
 | |
|       store double %val, double* %A
 | |
|       %sqr = mul i32 %j, %j
 | |
|       %cmp = icmp eq i32 %sqr, 42
 | |
|       br i1 %cmp, label %region_true, label %region_exit
 | |
| 
 | |
|     region_true:
 | |
|       store double 0.0, double* %A
 | |
|       br label %region_entry
 | |
| 
 | |
|     region_exit:
 | |
|       br label %inc
 | |
| 
 | |
| 
 | |
| inc:
 | |
|   %j.inc = add nuw nsw i32 %j, 1
 | |
|   br label %for
 | |
| 
 | |
| exit:
 | |
|   br label %return
 | |
| 
 | |
| return:
 | |
|   ret void
 | |
| }
 | |
| 
 | |
| 
 | |
| ; CHECK: SCoP could not be simplified
 |