mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-19 17:33:29 +00:00
37ac8d3622
This commit moves `MDLocation`, finishing off PR21433. There's an accompanying clang commit for frontend testcases. I'll attach the testcase upgrade script I used to PR21433 to help out-of-tree frontends/backends. This changes the schema for `DebugLoc` and `DILocation` from: !{i32 3, i32 7, !7, !8} to: !MDLocation(line: 3, column: 7, scope: !7, inlinedAt: !8) Note that empty fields (line/column: 0 and inlinedAt: null) don't get printed by the assembly writer. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@226048 91177308-0d34-0410-b5e6-96231b3b80d8
66 lines
3.0 KiB
LLVM
66 lines
3.0 KiB
LLVM
; RUN: opt < %s -scalarrepl -S | FileCheck %s
|
|
; RUN: opt < %s -scalarrepl-ssa -S | FileCheck %s
|
|
target 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-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
|
|
target triple = "x86_64-apple-macosx10.6.0"
|
|
|
|
; CHECK: f
|
|
; CHECK-NOT: llvm.dbg.declare
|
|
; CHECK: llvm.dbg.value
|
|
; CHECK: llvm.dbg.value
|
|
; CHECK: llvm.dbg.value
|
|
; CHECK: llvm.dbg.value
|
|
; CHECK: llvm.dbg.value
|
|
|
|
define i32 @f(i32 %a, i32 %b) nounwind ssp {
|
|
entry:
|
|
%a.addr = alloca i32, align 4
|
|
%b.addr = alloca i32, align 4
|
|
%c = alloca i32, align 4
|
|
store i32 %a, i32* %a.addr, align 4
|
|
call void @llvm.dbg.declare(metadata i32* %a.addr, metadata !6, metadata !{}), !dbg !7
|
|
store i32 %b, i32* %b.addr, align 4
|
|
call void @llvm.dbg.declare(metadata i32* %b.addr, metadata !8, metadata !{}), !dbg !9
|
|
call void @llvm.dbg.declare(metadata i32* %c, metadata !10, metadata !{}), !dbg !12
|
|
%tmp = load i32* %a.addr, align 4, !dbg !13
|
|
store i32 %tmp, i32* %c, align 4, !dbg !13
|
|
%tmp1 = load i32* %a.addr, align 4, !dbg !14
|
|
%tmp2 = load i32* %b.addr, align 4, !dbg !14
|
|
%add = add nsw i32 %tmp1, %tmp2, !dbg !14
|
|
store i32 %add, i32* %a.addr, align 4, !dbg !14
|
|
%tmp3 = load i32* %c, align 4, !dbg !15
|
|
%tmp4 = load i32* %b.addr, align 4, !dbg !15
|
|
%sub = sub nsw i32 %tmp3, %tmp4, !dbg !15
|
|
store i32 %sub, i32* %b.addr, align 4, !dbg !15
|
|
%tmp5 = load i32* %a.addr, align 4, !dbg !16
|
|
%tmp6 = load i32* %b.addr, align 4, !dbg !16
|
|
%add7 = add nsw i32 %tmp5, %tmp6, !dbg !16
|
|
ret i32 %add7, !dbg !16
|
|
}
|
|
|
|
declare void @llvm.dbg.declare(metadata, metadata, metadata) nounwind readnone
|
|
|
|
!llvm.dbg.cu = !{!0}
|
|
!llvm.module.flags = !{!20}
|
|
|
|
!0 = !{!"0x11\0012\00clang version 3.0 (trunk 131941)\000\00\000\00\000", !18, !19, !19, !17, null, null} ; [ DW_TAG_compile_unit ]
|
|
!1 = !{!"0x2e\00f\00f\00\001\000\001\000\006\00256\000\001", !18, !2, !3, null, i32 (i32, i32)* @f, null, null, null} ; [ DW_TAG_subprogram ] [line 1] [def] [f]
|
|
!2 = !{!"0x29", !18} ; [ DW_TAG_file_type ]
|
|
!3 = !{!"0x15\00\000\000\000\000\000\000", !18, !2, null, !4, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]
|
|
!4 = !{!5}
|
|
!5 = !{!"0x24\00int\000\0032\0032\000\000\005", null, !0} ; [ DW_TAG_base_type ]
|
|
!6 = !{!"0x101\00a\0016777217\000", !1, !2, !5} ; [ DW_TAG_arg_variable ]
|
|
!7 = !MDLocation(line: 1, column: 11, scope: !1)
|
|
!8 = !{!"0x101\00b\0033554433\000", !1, !2, !5} ; [ DW_TAG_arg_variable ]
|
|
!9 = !MDLocation(line: 1, column: 18, scope: !1)
|
|
!10 = !{!"0x100\00c\002\000", !11, !2, !5} ; [ DW_TAG_auto_variable ]
|
|
!11 = !{!"0xb\001\0021\000", !18, !1} ; [ DW_TAG_lexical_block ]
|
|
!12 = !MDLocation(line: 2, column: 9, scope: !11)
|
|
!13 = !MDLocation(line: 2, column: 14, scope: !11)
|
|
!14 = !MDLocation(line: 3, column: 5, scope: !11)
|
|
!15 = !MDLocation(line: 4, column: 5, scope: !11)
|
|
!16 = !MDLocation(line: 5, column: 5, scope: !11)
|
|
!17 = !{!1}
|
|
!18 = !{!"/d/j/debug-test.c", !"/Volumes/Data/b"}
|
|
!19 = !{i32 0}
|
|
!20 = !{i32 1, !"Debug Info Version", i32 2}
|