summaryrefslogtreecommitdiffstats
path: root/llvm/test
diff options
context:
space:
mode:
authorHal Finkel <hfinkel@anl.gov>2012-03-24 03:53:55 +0000
committerHal Finkel <hfinkel@anl.gov>2012-03-24 03:53:55 +0000
commite44eb28807e2fdb41367b3832dc0d713f2b1fffc (patch)
treec0fb14b7f60ee136b3f9b5615040e003c79c03bf /llvm/test
parent71c2ba3d2e5b74d7b883847998d9d6884246aa30 (diff)
downloadbcm5719-llvm-e44eb28807e2fdb41367b3832dc0d713f2b1fffc.tar.gz
bcm5719-llvm-e44eb28807e2fdb41367b3832dc0d713f2b1fffc.zip
Fix small-integer VAARG on SVR4 ABI PPC64.
The PPC64 SVR4 ABI requires integer stack arguments, and thus the var. args., that are smaller than 64 bits be zero extended to 64 bits. llvm-svn: 153373
Diffstat (limited to 'llvm/test')
-rw-r--r--llvm/test/CodeGen/PowerPC/ppc64-vaarg-int.ll20
1 files changed, 20 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/PowerPC/ppc64-vaarg-int.ll b/llvm/test/CodeGen/PowerPC/ppc64-vaarg-int.ll
new file mode 100644
index 00000000000..5a63b01badc
--- /dev/null
+++ b/llvm/test/CodeGen/PowerPC/ppc64-vaarg-int.ll
@@ -0,0 +1,20 @@
+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-v128:128:128-n32:64"
+target triple = "powerpc64-unknown-linux-gnu"
+; RUN: llc < %s | FileCheck %s
+
+define i32 @intvaarg(i32 %a, ...) nounwind {
+entry:
+ %va = alloca i8*, align 8
+ %va1 = bitcast i8** %va to i8*
+ call void @llvm.va_start(i8* %va1)
+ %0 = va_arg i8** %va, i32
+ %sub = sub nsw i32 %a, %0
+ ret i32 %sub
+}
+
+declare void @llvm.va_start(i8*) nounwind
+
+; CHECK: @intvaarg
+; Make sure that the va pointer is incremented by 8 (not 4).
+; CHECK: addi{{.*}}, 8
+
OpenPOWER on IntegriCloud