2014-02-13 07:03:51 +08:00
; RUN: llc %s -o - -filetype=asm -O0 -mtriple=x86_64-unknown-linux-gnu \
2015-07-29 00:24:05 +08:00
; RUN: | FileCheck --check-prefix=NOEMU --check-prefix=SINGLE --check-prefix=SINGLE-64 --check-prefix=GNUOP %s
2014-02-13 07:03:51 +08:00
; RUN: llc %s -o - -filetype=asm -O0 -mtriple=i386-linux-gnu \
2015-07-29 00:24:05 +08:00
; RUN: | FileCheck --check-prefix=NOEMU --check-prefix=SINGLE --check-prefix=SINGLE-32 --check-prefix=GNUOP %s
2014-02-13 07:03:51 +08:00
2017-04-22 07:35:26 +08:00
; RUN: llc %s -o - -filetype=asm -O0 -mtriple=x86_64-unknown-linux-gnu -split-dwarf-file=foo.dwo \
2015-07-29 00:24:05 +08:00
; RUN: | FileCheck --check-prefix=NOEMU --check-prefix=FISSION --check-prefix=GNUOP %s
2013-06-29 04:05:11 +08:00
2015-03-04 05:01:27 +08:00
; RUN: llc %s -o - -filetype=asm -O0 -mtriple=x86_64-scei-ps4 \
2015-07-29 00:24:05 +08:00
; RUN: | FileCheck --check-prefix=NOEMU --check-prefix=SINGLE --check-prefix=SINGLE-64 --check-prefix=STDOP %s
2015-03-05 04:55:11 +08:00
; RUN: llc %s -o - -filetype=asm -O0 -mtriple=x86_64-apple-darwin \
2015-07-29 00:24:05 +08:00
; RUN: | FileCheck --check-prefix=NOEMU --check-prefix=DARWIN --check-prefix=STDOP %s
2015-03-04 05:01:27 +08:00
; RUN: llc %s -o - -filetype=asm -O0 -mtriple=x86_64-unknown-freebsd \
Turn off lldb debug tuning by default for FreeBSD
Summary:
In rL242338, debugger tuning was introduced, and the tuning for FreeBSD
was set to lldb by default. However, for the foreseeable future we
still need to default to gdb tuning, since lldb is not ready for all of
FreeBSD's architectures, and some system tools (like objcopy, etc) have
not yet been adapted to cope with the lldb tuned format, which has
.apple sections.
Therefore, let FreeBSD use gdb by default for now.
Reviewers: emaste, probinson
Subscribers: llvm-commits, emaste
Differential Revision: http://reviews.llvm.org/D15966
llvm-svn: 257103
2016-01-08 06:09:12 +08:00
; RUN: | FileCheck --check-prefix=NOEMU --check-prefix=SINGLE --check-prefix=SINGLE-64 --check-prefix=GNUOP %s
2015-07-29 00:24:05 +08:00
; RUN: llc %s -o - -filetype=asm -O0 -mtriple=x86_64-unknown-linux-gnu -emulated-tls \
; RUN: | FileCheck --check-prefix=SINGLE --check-prefix=EMUSINGLE-64 \
; RUN: --check-prefix=EMUGNUOP --check-prefix=EMU %s
; RUN: llc %s -o - -filetype=asm -O0 -mtriple=i386-linux-gnu -emulated-tls \
; RUN: | FileCheck --check-prefix=SINGLE --check-prefix=EMUSINGLE-32 \
; RUN: --check-prefix=EMUGNUOP --check-prefix=EMU %s
; TODO: Add expected output for -emulated-tls tests.
2015-03-04 05:01:27 +08:00
2013-06-29 04:05:11 +08:00
; FIXME: add relocation and DWARF expression support to llvm-dwarfdump & use
; that here instead of raw assembly printing
2014-02-13 07:03:51 +08:00
; FISSION: .section .debug_info.dwo,
; 3 bytes of data in this DW_FORM_block1 representation of the location of 'tls'
; FISSION: .byte 3{{ *}}# DW_AT_location
2014-02-13 07:03:54 +08:00
; DW_OP_GNU_const_index (0xfx == 252) to refer to the debug_addr table
2014-02-13 07:03:51 +08:00
; FISSION-NEXT: .byte 252
; an index of zero into the debug_addr table
; FISSION-NEXT: .byte 0
; SINGLE: .section .debug_info,
2015-03-05 04:55:11 +08:00
; DARWIN: .section {{.*}}debug_info,
2013-06-29 04:05:11 +08:00
; 10 bytes of data in this DW_FORM_block1 representation of the location of 'tls'
2014-02-13 07:03:51 +08:00
; SINGLE-64: .byte 10 # DW_AT_location
2014-01-25 01:20:08 +08:00
; DW_OP_const8u (0x0e == 14) of address
2014-02-13 07:03:51 +08:00
; SINGLE-64-NEXT: .byte 14
; SINGLE-64-NEXT: .quad tls@DTPOFF
2015-03-05 04:55:11 +08:00
; DARWIN: .byte 10 ## DW_AT_location
; DW_OP_const8u (0x0e == 14) of address
; DARWIN-NEXT: .byte 14
; DARWIN-NEXT: .quad _tls
; 6 bytes of data in 32-bit mode
2014-02-13 07:03:51 +08:00
; SINGLE-32: .byte 6 # DW_AT_location
; DW_OP_const4u (0x0e == 12) of address
; SINGLE-32-NEXT: .byte 12
; SINGLE-32-NEXT: .long tls@DTPOFF
; DW_OP_GNU_push_tls_address
2015-03-05 04:55:11 +08:00
; GNUOP-NEXT: .byte 224
; DW_OP_form_tls_address
; STDOP-NEXT: .byte 155
2013-06-29 04:05:11 +08:00
2014-02-13 07:03:54 +08:00
; FISSION: DW_TAG_variable
; FISSION: .byte 2 # DW_AT_location
; DW_OP_GNU_addr_index
; FISSION-NEXT: .byte 251
; FISSION-NEXT: .byte 1
; FISSION: DW_TAG_template_value_parameter
; FISSION: .byte 3 # DW_AT_location
; DW_OP_GNU_addr_index
; FISSION-NEXT: .byte 251
2014-02-16 03:34:03 +08:00
; FISSION-NEXT: .byte 1
2014-02-13 07:03:54 +08:00
; DW_OP_stack_value
; FISSION-NEXT: .byte 159
2014-02-13 07:03:51 +08:00
; check that the expected TLS address description is the first thing in the debug_addr section
; FISSION: .section .debug_addr
2018-09-20 17:17:36 +08:00
; FISSION-NEXT: .Laddr_table_base0:
2014-02-13 07:03:51 +08:00
; FISSION-NEXT: .quad tls@DTPOFF
2014-02-13 07:03:54 +08:00
; FISSION-NEXT: .quad glbl
2014-02-16 03:34:03 +08:00
; FISSION-NOT: .quad glbl
2014-02-13 07:03:54 +08:00
; Generated from:
; __thread int tls;
; int glbl;
;
; template <int *I>
; int func() {
; return 0;
; }
;
; template int func<&glbl>(); // create a second reference to 'glbl'
2016-12-22 08:45:21 +08:00
source_filename = "test/DebugInfo/X86/tls.ll"
2013-06-29 04:05:11 +08:00
2016-12-22 08:45:21 +08:00
@tls = thread_local global i32 0 , align 4 , !dbg !0
@glbl = global i32 0 , align 4 , !dbg !4
2014-02-13 07:03:54 +08:00
; Function Attrs: nounwind uwtable
2016-12-22 08:45:21 +08:00
define weak_odr i32 @_Z4funcIXadL_Z4glblEEEiv ( ) #0 !dbg !12 {
2014-02-13 07:03:54 +08:00
entry:
ret i32 0 , !dbg !18
}
attributes #0 = { nounwind uwtable "less-precise-fpmad" = "false" "no-frame-pointer-elim" = "true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math" = "false" "no-nans-fp-math" = "false" "stack-protector-buffer-size" = "8" "unsafe-fp-math" = "false" "use-soft-float" = "false" }
2013-06-29 04:05:11 +08:00
2016-12-22 08:45:21 +08:00
!llvm.dbg.cu = ! { !6 }
!llvm.module.flags = ! { !9 , !10 }
!llvm.ident = ! { !11 }
2017-08-31 02:06:51 +08:00
!0 = !DIGlobalVariableExpression ( var: !1 , expr: !DIExpression ( ) )
2016-12-22 08:45:21 +08:00
!1 = !DIGlobalVariable ( name: "tls" , scope: null , file: !2 , line: 1 , type: !3 , isLocal: false , isDefinition: true )
!2 = !DIFile ( filename: "tls.cpp" , directory: "/tmp/dbginfo" )
!3 = !DIBasicType ( name: "int" , size: 32 , align: 32 , encoding: D W _ A T E _ s i g n e d )
2017-08-31 02:06:51 +08:00
!4 = !DIGlobalVariableExpression ( var: !5 , expr: !DIExpression ( ) )
2016-12-22 08:45:21 +08:00
!5 = !DIGlobalVariable ( name: "glbl" , scope: null , file: !2 , line: 2 , type: !3 , isLocal: false , isDefinition: true )
!6 = distinct !DICompileUnit ( language: D W _ L A N G _ C _ p l u s _ p l u s , file: !2 , producer: "clang version 3.5 " , isOptimized: false , runtimeVersion: 0 , splitDebugFilename: "-.dwo" , emissionKind: F u l l D e b u g , enums: !7 , retainedTypes: !7 , globals: !8 , imports: !7 )
!7 = ! { }
!8 = ! { !0 , !4 }
!9 = ! { i32 2 , !"Dwarf Version" , i32 4 }
!10 = ! { i32 1 , !"Debug Info Version" , i32 3 }
!11 = ! { !"clang version 3.5 " }
[DebugInfo] Add DILabel metadata and intrinsic llvm.dbg.label.
In order to set breakpoints on labels and list source code around
labels, we need collect debug information for labels, i.e., label
name, the function label belong, line number in the file, and the
address label located. In order to keep these information in LLVM
IR and to allow backend to generate debug information correctly.
We create a new kind of metadata for labels, DILabel. The format
of DILabel is
!DILabel(scope: !1, name: "foo", file: !2, line: 3)
We hope to keep debug information as much as possible even the
code is optimized. So, we create a new kind of intrinsic for label
metadata to avoid the metadata is eliminated with basic block.
The intrinsic will keep existing if we keep it from optimized out.
The format of the intrinsic is
llvm.dbg.label(metadata !1)
It has only one argument, that is the DILabel metadata. The
intrinsic will follow the label immediately. Backend could get the
label metadata through the intrinsic's parameter.
We also create DIBuilder API for labels to be used by Frontend.
Frontend could use createLabel() to allocate DILabel objects, and use
insertLabel() to insert llvm.dbg.label intrinsic in LLVM IR.
Differential Revision: https://reviews.llvm.org/D45024
Patch by Hsiangkai Wang.
llvm-svn: 331841
2018-05-09 10:40:45 +08:00
!12 = distinct !DISubprogram ( name: "func<&glbl>" , linkageName: "_Z4funcIXadL_Z4glblEEEiv" , scope: !2 , file: !2 , line: 5 , type: !13 , isLocal: false , isDefinition: true , scopeLine: 5 , virtualIndex: 6 , flags: D I F l a g P r o t o t y p e d , isOptimized: false , unit: !6 , templateParams: !15 , retainedNodes: !7 )
2016-12-22 08:45:21 +08:00
!13 = !DISubroutineType ( types: !14 )
!14 = ! { !3 }
!15 = ! { !16 }
!16 = !DITemplateValueParameter ( name: "I" , type: !17 , value: i32 * @glbl )
!17 = !DIDerivedType ( tag: D W _ T A G _ p o i n t e r _ type , baseType: !3 , size: 64 , align: 64 )
!18 = !DILocation ( line: 6 , scope: !12 )