1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=aarch64-non-linux-gnu -dwarf-version=4 < %s -filetype=obj \ 2*9880d681SAndroid Build Coastguard Worker; RUN: | llvm-dwarfdump - | FileCheck -check-prefix=CHECK -check-prefix=CHECK-4 %s 3*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=aarch64-non-linux-gnu -dwarf-version=3 < %s -filetype=obj \ 4*9880d681SAndroid Build Coastguard Worker; RUN: | llvm-dwarfdump - | FileCheck -check-prefix=CHECK -check-prefix=CHECK-3 %s 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Worker; We're mostly checking that relocations are applied correctly 7*9880d681SAndroid Build Coastguard Worker; here. Currently R_AARCH64_ABS32 is used for references to debug data 8*9880d681SAndroid Build Coastguard Worker; and R_AARCH64_ABS64 is used for program addresses. 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Worker; A couple of ABS32s, both at 0 and elsewhere, interpreted correctly: 11*9880d681SAndroid Build Coastguard Worker 12*9880d681SAndroid Build Coastguard Worker; CHECK: DW_AT_producer [DW_FORM_strp] ( .debug_str[0x00000000] = "clang version 3.3 ") 13*9880d681SAndroid Build Coastguard Worker; CHECK: DW_AT_name [DW_FORM_strp] ( .debug_str[0x00000013] = "tmp.c") 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Worker; A couple of ABS64s similarly: 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Worker; CHECK: DW_AT_low_pc [DW_FORM_addr] (0x0000000000000000) 18*9880d681SAndroid Build Coastguard Worker; CHECK-4: DW_AT_high_pc [DW_FORM_data4] (0x00000008) 19*9880d681SAndroid Build Coastguard Worker; CHECK-3: DW_AT_high_pc [DW_FORM_addr] (0x0000000000000008) 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Workerdefine i32 @main() nounwind !dbg !3 { 22*9880d681SAndroid Build Coastguard Worker ret i32 0, !dbg !8 23*9880d681SAndroid Build Coastguard Worker} 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Workerattributes #0 = { nounwind } 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Worker!llvm.dbg.cu = !{!0} 28*9880d681SAndroid Build Coastguard Worker!llvm.module.flags = !{!10} 29*9880d681SAndroid Build Coastguard Worker 30*9880d681SAndroid Build Coastguard Worker!0 = distinct !DICompileUnit(language: DW_LANG_C99, producer: "clang version 3.3 ", isOptimized: false, emissionKind: FullDebug, file: !9, enums: !1, retainedTypes: !1, globals: !1, imports: !1) 31*9880d681SAndroid Build Coastguard Worker!1 = !{} 32*9880d681SAndroid Build Coastguard Worker!3 = distinct !DISubprogram(name: "main", line: 1, isLocal: false, isDefinition: true, virtualIndex: 6, isOptimized: false, unit: !0, scopeLine: 1, file: !9, scope: !4, type: !5, variables: !1) 33*9880d681SAndroid Build Coastguard Worker!4 = !DIFile(filename: "tmp.c", directory: "/home/tim/llvm/build") 34*9880d681SAndroid Build Coastguard Worker!5 = !DISubroutineType(types: !6) 35*9880d681SAndroid Build Coastguard Worker!6 = !{!7} 36*9880d681SAndroid Build Coastguard Worker!7 = !DIBasicType(tag: DW_TAG_base_type, name: "int", size: 32, align: 32, encoding: DW_ATE_signed) 37*9880d681SAndroid Build Coastguard Worker!8 = !DILocation(line: 2, scope: !3) 38*9880d681SAndroid Build Coastguard Worker!9 = !DIFile(filename: "tmp.c", directory: "/home/tim/llvm/build") 39*9880d681SAndroid Build Coastguard Worker!10 = !{i32 1, !"Debug Info Version", i32 3} 40