1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=ppc64 -mattr=+altivec | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Workertarget datalayout = "E-m:e-i64:64-n32:64" 4*9880d681SAndroid Build Coastguard Workertarget triple = "powerpc64-unknown-linux-gnu" 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Worker; Verify that in the 64-bit Linux ABI, vector arguments take up space 7*9880d681SAndroid Build Coastguard Worker; in the parameter save area. 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Workerdefine i64 @callee(i64 %a, <4 x i32> %b, i64 %c, <4 x i32> %d, i64 %e) { 10*9880d681SAndroid Build Coastguard Workerentry: 11*9880d681SAndroid Build Coastguard Worker ret i64 %e 12*9880d681SAndroid Build Coastguard Worker} 13*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: callee: 14*9880d681SAndroid Build Coastguard Worker; CHECK: ld 3, 112(1) 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Workerdefine void @caller(i64 %x, <4 x i32> %y) { 17*9880d681SAndroid Build Coastguard Workerentry: 18*9880d681SAndroid Build Coastguard Worker tail call void @test(i64 %x, <4 x i32> %y, i64 %x, <4 x i32> %y, i64 %x) 19*9880d681SAndroid Build Coastguard Worker ret void 20*9880d681SAndroid Build Coastguard Worker} 21*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: caller: 22*9880d681SAndroid Build Coastguard Worker; CHECK: std 3, 112(1) 23*9880d681SAndroid Build Coastguard Worker 24*9880d681SAndroid Build Coastguard Workerdeclare void @test(i64, <4 x i32>, i64, <4 x i32>, i64) 25*9880d681SAndroid Build Coastguard Worker 26