mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Migrate _chk call lowering from SimplifyLibCalls to InstCombine. Stub
out the remainder of the calls that we should lower in some way and move the tests to the new correct directory. Fix up tests that are now optimized more than they were before by -instcombine. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@97875 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -1,18 +0,0 @@ | ||||
| ; RUN: opt < %s -simplify-libcalls -S | FileCheck %s | ||||
| ; rdar://7719085 | ||||
|  | ||||
| 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" | ||||
|  | ||||
| %struct.data = type { [100 x i32], [100 x i32], [1024 x i8] } | ||||
|  | ||||
| define i32 @t() nounwind ssp { | ||||
| ; CHECK: @t | ||||
| ; CHECK: @llvm.memset.i64 | ||||
| entry: | ||||
|   %0 = alloca %struct.data, align 8               ; <%struct.data*> [#uses=1] | ||||
|   %1 = bitcast %struct.data* %0 to i8*            ; <i8*> [#uses=1] | ||||
|   %2 = call i8* @__memset_chk(i8* %1, i32 0, i64 1824, i64 1824) nounwind ; <i8*> [#uses=0] | ||||
|   ret i32 0 | ||||
| } | ||||
|  | ||||
| declare i8* @__memset_chk(i8*, i32, i64, i64) nounwind | ||||
| @@ -1,12 +0,0 @@ | ||||
| ; RUN: opt < %s -simplify-libcalls -S | FileCheck %s | ||||
| @a = common global [60 x i8] zeroinitializer, align 1 ; <[60 x i8]*> [#uses=1] | ||||
| @.str = private constant [8 x i8] c"abcdefg\00"   ; <[8 x i8]*> [#uses=1] | ||||
|  | ||||
| define i8* @foo() nounwind { | ||||
| ; CHECK: @foo | ||||
| ; CHECK-NEXT: call i8* @strcpy | ||||
|   %call = call i8* @__strcpy_chk(i8* getelementptr inbounds ([60 x i8]* @a, i32 0, i32 0), i8* getelementptr inbounds ([8 x i8]* @.str, i32 0, i32 0), i32 60) ; <i8*> [#uses=1] | ||||
|   ret i8* %call | ||||
| } | ||||
|  | ||||
| declare i8* @__strcpy_chk(i8*, i8*, i32) nounwind | ||||
		Reference in New Issue
	
	Block a user