forked from OSchip/llvm-project
Always use the string pool, even when it makes the .o larger. This may help
tools that read the debug info in the .o files by making the DIE sizes more consistent. llvm-svn: 143186
This commit is contained in:
parent
effdca9441
commit
cc64ae140d
|
@ -235,24 +235,6 @@ void DIEInteger::print(raw_ostream &O) {
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
|
||||||
// DIEString Implementation
|
|
||||||
//===----------------------------------------------------------------------===//
|
|
||||||
|
|
||||||
/// EmitValue - Emit string value.
|
|
||||||
///
|
|
||||||
void DIEString::EmitValue(AsmPrinter *AP, unsigned Form) const {
|
|
||||||
AP->OutStreamer.EmitBytes(Str, /*addrspace*/0);
|
|
||||||
// Emit nul terminator.
|
|
||||||
AP->OutStreamer.EmitIntValue(0, 1, /*addrspace*/0);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef NDEBUG
|
|
||||||
void DIEString::print(raw_ostream &O) {
|
|
||||||
O << "Str: \"" << Str << "\"";
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// DIELabel Implementation
|
// DIELabel Implementation
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
|
@ -269,33 +269,6 @@ namespace llvm {
|
||||||
static bool classof(const DIEInteger *) { return true; }
|
static bool classof(const DIEInteger *) { return true; }
|
||||||
static bool classof(const DIEValue *I) { return I->getType() == isInteger; }
|
static bool classof(const DIEValue *I) { return I->getType() == isInteger; }
|
||||||
|
|
||||||
#ifndef NDEBUG
|
|
||||||
virtual void print(raw_ostream &O);
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
|
|
||||||
//===--------------------------------------------------------------------===//
|
|
||||||
/// DIEString - A string value DIE. This DIE keeps string reference only.
|
|
||||||
///
|
|
||||||
class DIEString : public DIEValue {
|
|
||||||
const StringRef Str;
|
|
||||||
public:
|
|
||||||
explicit DIEString(const StringRef S) : DIEValue(isString), Str(S) {}
|
|
||||||
|
|
||||||
/// EmitValue - Emit string value.
|
|
||||||
///
|
|
||||||
virtual void EmitValue(AsmPrinter *AP, unsigned Form) const;
|
|
||||||
|
|
||||||
/// SizeOf - Determine size of string value in bytes.
|
|
||||||
///
|
|
||||||
virtual unsigned SizeOf(AsmPrinter *AP, unsigned /*Form*/) const {
|
|
||||||
return Str.size() + sizeof(char); // sizeof('\0');
|
|
||||||
}
|
|
||||||
|
|
||||||
// Implement isa/cast/dyncast.
|
|
||||||
static bool classof(const DIEString *) { return true; }
|
|
||||||
static bool classof(const DIEValue *S) { return S->getType() == isString; }
|
|
||||||
|
|
||||||
#ifndef NDEBUG
|
#ifndef NDEBUG
|
||||||
virtual void print(raw_ostream &O);
|
virtual void print(raw_ostream &O);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -67,23 +67,19 @@ void CompileUnit::addSInt(DIE *Die, unsigned Attribute,
|
||||||
Die->addValue(Attribute, Form, Value);
|
Die->addValue(Attribute, Form, Value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// addString - Add a string attribute data and value. DIEString only
|
/// addString - Add a string attribute data and value. We always emit a
|
||||||
/// keeps string reference.
|
/// reference to the string pool instead of immediate strings so that DIEs have
|
||||||
|
/// more predictable sizes.
|
||||||
void CompileUnit::addString(DIE *Die, unsigned Attribute, StringRef String) {
|
void CompileUnit::addString(DIE *Die, unsigned Attribute, StringRef String) {
|
||||||
if (String.size() > 3) {
|
MCSymbol *Symb = DD->getStringPoolEntry(String);
|
||||||
MCSymbol *Symb = DD->getStringPoolEntry(String);
|
DIEValue *Value;
|
||||||
DIEValue *Value;
|
if (Asm->needsRelocationsForDwarfStringPool())
|
||||||
if (Asm->needsRelocationsForDwarfStringPool())
|
Value = new (DIEValueAllocator) DIELabel(Symb);
|
||||||
Value = new (DIEValueAllocator) DIELabel(Symb);
|
else {
|
||||||
else {
|
MCSymbol *StringPool = DD->getStringPool();
|
||||||
MCSymbol *StringPool = DD->getStringPool();
|
Value = new (DIEValueAllocator) DIEDelta(Symb, StringPool);
|
||||||
Value = new (DIEValueAllocator) DIEDelta(Symb, StringPool);
|
|
||||||
}
|
|
||||||
Die->addValue(Attribute, dwarf::DW_FORM_strp, Value);
|
|
||||||
} else {
|
|
||||||
DIEValue *Value = new (DIEValueAllocator) DIEString(String);
|
|
||||||
Die->addValue(Attribute, dwarf::DW_FORM_string, Value);
|
|
||||||
}
|
}
|
||||||
|
Die->addValue(Attribute, dwarf::DW_FORM_strp, Value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// addLabel - Add a Dwarf label attribute data and value.
|
/// addLabel - Add a Dwarf label attribute data and value.
|
||||||
|
|
|
@ -17,8 +17,7 @@ target triple = "thumbv7-apple-darwin10"
|
||||||
; DW_OP_constu
|
; DW_OP_constu
|
||||||
; offset
|
; offset
|
||||||
|
|
||||||
;CHECK: .ascii "x2" @ DW_AT_name
|
;CHECK: .long Lset6
|
||||||
;CHECK-NEXT: .byte 0
|
|
||||||
;CHECK-NEXT: @ DW_AT_type
|
;CHECK-NEXT: @ DW_AT_type
|
||||||
;CHECK-NEXT: @ DW_AT_decl_file
|
;CHECK-NEXT: @ DW_AT_decl_file
|
||||||
;CHECK-NEXT: @ DW_AT_decl_line
|
;CHECK-NEXT: @ DW_AT_decl_line
|
||||||
|
|
|
@ -8,8 +8,7 @@
|
||||||
; DW_OP_constu
|
; DW_OP_constu
|
||||||
; offset
|
; offset
|
||||||
|
|
||||||
;CHECK: .ascii "x2" @ DW_AT_name
|
;CHECK: .long Lset33
|
||||||
;CHECK-NEXT: .byte 0
|
|
||||||
;CHECK-NEXT: @ DW_AT_type
|
;CHECK-NEXT: @ DW_AT_type
|
||||||
;CHECK-NEXT: @ DW_AT_decl_file
|
;CHECK-NEXT: @ DW_AT_decl_file
|
||||||
;CHECK-NEXT: @ DW_AT_decl_line
|
;CHECK-NEXT: @ DW_AT_decl_line
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
; RUN: llc -march=x86 -O0 < %s | FileCheck %s
|
; RUN: llc -march=x86 -O0 < %s | FileCheck %s
|
||||||
; CHECK: DW_TAG_constant
|
; CHECK: DW_TAG_constant
|
||||||
; CHECK-NEXT: ascii "ro" #{{#?}} DW_AT_name
|
; CHECK-NEXT: .long .Lstring3 #{{#?}} DW_AT_name
|
||||||
|
|
||||||
define void @foo() nounwind ssp {
|
define void @foo() nounwind ssp {
|
||||||
entry:
|
entry:
|
||||||
|
|
|
@ -4,8 +4,7 @@ target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f3
|
||||||
target triple = "x86_64-apple-darwin10.0.0"
|
target triple = "x86_64-apple-darwin10.0.0"
|
||||||
|
|
||||||
; Check debug info for variable z_s
|
; Check debug info for variable z_s
|
||||||
;CHECK: .ascii "z_s" ## DW_AT_name
|
;CHECK: .long Lset13
|
||||||
;CHECK-NEXT: .byte 0
|
|
||||||
;CHECK-NEXT: ## DW_AT_decl_file
|
;CHECK-NEXT: ## DW_AT_decl_file
|
||||||
;CHECK-NEXT: ## DW_AT_decl_line
|
;CHECK-NEXT: ## DW_AT_decl_line
|
||||||
;CHECK-NEXT: ## DW_AT_type
|
;CHECK-NEXT: ## DW_AT_type
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
;CHECK-NEXT: DW_AT_call_file
|
;CHECK-NEXT: DW_AT_call_file
|
||||||
;CHECK-NEXT: DW_AT_call_line
|
;CHECK-NEXT: DW_AT_call_line
|
||||||
;CHECK-NEXT: DW_TAG_formal_parameter
|
;CHECK-NEXT: DW_TAG_formal_parameter
|
||||||
;CHECK-NEXT: .ascii "sp" ## DW_AT_name
|
;CHECK-NEXT: Lstring11-Lsection_str ## DW_AT_name
|
||||||
|
|
||||||
%struct.S1 = type { float*, i32 }
|
%struct.S1 = type { float*, i32 }
|
||||||
|
|
||||||
|
|
|
@ -4,8 +4,7 @@ target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f3
|
||||||
target triple = "x86_64-apple-darwin10.0.0"
|
target triple = "x86_64-apple-darwin10.0.0"
|
||||||
;Radar 8950491
|
;Radar 8950491
|
||||||
|
|
||||||
;CHECK: .ascii "var" ## DW_AT_name
|
;CHECK: .long Lset5
|
||||||
;CHECK-NEXT: .byte 0
|
|
||||||
;CHECK-NEXT: ## DW_AT_decl_file
|
;CHECK-NEXT: ## DW_AT_decl_file
|
||||||
;CHECK-NEXT: ## DW_AT_decl_line
|
;CHECK-NEXT: ## DW_AT_decl_line
|
||||||
;CHECK-NEXT: ## DW_AT_type
|
;CHECK-NEXT: ## DW_AT_type
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
; RUN: llc -asm-verbose %s -o - | FileCheck %s
|
; RUN: llc -mtriple=x86_64-pc-linux-gnu -asm-verbose %s -o - | FileCheck %s
|
||||||
|
|
||||||
; ModuleID = 'test.c'
|
; ModuleID = 'test.c'
|
||||||
|
|
||||||
|
@ -38,10 +38,10 @@ declare void @llvm.dbg.declare(metadata, metadata) nounwind readnone
|
||||||
!18 = metadata !{i32 4, i32 23, metadata !16, null}
|
!18 = metadata !{i32 4, i32 23, metadata !16, null}
|
||||||
!19 = metadata !{i32 5, i32 5, metadata !16, null}
|
!19 = metadata !{i32 5, i32 5, metadata !16, null}
|
||||||
|
|
||||||
; CHECK: .ascii "GLB"
|
; CHECK: .long .Lstring3
|
||||||
; CHECK: .byte 1
|
; CHECK: .byte 1
|
||||||
; CHECK: .byte 1
|
; CHECK: .byte 1
|
||||||
|
|
||||||
; CHECK: .ascii "LOC"
|
; CHECK: .long .Lstring6
|
||||||
; CHECK: .byte 1
|
; CHECK: .byte 1
|
||||||
; CHECK: .byte 4
|
; CHECK: .byte 4
|
||||||
|
|
|
@ -1,54 +1,44 @@
|
||||||
; RUN: llc -O0 -mtriple=x86_64-unknown-linux-gnu < %s | FileCheck %s --check-prefix=LINUX
|
; RUN: llc -mtriple=x86_64-unknown-linux-gnu < %s | FileCheck %s --check-prefix=LINUX
|
||||||
; RUN: llc -O0 -mtriple=x86_64-darwin < %s | FileCheck %s --check-prefix=DARWIN
|
; RUN: llc -mtriple=x86_64-darwin < %s | FileCheck %s --check-prefix=DARWIN
|
||||||
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
|
|
||||||
target triple = "x86_64-unknown-linux-gnu"
|
|
||||||
|
|
||||||
@x = common global i32 0, align 4
|
@yyyy = common global i32 0, align 4
|
||||||
@yyyyyyyy = common global i32 0, align 4
|
|
||||||
|
|
||||||
!llvm.dbg.cu = !{!0}
|
!llvm.dbg.cu = !{!0}
|
||||||
|
|
||||||
!0 = metadata !{i32 720913, i32 0, i32 12, metadata !"hello.c", metadata !"/home/nlewycky", metadata !"clang version 3.1 (trunk 143048)", i1 true, i1 true, metadata !"", i32 0, metadata !1, metadata !1, metadata !1, metadata !3} ; [ DW_TAG_compile_unit ]
|
!0 = metadata !{i32 720913, i32 0, i32 12, metadata !"z.c", metadata !"/home/nicholas", metadata !"clang version 3.1 (trunk 143009)", i1 true, i1 true, metadata !"", i32 0, metadata !1, metadata !1, metadata !1, metadata !3} ; [ DW_TAG_compile_unit ]
|
||||||
!1 = metadata !{metadata !2}
|
!1 = metadata !{metadata !2}
|
||||||
!2 = metadata !{i32 0}
|
!2 = metadata !{i32 0}
|
||||||
!3 = metadata !{metadata !4}
|
!3 = metadata !{metadata !4}
|
||||||
!4 = metadata !{metadata !5, metadata !8}
|
!4 = metadata !{metadata !5}
|
||||||
!5 = metadata !{i32 720948, i32 0, null, metadata !"x", metadata !"x", metadata !"", metadata !6, i32 1, metadata !7, i32 0, i32 1, i32* @x} ; [ DW_TAG_variable ]
|
!5 = metadata !{i32 720948, i32 0, null, metadata !"yyyy", metadata !"yyyy", metadata !"", metadata !6, i32 1, metadata !7, i32 0, i32 1, i32* @yyyy} ; [ DW_TAG_variable ]
|
||||||
!6 = metadata !{i32 720937, metadata !"hello.c", metadata !"/home/nlewycky", null} ; [ DW_TAG_file_type ]
|
!6 = metadata !{i32 720937, metadata !"z.c", metadata !"/home/nicholas", null} ; [ DW_TAG_file_type ]
|
||||||
!7 = metadata !{i32 720932, null, metadata !"int", null, i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ]
|
!7 = metadata !{i32 720932, null, metadata !"int", null, i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ]
|
||||||
!8 = metadata !{i32 720948, i32 0, null, metadata !"yyyyyyyy", metadata !"yyyyyyyy", metadata !"", metadata !6, i32 2, metadata !7, i32 0, i32 1, i32* @yyyyyyyy} ; [ DW_TAG_variable ]
|
|
||||||
|
|
||||||
; 120 is ASCII 'x'. Verify that we use it directly as its name and don't emit
|
; Verify that we refer to 'yyyy' with a relocation.
|
||||||
; a reference to the string pool.
|
; LINUX: .long .Lstring3 # DW_AT_name
|
||||||
; LINUX: .byte 120 # DW_AT_name
|
|
||||||
; DARWIN: .byte 120 ## DW_AT_name
|
|
||||||
|
|
||||||
; Verify that we refer to 'yyyyyyyy' with a relocation.
|
|
||||||
; LINUX: .long .Lstring{{[0-9]+}} # DW_AT_name
|
|
||||||
; LINUX-NEXT: .long 39 # DW_AT_type
|
; LINUX-NEXT: .long 39 # DW_AT_type
|
||||||
; LINUX-NEXT: .byte 1 # DW_AT_external
|
; LINUX-NEXT: .byte 1 # DW_AT_external
|
||||||
; LINUX-NEXT: .byte 1 # DW_AT_decl_file
|
; LINUX-NEXT: .byte 1 # DW_AT_decl_file
|
||||||
; LINUX-NEXT: .byte 2 # DW_AT_decl_line
|
; LINUX-NEXT: .byte 1 # DW_AT_decl_line
|
||||||
; LINUX-NEXT: .byte 9 # DW_AT_location
|
; LINUX-NEXT: .byte 9 # DW_AT_location
|
||||||
; LINUX-NEXT: .byte 3
|
; LINUX-NEXT: .byte 3
|
||||||
; LINUX-NEXT: .quad yyyyyyyy
|
; LINUX-NEXT: .quad yyyy
|
||||||
|
|
||||||
; Verify that we refer to 'yyyyyyyy' without a relocation.
|
; Verify that we refer to 'yyyy' without a relocation.
|
||||||
; DARWIN: Lset[[N:[0-9]+]] = Lstring{{[0-9]+}}-Lsection_str ## DW_AT_name
|
; DARWIN: Lset5 = Lstring3-Lsection_str ## DW_AT_name
|
||||||
; DARWIN-NEXT: .long Lset[[N]]
|
; DARWIN-NEXT: .long Lset5
|
||||||
; DARWIN-NEXT: .long 39 ## DW_AT_type
|
; DARWIN-NEXT: .long 39 ## DW_AT_type
|
||||||
; DARWIN-NEXT: .byte 1 ## DW_AT_external
|
; DARWIN-NEXT: .byte 1 ## DW_AT_external
|
||||||
; DARWIN-NEXT: .byte 1 ## DW_AT_decl_file
|
; DARWIN-NEXT: .byte 1 ## DW_AT_decl_file
|
||||||
; DARWIN-NEXT: .byte 2 ## DW_AT_decl_line
|
; DARWIN-NEXT: .byte 1 ## DW_AT_decl_line
|
||||||
; DARWIN-NEXT: .byte 9 ## DW_AT_location
|
; DARWIN-NEXT: .byte 9 ## DW_AT_location
|
||||||
; DARWIN-NEXT: .byte 3
|
; DARWIN-NEXT: .byte 3
|
||||||
; DARWIN-NEXT: .quad _yyyyyyyy
|
; DARWIN-NEXT: .quad _yyyy
|
||||||
|
|
||||||
|
; Verify that "yyyy" ended up in the stringpool.
|
||||||
; Verify that "yyyyyyyy" ended up in the stringpool.
|
|
||||||
; LINUX: .section .debug_str,"MS",@progbits,1
|
; LINUX: .section .debug_str,"MS",@progbits,1
|
||||||
; LINUX-NOT: .section
|
; LINUX-NOT: .section
|
||||||
; LINUX: yyyyyyyy
|
; LINUX: yyyy
|
||||||
; DARWIN: .section __DWARF,__debug_str,regular,debug
|
; DARWIN: .section __DWARF,__debug_str,regular,debug
|
||||||
; DARWIN-NOT: .section
|
; DARWIN-NOT: .section
|
||||||
; DARWIN: yyyyyyyy
|
; DARWIN: yyyy
|
||||||
|
|
Loading…
Reference in New Issue