1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -stack-symbol-ordering=0 -march=x86-64 -verify-machineinstrs | FileCheck %s 3*9880d681SAndroid Build Coastguard Worker; PR3538 4*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128" 5*9880d681SAndroid Build Coastguard Workertarget triple = "i386-apple-darwin9" 6*9880d681SAndroid Build Coastguard Workerdefine signext i8 @foo(i8* %s1) nounwind ssp { 7*9880d681SAndroid Build Coastguard Worker 8*9880d681SAndroid Build Coastguard Worker; Make sure we generate: 9*9880d681SAndroid Build Coastguard Worker; movq -40(%rbp), %rsp 10*9880d681SAndroid Build Coastguard Worker; Instead of: 11*9880d681SAndroid Build Coastguard Worker; movq -40(%rbp), %rax 12*9880d681SAndroid Build Coastguard Worker; movq %rax, %rsp 13*9880d681SAndroid Build Coastguard Worker 14*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @foo 15*9880d681SAndroid Build Coastguard Worker; CHECK: movq -{{[0-9]+}}(%rbp), %rsp 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Workerentry: 18*9880d681SAndroid Build Coastguard Worker %s1_addr = alloca i8* ; <i8**> [#uses=2] 19*9880d681SAndroid Build Coastguard Worker %retval = alloca i32 ; <i32*> [#uses=2] 20*9880d681SAndroid Build Coastguard Worker %saved_stack.1 = alloca i8* ; <i8**> [#uses=2] 21*9880d681SAndroid Build Coastguard Worker %0 = alloca i32 ; <i32*> [#uses=2] 22*9880d681SAndroid Build Coastguard Worker %str.0 = alloca [0 x i8]* ; <[0 x i8]**> [#uses=3] 23*9880d681SAndroid Build Coastguard Worker %1 = alloca i64 ; <i64*> [#uses=2] 24*9880d681SAndroid Build Coastguard Worker %2 = alloca i64 ; <i64*> [#uses=1] 25*9880d681SAndroid Build Coastguard Worker %3 = alloca i64 ; <i64*> [#uses=6] 26*9880d681SAndroid Build Coastguard Worker %"alloca point" = bitcast i32 0 to i32 ; <i32> [#uses=0] 27*9880d681SAndroid Build Coastguard Worker call void @llvm.dbg.declare(metadata i8** %s1_addr, metadata !0, metadata !DIExpression()), !dbg !7 28*9880d681SAndroid Build Coastguard Worker store i8* %s1, i8** %s1_addr 29*9880d681SAndroid Build Coastguard Worker call void @llvm.dbg.declare(metadata [0 x i8]** %str.0, metadata !8, metadata !DIExpression()), !dbg !7 30*9880d681SAndroid Build Coastguard Worker %4 = call i8* @llvm.stacksave(), !dbg !7 ; <i8*> [#uses=1] 31*9880d681SAndroid Build Coastguard Worker store i8* %4, i8** %saved_stack.1, align 8, !dbg !7 32*9880d681SAndroid Build Coastguard Worker %5 = load i8*, i8** %s1_addr, align 8, !dbg !13 ; <i8*> [#uses=1] 33*9880d681SAndroid Build Coastguard Worker %6 = call i64 @strlen(i8* %5) nounwind readonly, !dbg !13 ; <i64> [#uses=1] 34*9880d681SAndroid Build Coastguard Worker %7 = add i64 %6, 1, !dbg !13 ; <i64> [#uses=1] 35*9880d681SAndroid Build Coastguard Worker store i64 %7, i64* %3, align 8, !dbg !13 36*9880d681SAndroid Build Coastguard Worker %8 = load i64, i64* %3, align 8, !dbg !13 ; <i64> [#uses=1] 37*9880d681SAndroid Build Coastguard Worker %9 = sub nsw i64 %8, 1, !dbg !13 ; <i64> [#uses=0] 38*9880d681SAndroid Build Coastguard Worker %10 = load i64, i64* %3, align 8, !dbg !13 ; <i64> [#uses=1] 39*9880d681SAndroid Build Coastguard Worker %11 = mul i64 %10, 8, !dbg !13 ; <i64> [#uses=0] 40*9880d681SAndroid Build Coastguard Worker %12 = load i64, i64* %3, align 8, !dbg !13 ; <i64> [#uses=1] 41*9880d681SAndroid Build Coastguard Worker store i64 %12, i64* %2, align 8, !dbg !13 42*9880d681SAndroid Build Coastguard Worker %13 = load i64, i64* %3, align 8, !dbg !13 ; <i64> [#uses=1] 43*9880d681SAndroid Build Coastguard Worker %14 = mul i64 %13, 8, !dbg !13 ; <i64> [#uses=0] 44*9880d681SAndroid Build Coastguard Worker %15 = load i64, i64* %3, align 8, !dbg !13 ; <i64> [#uses=1] 45*9880d681SAndroid Build Coastguard Worker store i64 %15, i64* %1, align 8, !dbg !13 46*9880d681SAndroid Build Coastguard Worker %16 = load i64, i64* %1, align 8, !dbg !13 ; <i64> [#uses=1] 47*9880d681SAndroid Build Coastguard Worker %17 = trunc i64 %16 to i32, !dbg !13 ; <i32> [#uses=1] 48*9880d681SAndroid Build Coastguard Worker %18 = alloca i8, i32 %17, !dbg !13 ; <i8*> [#uses=1] 49*9880d681SAndroid Build Coastguard Worker %19 = bitcast i8* %18 to [0 x i8]*, !dbg !13 ; <[0 x i8]*> [#uses=1] 50*9880d681SAndroid Build Coastguard Worker store [0 x i8]* %19, [0 x i8]** %str.0, align 8, !dbg !13 51*9880d681SAndroid Build Coastguard Worker %20 = load [0 x i8]*, [0 x i8]** %str.0, align 8, !dbg !15 ; <[0 x i8]*> [#uses=1] 52*9880d681SAndroid Build Coastguard Worker %21 = getelementptr inbounds [0 x i8], [0 x i8]* %20, i64 0, i64 0, !dbg !15 ; <i8*> [#uses=1] 53*9880d681SAndroid Build Coastguard Worker store i8 0, i8* %21, align 1, !dbg !15 54*9880d681SAndroid Build Coastguard Worker %22 = load [0 x i8]*, [0 x i8]** %str.0, align 8, !dbg !16 ; <[0 x i8]*> [#uses=1] 55*9880d681SAndroid Build Coastguard Worker %23 = getelementptr inbounds [0 x i8], [0 x i8]* %22, i64 0, i64 0, !dbg !16 ; <i8*> [#uses=1] 56*9880d681SAndroid Build Coastguard Worker %24 = load i8, i8* %23, align 1, !dbg !16 ; <i8> [#uses=1] 57*9880d681SAndroid Build Coastguard Worker %25 = sext i8 %24 to i32, !dbg !16 ; <i32> [#uses=1] 58*9880d681SAndroid Build Coastguard Worker store i32 %25, i32* %0, align 4, !dbg !16 59*9880d681SAndroid Build Coastguard Worker %26 = load i8*, i8** %saved_stack.1, align 8, !dbg !16 ; <i8*> [#uses=1] 60*9880d681SAndroid Build Coastguard Worker call void @llvm.stackrestore(i8* %26), !dbg !16 61*9880d681SAndroid Build Coastguard Worker %27 = load i32, i32* %0, align 4, !dbg !16 ; <i32> [#uses=1] 62*9880d681SAndroid Build Coastguard Worker store i32 %27, i32* %retval, align 4, !dbg !16 63*9880d681SAndroid Build Coastguard Worker br label %return, !dbg !16 64*9880d681SAndroid Build Coastguard Worker 65*9880d681SAndroid Build Coastguard Workerreturn: ; preds = %entry 66*9880d681SAndroid Build Coastguard Worker %retval1 = load i32, i32* %retval, !dbg !16 ; <i32> [#uses=1] 67*9880d681SAndroid Build Coastguard Worker %retval12 = trunc i32 %retval1 to i8, !dbg !16 ; <i8> [#uses=1] 68*9880d681SAndroid Build Coastguard Worker ret i8 %retval12, !dbg !16 69*9880d681SAndroid Build Coastguard Worker} 70*9880d681SAndroid Build Coastguard Worker 71*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.dbg.declare(metadata, metadata, metadata) nounwind readnone 72*9880d681SAndroid Build Coastguard Worker 73*9880d681SAndroid Build Coastguard Workerdeclare i8* @llvm.stacksave() nounwind 74*9880d681SAndroid Build Coastguard Worker 75*9880d681SAndroid Build Coastguard Workerdeclare i64 @strlen(i8*) nounwind readonly 76*9880d681SAndroid Build Coastguard Worker 77*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.stackrestore(i8*) nounwind 78*9880d681SAndroid Build Coastguard Worker 79*9880d681SAndroid Build Coastguard Worker!llvm.dbg.cu = !{!2} 80*9880d681SAndroid Build Coastguard Worker!0 = !DILocalVariable(name: "s1", line: 2, arg: 1, scope: !1, file: !2, type: !6) 81*9880d681SAndroid Build Coastguard Worker!1 = distinct !DISubprogram(name: "foo", linkageName: "foo", line: 2, isLocal: false, isDefinition: true, virtualIndex: 6, isOptimized: false, unit: !2, scope: !2, type: !3) 82*9880d681SAndroid Build Coastguard Worker!2 = distinct !DICompileUnit(language: DW_LANG_C89, producer: "4.2.1 (Based on Apple Inc. build 5658) (LLVM build)", isOptimized: true, emissionKind: FullDebug, file: !17, enums: !18, retainedTypes: !18) 83*9880d681SAndroid Build Coastguard Worker!3 = !DISubroutineType(types: !4) 84*9880d681SAndroid Build Coastguard Worker!4 = !{!5, !6} 85*9880d681SAndroid Build Coastguard Worker!5 = !DIBasicType(tag: DW_TAG_base_type, name: "char", size: 8, align: 8, encoding: DW_ATE_signed_char) 86*9880d681SAndroid Build Coastguard Worker!6 = !DIDerivedType(tag: DW_TAG_pointer_type, size: 64, align: 64, scope: !2, baseType: !5) 87*9880d681SAndroid Build Coastguard Worker!7 = !DILocation(line: 2, scope: !1) 88*9880d681SAndroid Build Coastguard Worker!8 = !DILocalVariable(name: "str.0", line: 3, scope: !1, file: !2, type: !9) 89*9880d681SAndroid Build Coastguard Worker!9 = !DIDerivedType(tag: DW_TAG_pointer_type, size: 64, align: 64, flags: DIFlagArtificial, scope: !2, baseType: !10) 90*9880d681SAndroid Build Coastguard Worker!10 = !DICompositeType(tag: DW_TAG_array_type, size: 8, align: 8, scope: !2, baseType: !5, elements: !11) 91*9880d681SAndroid Build Coastguard Worker!11 = !{!12} 92*9880d681SAndroid Build Coastguard Worker!12 = !DISubrange(count: 1) 93*9880d681SAndroid Build Coastguard Worker!13 = !DILocation(line: 3, scope: !14) 94*9880d681SAndroid Build Coastguard Worker!14 = distinct !DILexicalBlock(line: 0, column: 0, file: !17, scope: !1) 95*9880d681SAndroid Build Coastguard Worker!15 = !DILocation(line: 4, scope: !14) 96*9880d681SAndroid Build Coastguard Worker!16 = !DILocation(line: 5, scope: !14) 97*9880d681SAndroid Build Coastguard Worker!17 = !DIFile(filename: "vla.c", directory: "/tmp/") 98*9880d681SAndroid Build Coastguard Worker!18 = !{i32 0} 99