1*9880d681SAndroid Build Coastguard Worker; REQUIRES: object-emission 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=x86_64-linux -O0 -filetype=obj -generate-arange-section < %s | llvm-dwarfdump -debug-dump=aranges - | FileCheck %s 4*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=x86_64-linux -O0 -filetype=obj -generate-arange-section < %s | llvm-readobj --relocations - | FileCheck --check-prefix=OBJ %s 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Worker; extern int i; 7*9880d681SAndroid Build Coastguard Worker; template<int *x> 8*9880d681SAndroid Build Coastguard Worker; struct foo { 9*9880d681SAndroid Build Coastguard Worker; }; 10*9880d681SAndroid Build Coastguard Worker; 11*9880d681SAndroid Build Coastguard Worker; foo<&i> f; 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Worker; Check that we only have one arange in this compilation unit (it will be for 'f'), and not an extra one (for 'i' - since it isn't actually defined in this CU) 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Worker; CHECK: Address Range Header 16*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: [0x 17*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: [0x 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Worker; Check that we have a relocation back to the debug_info section from the debug_aranges section 20*9880d681SAndroid Build Coastguard Worker; OBJ: debug_aranges 21*9880d681SAndroid Build Coastguard Worker; OBJ-NEXT: R_X86_64_32 .debug_info 0x0 22*9880d681SAndroid Build Coastguard Worker 23*9880d681SAndroid Build Coastguard Worker%struct.foo = type { i8 } 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Worker@f = global %struct.foo zeroinitializer, align 1 26*9880d681SAndroid Build Coastguard Worker@i = external global i32 27*9880d681SAndroid Build Coastguard Worker 28*9880d681SAndroid Build Coastguard Worker!llvm.dbg.cu = !{!0} 29*9880d681SAndroid Build Coastguard Worker!llvm.module.flags = !{!12, !13} 30*9880d681SAndroid Build Coastguard Worker!llvm.ident = !{!14} 31*9880d681SAndroid Build Coastguard Worker 32*9880d681SAndroid Build Coastguard Worker!0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus, producer: "clang version 3.5 ", isOptimized: false, emissionKind: FullDebug, file: !1, enums: !2, retainedTypes: !3, globals: !9, imports: !2) 33*9880d681SAndroid Build Coastguard Worker!1 = !DIFile(filename: "simple.cpp", directory: "/tmp/dbginfo") 34*9880d681SAndroid Build Coastguard Worker!2 = !{} 35*9880d681SAndroid Build Coastguard Worker!3 = !{!4} 36*9880d681SAndroid Build Coastguard Worker!4 = !DICompositeType(tag: DW_TAG_structure_type, name: "foo<&i>", line: 3, size: 8, align: 8, file: !1, elements: !2, templateParams: !5, identifier: "_ZTS3fooIXadL_Z1iEEE") 37*9880d681SAndroid Build Coastguard Worker!5 = !{!6} 38*9880d681SAndroid Build Coastguard Worker!6 = !DITemplateValueParameter(tag: DW_TAG_template_value_parameter, name: "x", type: !7, value: i32* @i) 39*9880d681SAndroid Build Coastguard Worker!7 = !DIDerivedType(tag: DW_TAG_pointer_type, size: 64, align: 64, baseType: !8) 40*9880d681SAndroid Build Coastguard Worker!8 = !DIBasicType(tag: DW_TAG_base_type, name: "int", size: 32, align: 32, encoding: DW_ATE_signed) 41*9880d681SAndroid Build Coastguard Worker!9 = !{!10} 42*9880d681SAndroid Build Coastguard Worker!10 = !DIGlobalVariable(name: "f", line: 6, isLocal: false, isDefinition: true, scope: null, file: !11, type: !4, variable: %struct.foo* @f) 43*9880d681SAndroid Build Coastguard Worker!11 = !DIFile(filename: "simple.cpp", directory: "/tmp/dbginfo") 44*9880d681SAndroid Build Coastguard Worker!12 = !{i32 2, !"Dwarf Version", i32 4} 45*9880d681SAndroid Build Coastguard Worker!13 = !{i32 1, !"Debug Info Version", i32 3} 46*9880d681SAndroid Build Coastguard Worker!14 = !{!"clang version 3.5 "} 47