mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +00:00 
			
		
		
		
	Add additional test cases for WoA AEABI avoidance checking. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@207942 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			33 lines
		
	
	
		
			994 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			994 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; RUN: llc -mtriple=thumbv7-windows-itanium -mcpu=cortex-a9 -o - %s | FileCheck %s
 | |
| 
 | |
| declare void @llvm.memmove.p0i8.p0i8.i32(i8* nocapture, i8* nocapture, i32, i32, i1) nounwind
 | |
| declare void @llvm.memcpy.p0i8.p0i8.i32(i8* nocapture, i8* nocapture, i32, i32, i1) nounwind
 | |
| 
 | |
| @source = common global [512 x i8] zeroinitializer, align 4
 | |
| @target = common global [512 x i8] zeroinitializer, align 4
 | |
| 
 | |
| define void @move() nounwind {
 | |
| entry:
 | |
|   call void @llvm.memmove.p0i8.p0i8.i32(i8* bitcast ([512 x i8]* @target to i8*), i8* bitcast ([512 x i8]* @source to i8*), i32 512, i32 0, i1 false)
 | |
|   unreachable
 | |
| }
 | |
| 
 | |
| ; CHECK-NOT: __aeabi_memmove
 | |
| 
 | |
| define void @copy() nounwind {
 | |
| entry:
 | |
|   call void @llvm.memcpy.p0i8.p0i8.i32(i8* bitcast ([512 x i8]* @target to i8*), i8* bitcast ([512 x i8]* @source to i8*), i32 512, i32 0, i1 false)
 | |
|   unreachable
 | |
| }
 | |
| 
 | |
| ; CHECK-NOT: __aeabi_memcpy
 | |
| 
 | |
| define i32 @divide(i32 %i, i32 %j) nounwind {
 | |
| entry:
 | |
|   %quotient = sdiv i32 %i, %j
 | |
|   ret i32 %quotient
 | |
| }
 | |
| 
 | |
| ; CHECK-NOT: __aeabi_idiv
 | |
| 
 |