1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-22 20:43:44 +02:00
llvm-mirror/test/CodeGen/X86/lea-opt-with-debug.mir
Reid Kleckner 67886a34d2 Parse and print DIExpressions inline to ease IR and MIR testing
Summary:
Most DIExpressions are empty or very simple. When they are complex, they
tend to be unique, so checking them inline is reasonable.

This also avoids the need for CodeGen passes to append to the
llvm.dbg.mir named md node.

See also PR22780, for making DIExpression not be an MDNode.

Reviewers: aprantl, dexonsmith, dblaikie

Subscribers: qcolombet, javed.absar, eraman, hiraditya, llvm-commits

Differential Revision: https://reviews.llvm.org/D37075

llvm-svn: 311594
2017-08-23 20:31:27 +00:00

123 lines
4.7 KiB
YAML

# RUN: llc -mtriple=x86_64-unknown-unknown -start-after=peephole-opt -stop-before=detect-dead-lanes -o - %s | FileCheck %s
# Test that the optimize LEA pass can remove a redundant LEA even when it is
# also used by a DBG_VALUE. Check that the uses of the replaced LEA are updated
# correctly.
--- |
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
%struct.A = type { i32, i32, i32 }
@c = common local_unnamed_addr global %struct.A* null, align 8
@a = common local_unnamed_addr global i32 0, align 4
@d = common local_unnamed_addr global i32 0, align 4
@b = common local_unnamed_addr global i32 0, align 4
define i32 @fn1() local_unnamed_addr !dbg !8 {
%1 = load %struct.A*, %struct.A** @c, align 8, !dbg !13
%2 = load i32, i32* @a, align 4, !dbg !13
%3 = sext i32 %2 to i64, !dbg !13
%4 = getelementptr inbounds %struct.A, %struct.A* %1, i64 %3, !dbg !13
%5 = ptrtoint %struct.A* %4 to i64, !dbg !13
%6 = trunc i64 %5 to i32, !dbg !13
store i32 %6, i32* @d, align 4, !dbg !13
%7 = getelementptr inbounds %struct.A, %struct.A* %1, i64 %3, i32 2, !dbg !14
tail call void @llvm.dbg.value(metadata i32* %7, i64 0, metadata !11, metadata !DIExpression()), !dbg !15
br label %8, !dbg !16
; <label>:8: ; preds = %8, %0
%9 = load i32, i32* %7, align 4, !dbg !17
store i32 %9, i32* @d, align 4, !dbg !17
br label %8, !dbg !18
}
; Function Attrs: nounwind readnone
declare void @llvm.dbg.value(metadata, i64, metadata, metadata) #0
attributes #0 = { nounwind readnone }
!llvm.dbg.cu = !{!0}
!llvm.module.flags = !{!5, !6, !7}
!0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, enums: !2, retainedTypes: !3, globals: !2)
!1 = !DIFile(filename: "test.c", directory: "")
!2 = !{}
!3 = !{!4}
!4 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
!5 = !{i32 2, !"Dwarf Version", i32 4}
!6 = !{i32 2, !"Debug Info Version", i32 3}
!7 = !{i32 1, !"PIC Level", i32 2}
!8 = distinct !DISubprogram(name: "fn1", scope: !1, file: !1, line: 7, type: !9, isLocal: false, isDefinition: true, scopeLine: 7, isOptimized: true, unit: !0, variables: !10)
!9 = !DISubroutineType(types: !3)
!10 = !{!11}
!11 = !DILocalVariable(name: "e", scope: !8, file: !1, line: 8, type: !12)
!12 = !DIDerivedType(tag: DW_TAG_pointer_type, baseType: !4, size: 64)
!13 = !DILocation(line: 9, scope: !8)
!14 = !DILocation(line: 10, scope: !8)
!15 = !DILocation(line: 8, scope: !8)
!16 = !DILocation(line: 11, scope: !8)
!17 = !DILocation(line: 13, scope: !8)
!18 = !DILocation(line: 14, scope: !8)
...
---
name: fn1
alignment: 4
exposesReturnsTwice: false
legalized: false
regBankSelected: false
selected: false
tracksRegLiveness: true
registers:
- { id: 0, class: gr64 }
- { id: 1, class: gr64 }
- { id: 2, class: gr64_nosp }
- { id: 3, class: gr64_nosp }
- { id: 4, class: gr64 }
- { id: 5, class: gr32 }
- { id: 6, class: gr32 }
frameInfo:
isFrameAddressTaken: false
isReturnAddressTaken: false
hasStackMap: false
hasPatchPoint: false
stackSize: 0
offsetAdjustment: 0
maxAlignment: 0
adjustsStack: false
hasCalls: false
maxCallFrameSize: 0
hasOpaqueSPAdjustment: false
hasVAStart: false
hasMustTailInVarArgFunc: false
body: |
bb.0 (%ir-block.0):
successors: %bb.1(0x80000000)
; CHECK: %3 = LEA64r %2, 2, %2, 0, _, debug-location !13
; CHECK-NEXT: %4 = LEA64r %1, 4, %3, 0, _, debug-location !13
; CHECK-NOT: %0 = LEA64r %1, 4, %3, 8, _, debug-location !14
; CHECK: DBG_VALUE debug-use %4, debug-use _, !11, !DIExpression(DW_OP_plus_uconst, 8, DW_OP_stack_value), debug-location !15
%1 = MOV64rm %rip, 1, _, @c, _, debug-location !13 :: (dereferenceable load 8 from @c)
%2 = MOVSX64rm32 %rip, 1, _, @a, _, debug-location !13 :: (dereferenceable load 4 from @a)
%3 = LEA64r %2, 2, %2, 0, _, debug-location !13
%4 = LEA64r %1, 4, %3, 0, _, debug-location !13
%5 = COPY %4.sub_32bit, debug-location !13
MOV32mr %rip, 1, _, @d, _, killed %5, debug-location !13 :: (store 4 into @d)
%0 = LEA64r %1, 4, %3, 8, _, debug-location !14
DBG_VALUE debug-use %0, debug-use _, !11, !DIExpression(), debug-location !15
; CHECK-LABEL: bb.1 (%ir-block.8):
; CHECK: %6 = MOV32rm %4, 1, _, 8, _, debug-location !17 :: (load 4 from %ir.7)
bb.1 (%ir-block.8):
successors: %bb.1(0x80000000)
%6 = MOV32rm %0, 1, _, 0, _, debug-location !17 :: (load 4 from %ir.7)
MOV32mr %rip, 1, _, @d, _, killed %6, debug-location !17 :: (store 4 into @d)
JMP_1 %bb.1, debug-location !18
...