Ulrich Weigand | 0f03982 | 2013-07-02 18:47:35 +0000 | [diff] [blame] | 1 | ; RUN: llc -split-dwarf=Enable -mtriple=powerpc64-unknown-linux-gnu -O0 -filetype=asm < %s | FileCheck %s |
| 2 | |
| 3 | ; FIXME: add relocation and DWARF expression support to llvm-dwarfdump & use |
| 4 | ; that here instead of raw assembly printing |
| 5 | |
| 6 | ; CHECK: debug_info.dwo |
| 7 | ; 3 bytes of data in this DW_FORM_block1 representation of the location of 'tls' |
| 8 | ; CHECK: .byte 3{{ *}}# DW_AT_location |
| 9 | ; DW_OP_const_index (0xfx == 252) to refer to the debug_addr table |
| 10 | ; CHECK-NEXT: .byte 252 |
| 11 | ; an index of zero into the debug_addr table |
| 12 | ; CHECK-NEXT: .byte 0 |
| 13 | ; DW_OP_GNU_push_tls_address |
| 14 | ; CHECK-NEXT: .byte 224 |
| 15 | ; check that the expected TLS address description is the first thing in the debug_addr section |
| 16 | ; CHECK: debug_addr |
Rafael Espindola | f1a13f5 | 2015-03-11 00:51:37 +0000 | [diff] [blame] | 17 | ; CHECK-NEXT: .Laddr_sec: |
Colin LeMahieu | 0e05192 | 2016-02-10 18:32:01 +0000 | [diff] [blame] | 18 | ; CHECK-NEXT: .quad tls@DTPREL+32768 |
Ulrich Weigand | 0f03982 | 2013-07-02 18:47:35 +0000 | [diff] [blame] | 19 | |
| 20 | @tls = thread_local global i32 0, align 4 |
| 21 | |
| 22 | !llvm.dbg.cu = !{!0} |
Manman Ren | 409558f | 2013-11-22 21:49:45 +0000 | [diff] [blame] | 23 | !llvm.module.flags = !{!7, !8} |
Ulrich Weigand | 0f03982 | 2013-07-02 18:47:35 +0000 | [diff] [blame] | 24 | |
Adrian Prantl | 75819ae | 2016-04-15 15:57:41 +0000 | [diff] [blame] | 25 | !0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus, producer: "clang version 3.4 ", isOptimized: false, splitDebugFilename: "tls.dwo", emissionKind: FullDebug, file: !1, enums: !2, retainedTypes: !2, globals: !3, imports: !2) |
Duncan P. N. Exon Smith | a9308c4 | 2015-04-29 16:38:44 +0000 | [diff] [blame] | 26 | !1 = !DIFile(filename: "tls.cpp", directory: "/tmp") |
Duncan P. N. Exon Smith | be7ea19 | 2014-12-15 19:07:53 +0000 | [diff] [blame] | 27 | !2 = !{} |
| 28 | !3 = !{!4} |
Duncan P. N. Exon Smith | a9308c4 | 2015-04-29 16:38:44 +0000 | [diff] [blame] | 29 | !4 = !DIGlobalVariable(name: "tls", line: 1, isLocal: false, isDefinition: true, scope: null, file: !5, type: !6, variable: i32* @tls) |
| 30 | !5 = !DIFile(filename: "tls.cpp", directory: "/tmp") |
| 31 | !6 = !DIBasicType(tag: DW_TAG_base_type, name: "int", size: 32, align: 32, encoding: DW_ATE_signed) |
Duncan P. N. Exon Smith | be7ea19 | 2014-12-15 19:07:53 +0000 | [diff] [blame] | 32 | !7 = !{i32 2, !"Dwarf Version", i32 3} |
Duncan P. N. Exon Smith | e274180 | 2015-03-03 17:24:31 +0000 | [diff] [blame] | 33 | !8 = !{i32 1, !"Debug Info Version", i32 3} |