mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-26 02:22:29 +00:00 
			
		
		
		
	This provides an implementation of CFL alias analysis (including some supporting data structures). Currently, we don't have any extremely fancy features, sans some interprocedural analysis (i.e. no field sensitivity, etc.), and we do best sitting behind BasicAA + TBAA. In such a configuration, we take ~0.6-0.8% of total compile time, and give ~7-8% NoAlias responses to queries TBAA and BasicAA couldn't answer when bootstrapping LLVM. In testing this on other projects, we've seen up to 10.5% of queries dropped by BasicAA+TBAA answered with NoAlias by this algorithm. Patch by George Burgess IV (with minor modifications by me -- mostly adapting some BasicAA tests), thanks! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@216970 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; RUN: opt < %s -cfl-aa -aa-eval -print-all-alias-modref-info 2>&1 | FileCheck %s
 | |
| 
 | |
| ; When merging MustAlias and PartialAlias, merge to PartialAlias
 | |
| ; instead of MayAlias.
 | |
| 
 | |
| 
 | |
| target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
 | |
| 
 | |
| ; CHECK: PartialAlias:  i16* %bigbase0, i8* %phi
 | |
| define i8 @test0(i8* %base, i1 %x) {
 | |
| entry:
 | |
|   %baseplusone = getelementptr i8* %base, i64 1
 | |
|   br i1 %x, label %red, label %green
 | |
| red:
 | |
|   br label %green
 | |
| green:
 | |
|   %phi = phi i8* [ %baseplusone, %red ], [ %base, %entry ]
 | |
|   store i8 0, i8* %phi
 | |
| 
 | |
|   %bigbase0 = bitcast i8* %base to i16*
 | |
|   store i16 -1, i16* %bigbase0
 | |
| 
 | |
|   %loaded = load i8* %phi
 | |
|   ret i8 %loaded
 | |
| }
 | |
| 
 | |
| ; CHECK: PartialAlias:  i16* %bigbase1, i8* %sel
 | |
| define i8 @test1(i8* %base, i1 %x) {
 | |
| entry:
 | |
|   %baseplusone = getelementptr i8* %base, i64 1
 | |
|   %sel = select i1 %x, i8* %baseplusone, i8* %base
 | |
|   store i8 0, i8* %sel
 | |
| 
 | |
|   %bigbase1 = bitcast i8* %base to i16*
 | |
|   store i16 -1, i16* %bigbase1
 | |
| 
 | |
|   %loaded = load i8* %sel
 | |
|   ret i8 %loaded
 | |
| }
 |