mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-01 00:33:09 +00:00
4fc5273a49
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
|
|
|