mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-26 14:15:53 +00:00
00a99a3584
only run for x86 with fastisel. I've found it being very effective in eliminating some obvious dead code as result of formal parameter lowering especially when tail call optimization eliminated the need for some of the loads from fixed frame objects. It also shrinks a number of the tests. A couple of tests no longer make sense and are now eliminated. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@95493 91177308-0d34-0410-b5e6-96231b3b80d8
18 lines
515 B
LLVM
18 lines
515 B
LLVM
; RUN: llc < %s -mtriple=arm-linux-gnueabi | FileCheck %s
|
|
; This test checks that the address of the varg arguments is correctly
|
|
; computed when there are 5 or more regular arguments.
|
|
|
|
define void @f(i32 %a1, i32 %a2, i32 %a3, i32 %a4, i32 %a5, ...) {
|
|
entry:
|
|
;CHECK: sub sp, sp, #4
|
|
;CHECK: add r{{[0-9]+}}, sp, #8
|
|
;CHECK: str r{{[0-9]+}}, [sp], #+4
|
|
;CHECK: bx lr
|
|
%ap = alloca i8*, align 4
|
|
%ap1 = bitcast i8** %ap to i8*
|
|
call void @llvm.va_start(i8* %ap1)
|
|
ret void
|
|
}
|
|
|
|
declare void @llvm.va_start(i8*) nounwind
|