Ulrich Weigand | 0f03982 | 2013-07-02 18:47:35 +0000 | [diff] [blame] | 1 | ; RUN: llc -mtriple=powerpc64-unknown-linux-gnu -O0 -filetype=asm < %s | FileCheck %s |
David Blaikie | 1b01ae8 | 2013-07-01 21:45:25 +0000 | [diff] [blame] | 2 | |
| 3 | ; FIXME: add relocation and DWARF expression support to llvm-dwarfdump & use |
| 4 | ; that here instead of raw assembly printing |
| 5 | |
Ulrich Weigand | 0f03982 | 2013-07-02 18:47:35 +0000 | [diff] [blame] | 6 | ; 10 bytes of data in this DW_FORM_block1 representation of the location of 'tls' |
| 7 | ; CHECK: .byte 10{{ *}}# DW_AT_location |
| 8 | ; DW_OP_const8u |
| 9 | ; CHECK: .byte 14 |
| 10 | ; The debug relocation of the address of the tls variable |
Colin LeMahieu | 0e05192 | 2016-02-10 18:32:01 +0000 | [diff] [blame] | 11 | ; CHECK: .quad tls@DTPREL+32768 |
Ulrich Weigand | 0f03982 | 2013-07-02 18:47:35 +0000 | [diff] [blame] | 12 | ; DW_OP_GNU_push_tls_address |
| 13 | ; CHECK: .byte 224 |
David Blaikie | 1b01ae8 | 2013-07-01 21:45:25 +0000 | [diff] [blame] | 14 | |
| 15 | @tls = thread_local global i32 7, align 4 |
| 16 | |
| 17 | !llvm.dbg.cu = !{!0} |
Manman Ren | 409558f | 2013-11-22 21:49:45 +0000 | [diff] [blame] | 18 | !llvm.module.flags = !{!7, !8} |
David Blaikie | 1b01ae8 | 2013-07-01 21:45:25 +0000 | [diff] [blame] | 19 | |
Adrian Prantl | 75819ae | 2016-04-15 15:57:41 +0000 | [diff] [blame] | 20 | !0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus, producer: "clang version 3.4 ", isOptimized: false, 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] | 21 | !1 = !DIFile(filename: "tls.cpp", directory: "/tmp") |
Duncan P. N. Exon Smith | be7ea19 | 2014-12-15 19:07:53 +0000 | [diff] [blame] | 22 | !2 = !{} |
| 23 | !3 = !{!4} |
Duncan P. N. Exon Smith | a9308c4 | 2015-04-29 16:38:44 +0000 | [diff] [blame] | 24 | !4 = !DIGlobalVariable(name: "tls", line: 1, isLocal: false, isDefinition: true, scope: null, file: !5, type: !6, variable: i32* @tls) |
| 25 | !5 = !DIFile(filename: "tls.cpp", directory: "/tmp") |
| 26 | !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] | 27 | !7 = !{i32 2, !"Dwarf Version", i32 3} |
David Blaikie | 1b01ae8 | 2013-07-01 21:45:25 +0000 | [diff] [blame] | 28 | |
Duncan P. N. Exon Smith | e274180 | 2015-03-03 17:24:31 +0000 | [diff] [blame] | 29 | !8 = !{i32 1, !"Debug Info Version", i32 3} |