1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Workertarget datalayout = "E-m:e-i64:64-n32:64" 3*9880d681SAndroid Build Coastguard Workertarget triple = "powerpc64-unknown-linux-gnu" 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test: 6*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[test_BEGIN:.*]]:{{$}} 7*9880d681SAndroid Build Coastguard Worker 8*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: property_access1: 9*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[property_access1_BEGIN:.*]]:{{$}} 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: property_access2: 12*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[property_access2_BEGIN:.*]]:{{$}} 13*9880d681SAndroid Build Coastguard Worker 14*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: property_access3: 15*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[property_access3_BEGIN:.*]]:{{$}} 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: anyreg_test1: 18*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[anyreg_test1_BEGIN:.*]]:{{$}} 19*9880d681SAndroid Build Coastguard Worker 20*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: anyreg_test2: 21*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[anyreg_test2_BEGIN:.*]]:{{$}} 22*9880d681SAndroid Build Coastguard Worker 23*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: patchpoint_spilldef: 24*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[patchpoint_spilldef_BEGIN:.*]]:{{$}} 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: patchpoint_spillargs: 27*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[patchpoint_spillargs_BEGIN:.*]]:{{$}} 28*9880d681SAndroid Build Coastguard Worker 29*9880d681SAndroid Build Coastguard Worker 30*9880d681SAndroid Build Coastguard Worker; Stackmap Header: no constants - 6 callsites 31*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: .section .llvm_stackmaps 32*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: __LLVM_StackMaps: 33*9880d681SAndroid Build Coastguard Worker; Header 34*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 35*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 0 36*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 0 37*9880d681SAndroid Build Coastguard Worker; Num Functions 38*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 8 39*9880d681SAndroid Build Coastguard Worker; Num LargeConstants 40*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 41*9880d681SAndroid Build Coastguard Worker; Num Callsites 42*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 8 43*9880d681SAndroid Build Coastguard Worker 44*9880d681SAndroid Build Coastguard Worker; Functions and stack size 45*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad test 46*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad 128 47*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad property_access1 48*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad 128 49*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad property_access2 50*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad 128 51*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad property_access3 52*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad 128 53*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad anyreg_test1 54*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad 144 55*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad anyreg_test2 56*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad 144 57*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad patchpoint_spilldef 58*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad 256 59*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad patchpoint_spillargs 60*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .quad 288 61*9880d681SAndroid Build Coastguard Worker 62*9880d681SAndroid Build Coastguard Worker 63*9880d681SAndroid Build Coastguard Worker; test 64*9880d681SAndroid Build Coastguard Worker; CHECK: .long .L{{.*}}-.L[[test_BEGIN]] 65*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 0 66*9880d681SAndroid Build Coastguard Worker; 3 locations 67*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 3 68*9880d681SAndroid Build Coastguard Worker; Loc 0: Register 69*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 70*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 4 71*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 72*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 73*9880d681SAndroid Build Coastguard Worker; Loc 1: Register 74*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 75*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 4 76*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 77*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 78*9880d681SAndroid Build Coastguard Worker; Loc 2: Constant 3 79*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 4 80*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 81*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 0 82*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 3 83*9880d681SAndroid Build Coastguard Workerdefine i64 @test() nounwind ssp uwtable { 84*9880d681SAndroid Build Coastguard Workerentry: 85*9880d681SAndroid Build Coastguard Worker call anyregcc void (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.void(i64 0, i32 40, i8* null, i32 2, i32 1, i32 2, i64 3) 86*9880d681SAndroid Build Coastguard Worker ret i64 0 87*9880d681SAndroid Build Coastguard Worker} 88*9880d681SAndroid Build Coastguard Worker 89*9880d681SAndroid Build Coastguard Worker; property access 1 - %obj is an anyreg call argument and should therefore be in a register 90*9880d681SAndroid Build Coastguard Worker; CHECK: .long .L{{.*}}-.L[[property_access1_BEGIN]] 91*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 0 92*9880d681SAndroid Build Coastguard Worker; 2 locations 93*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 2 94*9880d681SAndroid Build Coastguard Worker; Loc 0: Register <-- this is the return register 95*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 96*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 97*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 98*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 99*9880d681SAndroid Build Coastguard Worker; Loc 1: Register 100*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 101*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 102*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 103*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 104*9880d681SAndroid Build Coastguard Workerdefine i64 @property_access1(i8* %obj) nounwind ssp uwtable { 105*9880d681SAndroid Build Coastguard Workerentry: 106*9880d681SAndroid Build Coastguard Worker %f = inttoptr i64 281474417671919 to i8* 107*9880d681SAndroid Build Coastguard Worker %ret = call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 1, i32 40, i8* %f, i32 1, i8* %obj) 108*9880d681SAndroid Build Coastguard Worker ret i64 %ret 109*9880d681SAndroid Build Coastguard Worker} 110*9880d681SAndroid Build Coastguard Worker 111*9880d681SAndroid Build Coastguard Worker; property access 2 - %obj is an anyreg call argument and should therefore be in a register 112*9880d681SAndroid Build Coastguard Worker; CHECK: .long .L{{.*}}-.L[[property_access2_BEGIN]] 113*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 0 114*9880d681SAndroid Build Coastguard Worker; 2 locations 115*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 2 116*9880d681SAndroid Build Coastguard Worker; Loc 0: Register <-- this is the return register 117*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 118*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 119*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 120*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 121*9880d681SAndroid Build Coastguard Worker; Loc 1: Register 122*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 123*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 124*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 125*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 126*9880d681SAndroid Build Coastguard Workerdefine i64 @property_access2() nounwind ssp uwtable { 127*9880d681SAndroid Build Coastguard Workerentry: 128*9880d681SAndroid Build Coastguard Worker %obj = alloca i64, align 8 129*9880d681SAndroid Build Coastguard Worker %f = inttoptr i64 281474417671919 to i8* 130*9880d681SAndroid Build Coastguard Worker %ret = call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 2, i32 40, i8* %f, i32 1, i64* %obj) 131*9880d681SAndroid Build Coastguard Worker ret i64 %ret 132*9880d681SAndroid Build Coastguard Worker} 133*9880d681SAndroid Build Coastguard Worker 134*9880d681SAndroid Build Coastguard Worker; property access 3 - %obj is a frame index 135*9880d681SAndroid Build Coastguard Worker; CHECK: .long .L{{.*}}-.L[[property_access3_BEGIN]] 136*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 0 137*9880d681SAndroid Build Coastguard Worker; 2 locations 138*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 2 139*9880d681SAndroid Build Coastguard Worker; Loc 0: Register <-- this is the return register 140*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 141*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 142*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 143*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 144*9880d681SAndroid Build Coastguard Worker; Loc 1: Direct FP - 8 145*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 2 146*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 147*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 31 148*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 112 149*9880d681SAndroid Build Coastguard Workerdefine i64 @property_access3() nounwind ssp uwtable { 150*9880d681SAndroid Build Coastguard Workerentry: 151*9880d681SAndroid Build Coastguard Worker %obj = alloca i64, align 8 152*9880d681SAndroid Build Coastguard Worker %f = inttoptr i64 281474417671919 to i8* 153*9880d681SAndroid Build Coastguard Worker %ret = call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 3, i32 40, i8* %f, i32 0, i64* %obj) 154*9880d681SAndroid Build Coastguard Worker ret i64 %ret 155*9880d681SAndroid Build Coastguard Worker} 156*9880d681SAndroid Build Coastguard Worker 157*9880d681SAndroid Build Coastguard Worker; anyreg_test1 158*9880d681SAndroid Build Coastguard Worker; CHECK: .long .L{{.*}}-.L[[anyreg_test1_BEGIN]] 159*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 0 160*9880d681SAndroid Build Coastguard Worker; 14 locations 161*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 14 162*9880d681SAndroid Build Coastguard Worker; Loc 0: Register <-- this is the return register 163*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 164*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 165*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 166*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 167*9880d681SAndroid Build Coastguard Worker; Loc 1: Register 168*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 169*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 170*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 171*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 172*9880d681SAndroid Build Coastguard Worker; Loc 2: Register 173*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 174*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 175*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 176*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 177*9880d681SAndroid Build Coastguard Worker; Loc 3: Register 178*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 179*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 180*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 181*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 182*9880d681SAndroid Build Coastguard Worker; Loc 4: Register 183*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 184*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 185*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 186*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 187*9880d681SAndroid Build Coastguard Worker; Loc 5: Register 188*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 189*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 190*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 191*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 192*9880d681SAndroid Build Coastguard Worker; Loc 6: Register 193*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 194*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 195*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 196*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 197*9880d681SAndroid Build Coastguard Worker; Loc 7: Register 198*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 199*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 200*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 201*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 202*9880d681SAndroid Build Coastguard Worker; Loc 8: Register 203*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 204*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 205*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 206*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 207*9880d681SAndroid Build Coastguard Worker; Loc 9: Register 208*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 209*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 210*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 211*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 212*9880d681SAndroid Build Coastguard Worker; Loc 10: Register 213*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 214*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 215*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 216*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 217*9880d681SAndroid Build Coastguard Worker; Loc 11: Register 218*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 219*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 220*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 221*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 222*9880d681SAndroid Build Coastguard Worker; Loc 12: Register 223*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 224*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 225*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 226*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 227*9880d681SAndroid Build Coastguard Worker; Loc 13: Register 228*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 229*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 230*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 231*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 232*9880d681SAndroid Build Coastguard Workerdefine i64 @anyreg_test1(i8* %a1, i8* %a2, i8* %a3, i8* %a4, i8* %a5, i8* %a6, i8* %a7, i8* %a8, i8* %a9, i8* %a10, i8* %a11, i8* %a12, i8* %a13) nounwind ssp uwtable { 233*9880d681SAndroid Build Coastguard Workerentry: 234*9880d681SAndroid Build Coastguard Worker %f = inttoptr i64 281474417671919 to i8* 235*9880d681SAndroid Build Coastguard Worker %ret = call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 4, i32 40, i8* %f, i32 13, i8* %a1, i8* %a2, i8* %a3, i8* %a4, i8* %a5, i8* %a6, i8* %a7, i8* %a8, i8* %a9, i8* %a10, i8* %a11, i8* %a12, i8* %a13) 236*9880d681SAndroid Build Coastguard Worker ret i64 %ret 237*9880d681SAndroid Build Coastguard Worker} 238*9880d681SAndroid Build Coastguard Worker 239*9880d681SAndroid Build Coastguard Worker; anyreg_test2 240*9880d681SAndroid Build Coastguard Worker; CHECK: .long .L{{.*}}-.L[[anyreg_test2_BEGIN]] 241*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 0 242*9880d681SAndroid Build Coastguard Worker; 14 locations 243*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 14 244*9880d681SAndroid Build Coastguard Worker; Loc 0: Register <-- this is the return register 245*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 246*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 247*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 248*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 249*9880d681SAndroid Build Coastguard Worker; Loc 1: Register 250*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 251*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 252*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 253*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 254*9880d681SAndroid Build Coastguard Worker; Loc 2: Register 255*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 256*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 257*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 258*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 259*9880d681SAndroid Build Coastguard Worker; Loc 3: Register 260*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 261*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 262*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 263*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 264*9880d681SAndroid Build Coastguard Worker; Loc 4: Register 265*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 266*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 267*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 268*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 269*9880d681SAndroid Build Coastguard Worker; Loc 5: Register 270*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 271*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 272*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 273*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 274*9880d681SAndroid Build Coastguard Worker; Loc 6: Register 275*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 276*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 277*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 278*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 279*9880d681SAndroid Build Coastguard Worker; Loc 7: Register 280*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 281*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 282*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 283*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 284*9880d681SAndroid Build Coastguard Worker; Loc 8: Register 285*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 286*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 287*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 288*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 289*9880d681SAndroid Build Coastguard Worker; Loc 9: Register 290*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 291*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 292*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 293*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 294*9880d681SAndroid Build Coastguard Worker; Loc 10: Register 295*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 296*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 297*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 298*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 299*9880d681SAndroid Build Coastguard Worker; Loc 11: Register 300*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 301*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 302*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 303*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 304*9880d681SAndroid Build Coastguard Worker; Loc 12: Register 305*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 306*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 307*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 308*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 309*9880d681SAndroid Build Coastguard Worker; Loc 13: Register 310*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 311*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 312*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 313*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 314*9880d681SAndroid Build Coastguard Workerdefine i64 @anyreg_test2(i8* %a1, i8* %a2, i8* %a3, i8* %a4, i8* %a5, i8* %a6, i8* %a7, i8* %a8, i8* %a9, i8* %a10, i8* %a11, i8* %a12, i8* %a13) nounwind ssp uwtable { 315*9880d681SAndroid Build Coastguard Workerentry: 316*9880d681SAndroid Build Coastguard Worker %f = inttoptr i64 281474417671919 to i8* 317*9880d681SAndroid Build Coastguard Worker %ret = call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 5, i32 40, i8* %f, i32 8, i8* %a1, i8* %a2, i8* %a3, i8* %a4, i8* %a5, i8* %a6, i8* %a7, i8* %a8, i8* %a9, i8* %a10, i8* %a11, i8* %a12, i8* %a13) 318*9880d681SAndroid Build Coastguard Worker ret i64 %ret 319*9880d681SAndroid Build Coastguard Worker} 320*9880d681SAndroid Build Coastguard Worker 321*9880d681SAndroid Build Coastguard Worker; Test spilling the return value of an anyregcc call. 322*9880d681SAndroid Build Coastguard Worker; 323*9880d681SAndroid Build Coastguard Worker; <rdar://problem/15432754> [JS] Assertion: "Folded a def to a non-store!" 324*9880d681SAndroid Build Coastguard Worker; 325*9880d681SAndroid Build Coastguard Worker; CHECK: .long .L{{.*}}-.L[[patchpoint_spilldef_BEGIN]] 326*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 0 327*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 3 328*9880d681SAndroid Build Coastguard Worker; Loc 0: Register (some register that will be spilled to the stack) 329*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 330*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 331*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 332*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 333*9880d681SAndroid Build Coastguard Worker; Loc 1: Register 334*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 335*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 336*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 337*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 338*9880d681SAndroid Build Coastguard Worker; Loc 1: Register 339*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 340*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 341*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 342*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 343*9880d681SAndroid Build Coastguard Workerdefine i64 @patchpoint_spilldef(i64 %p1, i64 %p2, i64 %p3, i64 %p4) { 344*9880d681SAndroid Build Coastguard Workerentry: 345*9880d681SAndroid Build Coastguard Worker %result = tail call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 12, i32 40, i8* inttoptr (i64 0 to i8*), i32 2, i64 %p1, i64 %p2) 346*9880d681SAndroid Build Coastguard Worker tail call void asm sideeffect "nop", "~{r0},~{r3},~{r4},~{r5},~{r6},~{r7},~{r8},~{r9},~{r10},~{r11},~{r12},~{r14},~{r15},~{r16},~{r17 347*9880d681SAndroid Build Coastguard Worker},~{r18},~{r19},~{r20},~{r21},~{r22},~{r23},~{r24},~{r25},~{r26},~{r27},~{r28},~{r29},~{r30},~{r31}"() nounwind 348*9880d681SAndroid Build Coastguard Worker ret i64 %result 349*9880d681SAndroid Build Coastguard Worker} 350*9880d681SAndroid Build Coastguard Worker 351*9880d681SAndroid Build Coastguard Worker; Test spilling the arguments of an anyregcc call. 352*9880d681SAndroid Build Coastguard Worker; 353*9880d681SAndroid Build Coastguard Worker; <rdar://problem/15487687> [JS] AnyRegCC argument ends up being spilled 354*9880d681SAndroid Build Coastguard Worker; 355*9880d681SAndroid Build Coastguard Worker; CHECK: .long .L{{.*}}-.L[[patchpoint_spillargs_BEGIN]] 356*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 0 357*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 5 358*9880d681SAndroid Build Coastguard Worker; Loc 0: Return a register 359*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 360*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 361*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 362*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 363*9880d681SAndroid Build Coastguard Worker; Loc 1: Arg0 in a Register 364*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 365*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 366*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 367*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 368*9880d681SAndroid Build Coastguard Worker; Loc 2: Arg1 in a Register 369*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 1 370*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 371*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}} 372*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 0 373*9880d681SAndroid Build Coastguard Worker; Loc 3: Arg2 spilled to FP -96 374*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 3 375*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 376*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 31 377*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 128 378*9880d681SAndroid Build Coastguard Worker; Loc 4: Arg3 spilled to FP - 88 379*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 3 380*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte 8 381*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 31 382*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 136 383*9880d681SAndroid Build Coastguard Workerdefine i64 @patchpoint_spillargs(i64 %p1, i64 %p2, i64 %p3, i64 %p4) { 384*9880d681SAndroid Build Coastguard Workerentry: 385*9880d681SAndroid Build Coastguard Worker tail call void asm sideeffect "nop", "~{r0},~{r3},~{r4},~{r5},~{r6},~{r7},~{r8},~{r9},~{r10},~{r11},~{r12},~{r14},~{r15},~{r16},~{r17 386*9880d681SAndroid Build Coastguard Worker},~{r18},~{r19},~{r20},~{r21},~{r22},~{r23},~{r24},~{r25},~{r26},~{r27},~{r28},~{r29},~{r30},~{r31}"() nounwind 387*9880d681SAndroid Build Coastguard Worker %result = tail call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 13, i32 40, i8* inttoptr (i64 0 to i8*), i32 2, i64 %p1, i64 %p2, i64 %p3, i64 %p4) 388*9880d681SAndroid Build Coastguard Worker ret i64 %result 389*9880d681SAndroid Build Coastguard Worker} 390*9880d681SAndroid Build Coastguard Worker 391*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.experimental.patchpoint.void(i64, i32, i8*, i32, ...) 392*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.experimental.patchpoint.i64(i64, i32, i8*, i32, ...) 393