]> Gitweb @ Texas Instruments - Open Source Git Repositories - git.TI.com/gitweb - opencl/llvm.git/blob - test/CodeGen/X86/2009-02-12-DebugInfoVLA.ll
[X86][AVX] Simplified diff between AVX1 and SSE42 fp stack folding tests. NFC.
[opencl/llvm.git] / test / CodeGen / X86 / 2009-02-12-DebugInfoVLA.ll
1 ; RUN: llc < %s
2 ; RUN: llc < %s -march=x86-64 -verify-machineinstrs | FileCheck %s
3 ; PR3538
4 target 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 target triple = "i386-apple-darwin9"
6 define signext i8 @foo(i8* %s1) nounwind ssp {
8 ; Make sure we generate:
9 ;  movq -40(%rbp), %rsp
10 ; Instead of:
11 ;  movq -40(%rbp), %rax
12 ;  movq %rax, %rsp
14 ; CHECK-LABEL: @foo
15 ; CHECK: movq   -40(%rbp), %rsp
17 entry:
18   %s1_addr = alloca i8*                           ; <i8**> [#uses=2]
19   %retval = alloca i32                            ; <i32*> [#uses=2]
20   %saved_stack.1 = alloca i8*                     ; <i8**> [#uses=2]
21   %0 = alloca i32                                 ; <i32*> [#uses=2]
22   %str.0 = alloca [0 x i8]*                       ; <[0 x i8]**> [#uses=3]
23   %1 = alloca i64                                 ; <i64*> [#uses=2]
24   %2 = alloca i64                                 ; <i64*> [#uses=1]
25   %3 = alloca i64                                 ; <i64*> [#uses=6]
26   %"alloca point" = bitcast i32 0 to i32          ; <i32> [#uses=0]
27   call void @llvm.dbg.declare(metadata i8** %s1_addr, metadata !0, metadata !{!"0x102"}), !dbg !7
28   store i8* %s1, i8** %s1_addr
29   call void @llvm.dbg.declare(metadata [0 x i8]** %str.0, metadata !8, metadata !{!"0x102"}), !dbg !7
30   %4 = call i8* @llvm.stacksave(), !dbg !7        ; <i8*> [#uses=1]
31   store i8* %4, i8** %saved_stack.1, align 8, !dbg !7
32   %5 = load i8** %s1_addr, align 8, !dbg !13      ; <i8*> [#uses=1]
33   %6 = call i64 @strlen(i8* %5) nounwind readonly, !dbg !13 ; <i64> [#uses=1]
34   %7 = add i64 %6, 1, !dbg !13                    ; <i64> [#uses=1]
35   store i64 %7, i64* %3, align 8, !dbg !13
36   %8 = load i64* %3, align 8, !dbg !13            ; <i64> [#uses=1]
37   %9 = sub nsw i64 %8, 1, !dbg !13                ; <i64> [#uses=0]
38   %10 = load i64* %3, align 8, !dbg !13           ; <i64> [#uses=1]
39   %11 = mul i64 %10, 8, !dbg !13                  ; <i64> [#uses=0]
40   %12 = load i64* %3, align 8, !dbg !13           ; <i64> [#uses=1]
41   store i64 %12, i64* %2, align 8, !dbg !13
42   %13 = load i64* %3, align 8, !dbg !13           ; <i64> [#uses=1]
43   %14 = mul i64 %13, 8, !dbg !13                  ; <i64> [#uses=0]
44   %15 = load i64* %3, align 8, !dbg !13           ; <i64> [#uses=1]
45   store i64 %15, i64* %1, align 8, !dbg !13
46   %16 = load i64* %1, align 8, !dbg !13           ; <i64> [#uses=1]
47   %17 = trunc i64 %16 to i32, !dbg !13            ; <i32> [#uses=1]
48   %18 = alloca i8, i32 %17, !dbg !13              ; <i8*> [#uses=1]
49   %19 = bitcast i8* %18 to [0 x i8]*, !dbg !13    ; <[0 x i8]*> [#uses=1]
50   store [0 x i8]* %19, [0 x i8]** %str.0, align 8, !dbg !13
51   %20 = load [0 x i8]** %str.0, align 8, !dbg !15 ; <[0 x i8]*> [#uses=1]
52   %21 = getelementptr inbounds [0 x i8]* %20, i64 0, i64 0, !dbg !15 ; <i8*> [#uses=1]
53   store i8 0, i8* %21, align 1, !dbg !15
54   %22 = load [0 x i8]** %str.0, align 8, !dbg !16 ; <[0 x i8]*> [#uses=1]
55   %23 = getelementptr inbounds [0 x i8]* %22, i64 0, i64 0, !dbg !16 ; <i8*> [#uses=1]
56   %24 = load i8* %23, align 1, !dbg !16           ; <i8> [#uses=1]
57   %25 = sext i8 %24 to i32, !dbg !16              ; <i32> [#uses=1]
58   store i32 %25, i32* %0, align 4, !dbg !16
59   %26 = load i8** %saved_stack.1, align 8, !dbg !16 ; <i8*> [#uses=1]
60   call void @llvm.stackrestore(i8* %26), !dbg !16
61   %27 = load i32* %0, align 4, !dbg !16           ; <i32> [#uses=1]
62   store i32 %27, i32* %retval, align 4, !dbg !16
63   br label %return, !dbg !16
65 return:                                           ; preds = %entry
66   %retval1 = load i32* %retval, !dbg !16          ; <i32> [#uses=1]
67   %retval12 = trunc i32 %retval1 to i8, !dbg !16  ; <i8> [#uses=1]
68   ret i8 %retval12, !dbg !16
69 }
71 declare void @llvm.dbg.declare(metadata, metadata, metadata) nounwind readnone
73 declare i8* @llvm.stacksave() nounwind
75 declare i64 @strlen(i8*) nounwind readonly
77 declare void @llvm.stackrestore(i8*) nounwind
79 !0 = !{!"0x101\00s1\002\000", !1, !2, !6} ; [ DW_TAG_arg_variable ]
80 !1 = !{!"0x2e\00foo\00foo\00foo\002\000\001\000\006\000\000\000", i32 0, !2, !3, null, null, null, null, null} ; [ DW_TAG_subprogram ]
81 !2 = !{!"0x11\001\004.2.1 (Based on Apple Inc. build 5658) (LLVM build)\001\00\000\00\000", !17, !18, !18, null, null, null} ; [ DW_TAG_compile_unit ]
82 !3 = !{!"0x15\00\000\000\000\000\000\000", null, !2, null, !4, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]
83 !4 = !{!5, !6}
84 !5 = !{!"0x24\00char\000\008\008\000\000\006", null, !2} ; [ DW_TAG_base_type ]
85 !6 = !{!"0xf\00\000\0064\0064\000\000", null, !2, !5} ; [ DW_TAG_pointer_type ]
86 !7 = !MDLocation(line: 2, scope: !1)
87 !8 = !{!"0x100\00str.0\003\000", !1, !2, !9} ; [ DW_TAG_auto_variable ]
88 !9 = !{!"0xf\00\000\0064\0064\000\0064", null, !2, !10} ; [ DW_TAG_pointer_type ]
89 !10 = !{!"0x1\00\000\008\008\000\000", null, !2, !5, !11, i32 0, null, null, null} ; [ DW_TAG_array_type ] [line 0, size 8, align 8, offset 0] [from char]
90 !11 = !{!12}
91 !12 = !{!"0x21\000\001"}        ; [ DW_TAG_subrange_type ]
92 !13 = !MDLocation(line: 3, scope: !14)
93 !14 = !{!"0xb\000\000\000", !17, !1} ; [ DW_TAG_lexical_block ]
94 !15 = !MDLocation(line: 4, scope: !14)
95 !16 = !MDLocation(line: 5, scope: !14)
96 !17 = !{!"vla.c", !"/tmp/"}
97 !18 = !{i32 0}