1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -disable-block-placement | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -disable-block-placement -disable-sparc-leaf-proc=0 | FileCheck %s 3*9880d681SAndroid Build Coastguard Workertarget 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-v64:64:64-n32:64-S128" 4*9880d681SAndroid Build Coastguard Workertarget triple = "sparcv9-sun-solaris" 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Worker; CHECK: varargsfunc 7*9880d681SAndroid Build Coastguard Worker; 128 byte save ares + 1 alloca rounded up to 16 bytes alignment. 8*9880d681SAndroid Build Coastguard Worker; CHECK: save %sp, -144, %sp 9*9880d681SAndroid Build Coastguard Worker; Store the ... arguments to the argument array. The order is not important. 10*9880d681SAndroid Build Coastguard Worker; CHECK: stx %i5, [%fp+2215] 11*9880d681SAndroid Build Coastguard Worker; CHECK: stx %i4, [%fp+2207] 12*9880d681SAndroid Build Coastguard Worker; CHECK: stx %i3, [%fp+2199] 13*9880d681SAndroid Build Coastguard Worker; CHECK: stx %i2, [%fp+2191] 14*9880d681SAndroid Build Coastguard Worker; Store the address of the ... args to %ap at %fp+BIAS+128-8 15*9880d681SAndroid Build Coastguard Worker; add %fp, 2191, [[R:[gilo][0-7]]] 16*9880d681SAndroid Build Coastguard Worker; stx [[R]], [%fp+2039] 17*9880d681SAndroid Build Coastguard Workerdefine double @varargsfunc(i8* nocapture %fmt, double %sum, ...) { 18*9880d681SAndroid Build Coastguard Workerentry: 19*9880d681SAndroid Build Coastguard Worker %ap = alloca i8*, align 4 20*9880d681SAndroid Build Coastguard Worker %ap1 = bitcast i8** %ap to i8* 21*9880d681SAndroid Build Coastguard Worker call void @llvm.va_start(i8* %ap1) 22*9880d681SAndroid Build Coastguard Worker br label %for.cond 23*9880d681SAndroid Build Coastguard Worker 24*9880d681SAndroid Build Coastguard Workerfor.cond: 25*9880d681SAndroid Build Coastguard Worker %fmt.addr.0 = phi i8* [ %fmt, %entry ], [ %incdec.ptr, %for.cond.backedge ] 26*9880d681SAndroid Build Coastguard Worker %sum.addr.0 = phi double [ %sum, %entry ], [ %sum.addr.0.be, %for.cond.backedge ] 27*9880d681SAndroid Build Coastguard Worker %incdec.ptr = getelementptr inbounds i8, i8* %fmt.addr.0, i64 1 28*9880d681SAndroid Build Coastguard Worker %0 = load i8, i8* %fmt.addr.0, align 1 29*9880d681SAndroid Build Coastguard Worker %conv = sext i8 %0 to i32 30*9880d681SAndroid Build Coastguard Worker switch i32 %conv, label %sw.default [ 31*9880d681SAndroid Build Coastguard Worker i32 105, label %sw.bb 32*9880d681SAndroid Build Coastguard Worker i32 102, label %sw.bb3 33*9880d681SAndroid Build Coastguard Worker ] 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Worker; CHECK: sw.bb 36*9880d681SAndroid Build Coastguard Worker; ldx [%fp+2039], %[[AP:[gilo][0-7]]] 37*9880d681SAndroid Build Coastguard Worker; add %[[AP]], 4, %[[AP2:[gilo][0-7]]] 38*9880d681SAndroid Build Coastguard Worker; stx %[[AP2]], [%fp+2039] 39*9880d681SAndroid Build Coastguard Worker; ld [%[[AP]]] 40*9880d681SAndroid Build Coastguard Workersw.bb: 41*9880d681SAndroid Build Coastguard Worker %1 = va_arg i8** %ap, i32 42*9880d681SAndroid Build Coastguard Worker %conv2 = sitofp i32 %1 to double 43*9880d681SAndroid Build Coastguard Worker br label %for.cond.backedge 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker; CHECK: sw.bb3 46*9880d681SAndroid Build Coastguard Worker; ldx [%fp+2039], %[[AP:[gilo][0-7]]] 47*9880d681SAndroid Build Coastguard Worker; add %[[AP]], 8, %[[AP2:[gilo][0-7]]] 48*9880d681SAndroid Build Coastguard Worker; stx %[[AP2]], [%fp+2039] 49*9880d681SAndroid Build Coastguard Worker; ldd [%[[AP]]] 50*9880d681SAndroid Build Coastguard Workersw.bb3: 51*9880d681SAndroid Build Coastguard Worker %2 = va_arg i8** %ap, double 52*9880d681SAndroid Build Coastguard Worker br label %for.cond.backedge 53*9880d681SAndroid Build Coastguard Worker 54*9880d681SAndroid Build Coastguard Workerfor.cond.backedge: 55*9880d681SAndroid Build Coastguard Worker %.pn = phi double [ %2, %sw.bb3 ], [ %conv2, %sw.bb ] 56*9880d681SAndroid Build Coastguard Worker %sum.addr.0.be = fadd double %.pn, %sum.addr.0 57*9880d681SAndroid Build Coastguard Worker br label %for.cond 58*9880d681SAndroid Build Coastguard Worker 59*9880d681SAndroid Build Coastguard Workersw.default: 60*9880d681SAndroid Build Coastguard Worker ret double %sum.addr.0 61*9880d681SAndroid Build Coastguard Worker} 62*9880d681SAndroid Build Coastguard Worker 63*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.va_start(i8*) 64*9880d681SAndroid Build Coastguard Worker 65*9880d681SAndroid Build Coastguard Worker@.str = private unnamed_addr constant [4 x i8] c"abc\00", align 1 66*9880d681SAndroid Build Coastguard Worker 67*9880d681SAndroid Build Coastguard Worker; CHECK: call_1d 68*9880d681SAndroid Build Coastguard Worker; The fixed-arg double goes in %d2, the second goes in %o2. 69*9880d681SAndroid Build Coastguard Worker; CHECK: sethi 1048576 70*9880d681SAndroid Build Coastguard Worker; CHECK: , %f2 71*9880d681SAndroid Build Coastguard Worker; CHECK: , %o2 72*9880d681SAndroid Build Coastguard Workerdefine i32 @call_1d() #0 { 73*9880d681SAndroid Build Coastguard Workerentry: 74*9880d681SAndroid Build Coastguard Worker %call = call double (i8*, double, ...) @varargsfunc(i8* undef, double 1.000000e+00, double 2.000000e+00) 75*9880d681SAndroid Build Coastguard Worker ret i32 1 76*9880d681SAndroid Build Coastguard Worker} 77