Merging r261441, r261447, and r261546:
[oota-llvm.git] / test / CodeGen / ARM / vargs_align.ll
index e390cf051443387400ff45274deb14cec10822ad..6dc71352214bf4d32504bc16dc32e6de9921280d 100644 (file)
@@ -1,4 +1,4 @@
-; RUN: llc < %s -march=arm -mtriple=arm-linux-gnueabi | FileCheck %s -check-prefix=EABI
+; RUN: llc < %s -mtriple=armv7-linux-gnueabihf | FileCheck %s -check-prefix=EABI
 ; RUN: llc < %s -march=arm -mtriple=arm-linux-gnu | FileCheck %s -check-prefix=OABI
 
 define i32 @f(i32 %a, ...) {
@@ -8,15 +8,22 @@ entry:
        %tmp = alloca i32, align 4              ; <i32*> [#uses=2]
        store i32 %a, i32* %a_addr
        store i32 0, i32* %tmp
-       %tmp1 = load i32* %tmp          ; <i32> [#uses=1]
+       %tmp1 = load i32, i32* %tmp             ; <i32> [#uses=1]
        store i32 %tmp1, i32* %retval
+       call void @llvm.va_start(i8* null)
+       call void asm sideeffect "", "~{d8}"()
        br label %return
 
 return:                ; preds = %entry
-       %retval2 = load i32* %retval            ; <i32> [#uses=1]
+       %retval2 = load i32, i32* %retval               ; <i32> [#uses=1]
        ret i32 %retval2
-; EABI: add sp, sp, #12
 ; EABI: add sp, sp, #16
+; EABI: vpop {d8}
+; EABI: add sp, sp, #4
+; EABI: add sp, sp, #12
+
 ; OABI: add sp, sp, #12
 ; OABI: add sp, sp, #12
 }
+
+declare void @llvm.va_start(i8*) nounwind