diff options
author | Bill Wendling <isanbard@gmail.com> | 2012-11-13 02:31:47 +0000 |
---|---|---|
committer | Bill Wendling <isanbard@gmail.com> | 2012-11-13 02:31:47 +0000 |
commit | e7ff4c14b157746b3e0228d2dce9f70712d1c126 (patch) | |
tree | cb2924f6d68ba921a83cd91cde117e605f232cab /lib/VMCore | |
parent | f546ac5f9bdedc7d1ae49238c65a93201d0e4f05 (diff) | |
download | external_llvm-e7ff4c14b157746b3e0228d2dce9f70712d1c126.zip external_llvm-e7ff4c14b157746b3e0228d2dce9f70712d1c126.tar.gz external_llvm-e7ff4c14b157746b3e0228d2dce9f70712d1c126.tar.bz2 |
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>
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@167806 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/VMCore')
-rw-r--r-- | lib/VMCore/DIBuilder.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/lib/VMCore/DIBuilder.cpp b/lib/VMCore/DIBuilder.cpp index 152b825..ed9c3b0 100644 --- a/lib/VMCore/DIBuilder.cpp +++ b/lib/VMCore/DIBuilder.cpp @@ -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)); |