mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 03:02:36 +01:00
Use the 'count' attribute instead of the 'upper_bound' attribute.
If we have a type 'int a[1]' and a type 'int b[0]', the generated DWARF is the same for both of them because we use the 'upper_bound' attribute. Instead use the 'count' attrbute, which gives the correct number of elements in the array. <rdar://problem/12566646> llvm-svn: 167806
This commit is contained in:
parent
d8c621a864
commit
ab44d906b6
@ -371,7 +371,7 @@ namespace llvm {
|
||||
|
||||
/// getOrCreateSubrange - Create a descriptor for a value range. This
|
||||
/// implicitly uniques the values returned.
|
||||
DISubrange getOrCreateSubrange(int64_t Lo, int64_t Hi);
|
||||
DISubrange getOrCreateSubrange(int64_t Lo, int64_t Hi, uint64_t Count);
|
||||
|
||||
/// createGlobalVariable - Create a new descriptor for the specified global.
|
||||
/// @param Name Name of the variable.
|
||||
|
@ -143,6 +143,7 @@ namespace llvm {
|
||||
|
||||
uint64_t getLo() const { return getUInt64Field(1); }
|
||||
uint64_t getHi() const { return getUInt64Field(2); }
|
||||
uint64_t getCount() const { return getUInt64Field(3); }
|
||||
};
|
||||
|
||||
/// DIArray - This descriptor holds an array of descriptors.
|
||||
|
@ -1252,6 +1252,7 @@ void CompileUnit::constructSubrangeDIE(DIE &Buffer, DISubrange SR,
|
||||
addDIEEntry(DW_Subrange, dwarf::DW_AT_type, dwarf::DW_FORM_ref4, IndexTy);
|
||||
uint64_t L = SR.getLo();
|
||||
uint64_t H = SR.getHi();
|
||||
uint64_t C = SR.getCount();
|
||||
|
||||
// The L value defines the lower bounds which is typically zero for C/C++. The
|
||||
// H value is the upper bounds. Values are 64 bit. H - L + 1 is the size
|
||||
@ -1265,7 +1266,7 @@ void CompileUnit::constructSubrangeDIE(DIE &Buffer, DISubrange SR,
|
||||
}
|
||||
if (L)
|
||||
addUInt(DW_Subrange, dwarf::DW_AT_lower_bound, 0, L);
|
||||
addUInt(DW_Subrange, dwarf::DW_AT_upper_bound, 0, H);
|
||||
addUInt(DW_Subrange, dwarf::DW_AT_count, 0, C);
|
||||
Buffer.addChild(DW_Subrange);
|
||||
}
|
||||
|
||||
|
@ -741,11 +741,13 @@ DIArray DIBuilder::getOrCreateArray(ArrayRef<Value *> Elements) {
|
||||
|
||||
/// getOrCreateSubrange - Create a descriptor for a value range. This
|
||||
/// implicitly uniques the values returned.
|
||||
DISubrange DIBuilder::getOrCreateSubrange(int64_t Lo, int64_t Hi) {
|
||||
DISubrange DIBuilder::getOrCreateSubrange(int64_t Lo, int64_t Hi,
|
||||
uint64_t Count) {
|
||||
Value *Elts[] = {
|
||||
GetTagConstant(VMContext, dwarf::DW_TAG_subrange_type),
|
||||
ConstantInt::get(Type::getInt64Ty(VMContext), Lo),
|
||||
ConstantInt::get(Type::getInt64Ty(VMContext), Hi)
|
||||
ConstantInt::get(Type::getInt64Ty(VMContext), Hi),
|
||||
ConstantInt::get(Type::getInt64Ty(VMContext), Count)
|
||||
};
|
||||
|
||||
return DISubrange(MDNode::get(VMContext, Elts));
|
||||
|
@ -4,7 +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-macosx10.7.2"
|
||||
|
||||
@s = common global [4294967296 x i8] zeroinitializer, align 16
|
||||
;CHECK: .long 4294967295
|
||||
;CHECK: .quad 4294967296 ## DW_AT_count
|
||||
|
||||
define void @bar() nounwind uwtable ssp {
|
||||
entry:
|
||||
@ -31,7 +31,7 @@ entry:
|
||||
!14 = metadata !{i32 720897, null, metadata !"", null, i32 0, i64 34359738368, i64 8, i32 0, i32 0, metadata !15, metadata !16, i32 0, i32 0} ; [ DW_TAG_array_type ]
|
||||
!15 = metadata !{i32 720932, null, metadata !"char", null, i32 0, i64 8, i64 8, i64 0, i32 0, i32 6} ; [ DW_TAG_base_type ]
|
||||
!16 = metadata !{metadata !17}
|
||||
!17 = metadata !{i32 720929, i64 0, i64 4294967295} ; [ DW_TAG_subrange_type ]
|
||||
!17 = metadata !{i32 720929, i64 0, i64 4294967295, i64 4294967296} ; [ DW_TAG_subrange_type ]
|
||||
!18 = metadata !{i32 5, i32 3, metadata !19, null}
|
||||
!19 = metadata !{i32 720907, metadata !5, i32 4, i32 1, metadata !6, i32 0} ; [ DW_TAG_lexical_block ]
|
||||
!20 = metadata !{i32 6, i32 1, metadata !19, null}
|
||||
|
Loading…
Reference in New Issue
Block a user