llvm/llvm/test/CodeGen/AArch64/GlobalISel/localizer-propagate-debug-loc.mir

# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
# RUN: llc -O0 %s -global-isel -start-before localizer \
# RUN:    -stop-after localizer -o - | FileCheck --check-prefix=CHECK %s
--- |
  target datalayout = "e-m:o-i64:64-i128:128-n32:64-S128"
  target triple = "arm64-apple-macosx12.0.0"

  @A = global i32 1234, align 4
  @B = global i32 5678, align 4
  @C = global i32 9012, align 4

  define noundef i32 @foo() !dbg !5 {
    %1 = alloca i32, align 4
    br i1 false, label %2, label %4

  2:                                                ; preds = %0
    %3 = load i32, ptr @A, align 4, !dbg !10
    store volatile i32 %3, ptr %1, align 4
    br label %9

  4:                                                ; preds = %0
    br i1 false, label %5, label %8

  5:                                                ; preds = %4
    %6 = load i32, ptr @B, align 4, !dbg !13
    store volatile i32 %6, ptr %1, align 4
    %7 = load i32, ptr @B, align 4, !dbg !16
    store volatile i32 %7, ptr %1, align 4
    br label %9

  8:                                                ; preds = %4
    store i32 3, ptr @C, align 4, !dbg !17
    br label %9

  9:                                                ; preds = %8, %5, %2
    ret i32 0
  }

  !llvm.dbg.cu = !{!0}
  !llvm.module.flags = !{!2, !3, !4}

  !0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus_14, file: !1, isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, splitDebugInlining: false, nameTableKind: None)
  !1 = !DIFile(filename: "tmp.ll", directory: "/")
  !2 = !{i32 7, !"Dwarf Version", i32 4}
  !3 = !{i32 2, !"Debug Info Version", i32 3}
  !4 = !{i32 1, !"wchar_size", i32 4}
  !5 = distinct !DISubprogram(name: "foo", scope: !1, file: !1, line: 5, type: !6, scopeLine: 5, flags: DIFlagPrototyped, spFlags: DISPFlagDefinition, unit: !0, retainedNodes: !9)
  !6 = !DISubroutineType(types: !7)
  !7 = !{!8}
  !8 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
  !9 = !{}
  !10 = !DILocation(line: 9, column: 9, scope: !11)
  !11 = distinct !DILexicalBlock(scope: !12, file: !1, line: 8, column: 15)
  !12 = distinct !DILexicalBlock(scope: !5, file: !1, line: 8, column: 7)
  !13 = !DILocation(line: 11, column: 9, scope: !14)
  !14 = distinct !DILexicalBlock(scope: !15, file: !1, line: 10, column: 22)
  !15 = distinct !DILexicalBlock(scope: !12, file: !1, line: 10, column: 14)
  !16 = !DILocation(line: 12, column: 13, scope: !14)
  !17 = !DILocation(line: 14, column: 7, scope: !18)
  !18 = distinct !DILexicalBlock(scope: !15, file: !1, line: 13, column: 10)

...
---
name:            foo
alignment:       4
legalized:       true
regBankSelected: true
tracksRegLiveness: true
stack:
  - { id: 0, name: '', type: default, offset: 0, size: 4, alignment: 4,
      stack-id: default, callee-saved-register: '', callee-saved-restored: true,
      debug-info-variable: '', debug-info-expression: '', debug-info-location: '' }
body:             |
  ; CHECK:   [[ADRP3:%[0-9]+]]:gpr64(p0) = ADRP target-flags(aarch64-page) @A, debug-location !10
  ; CHECK-NEXT:   [[ADD_LOW3:%[0-9]+]]:gpr(p0) = G_ADD_LOW [[ADRP3]](p0), target-flags(aarch64-pageoff, aarch64-nc) @A, debug-location !10
  ; CHECK-NEXT:   [[LOAD:%[0-9]+]]:gpr(s32) = G_LOAD [[ADD_LOW3]](p0), debug-location !10 :: (dereferenceable load (s32))

  ; CHECK:   [[ADRP4:%[0-9]+]]:gpr64(p0) = ADRP target-flags(aarch64-page) @B, debug-location !DILocation(line: 0, scope: !14)
  ; CHECK-NEXT:   [[ADD_LOW4:%[0-9]+]]:gpr(p0) = G_ADD_LOW [[ADRP4]](p0), target-flags(aarch64-pageoff, aarch64-nc) @B, debug-location !DILocation(line: 0, scope: !14)
  ; CHECK-NEXT:   [[LOAD1:%[0-9]+]]:gpr(s32) = G_LOAD [[ADD_LOW4]](p0), debug-location !13 :: (dereferenceable load (s32))

  ; CHECK:   [[ADRP5:%[0-9]+]]:gpr64(p0) = ADRP target-flags(aarch64-page) @C, debug-location !17
  ; CHECK-NEXT:   [[ADD_LOW5:%[0-9]+]]:gpr(p0) = G_ADD_LOW [[ADRP5]](p0), target-flags(aarch64-pageoff, aarch64-nc) @C, debug-location !17
  ; CHECK-NEXT:   [[C5:%[0-9]+]]:gpr(s32) = G_CONSTANT i32 3, debug-location !17
  ; CHECK-NEXT:   G_STORE [[C5]](s32), [[ADD_LOW5]](p0), debug-location !17 :: (store (s32) into @C)
  bb.1:
    successors: %bb.2(0x40000000), %bb.3(0x40000000)

    %2:gpr(s32) = G_CONSTANT i32 3
    %24:gpr64(p0) = ADRP target-flags(aarch64-page) @C, debug-location !DILocation(line: 0, scope: !18)
    %3:gpr(p0) = G_ADD_LOW %24(p0), target-flags(aarch64-pageoff, aarch64-nc) @C, debug-location !DILocation(line: 0, scope: !18)
    %23:gpr64(p0) = ADRP target-flags(aarch64-page) @B, debug-location !DILocation(line: 0, scope: !14)
    %5:gpr(p0) = G_ADD_LOW %23(p0), target-flags(aarch64-pageoff, aarch64-nc) @B, debug-location !DILocation(line: 0, scope: !14)
    %22:gpr64(p0) = ADRP target-flags(aarch64-page) @A, debug-location !DILocation(line: 0, scope: !11)
    %8:gpr(p0) = G_ADD_LOW %22(p0), target-flags(aarch64-pageoff, aarch64-nc) @A, debug-location !DILocation(line: 0, scope: !11)
    %9:gpr(s32) = G_CONSTANT i32 0
    %0:gpr(p0) = G_FRAME_INDEX %stack.0
    %18:gpr(s32) = COPY %9(s32)
    %19:gpr(s32) = G_CONSTANT i32 1
    %20:gpr(s32) = G_XOR %18, %19
    %11:gpr(s1) = G_TRUNC %20(s32)
    G_BRCOND %11(s1), %bb.3
    G_BR %bb.2

  bb.2:
    successors: %bb.6(0x80000000)

    %7:gpr(s32) = G_LOAD %8(p0), debug-location !10 :: (dereferenceable load (s32))
    G_STORE %7(s32), %0(p0) :: (volatile store (s32) into %ir.1)
    G_BR %bb.6

  bb.3:
    successors: %bb.4(0x40000000), %bb.5(0x40000000)

    %14:gpr(s32) = G_CONSTANT i32 0
    %15:gpr(s32) = G_CONSTANT i32 1
    %16:gpr(s32) = G_XOR %14, %15
    %13:gpr(s1) = G_TRUNC %16(s32)
    G_BRCOND %13(s1), %bb.5
    G_BR %bb.4

  bb.4:
    successors: %bb.6(0x80000000)

    %4:gpr(s32) = G_LOAD %5(p0), debug-location !13 :: (dereferenceable load (s32))
    G_STORE %4(s32), %0(p0) :: (volatile store (s32) into %ir.1)
    %6:gpr(s32) = G_LOAD %5(p0), debug-location !16 :: (dereferenceable load (s32))
    G_STORE %6(s32), %0(p0) :: (volatile store (s32) into %ir.1)
    G_BR %bb.6

  bb.5:
    successors: %bb.6(0x80000000)

    G_STORE %2(s32), %3(p0), debug-location !17 :: (store (s32) into @C)
    G_BR %bb.6

  bb.6:
    $w0 = COPY %9(s32)
    RET_ReallyLR implicit $w0

...