From: David Majnemer Date: Sun, 25 Aug 2013 22:13:27 +0000 (+0000) Subject: DebugInfo: Emit info for casted decls in template args X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=5db8b3138f36e11bca835881e81cc56bbd7b4fa4;p=clang DebugInfo: Emit info for casted decls in template args Summary: Previously the backend wouldn't get to see the underlying GlobalValue that corresponds to the template argument because it would be hidden by a cast at the IR level. Instead strip the pointer casts off of the value until we see the underlying GlobalValue. Reviewers: dblaikie, echristo, majnemer Reviewed By: majnemer CC: cfe-commits Differential Revision: http://llvm-reviews.chandlerc.com/D1508 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@189200 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGDebugInfo.cpp b/lib/CodeGen/CGDebugInfo.cpp index c22ca886ef..c40dad1ac3 100644 --- a/lib/CodeGen/CGDebugInfo.cpp +++ b/lib/CodeGen/CGDebugInfo.cpp @@ -1258,7 +1258,8 @@ CollectTemplateParams(const TemplateParameterList *TPList, cast(T.getTypePtr()), chars); } llvm::DITemplateValueParameter TVP = - DBuilder.createTemplateValueParameter(TheCU, Name, TTy, V); + DBuilder.createTemplateValueParameter(TheCU, Name, TTy, + V->stripPointerCasts()); TemplateParams.push_back(TVP); } break; case TemplateArgument::NullPtr: { diff --git a/test/CodeGenCXX/debug-info-template.cpp b/test/CodeGenCXX/debug-info-template.cpp index 80891ab68b..ceb80cf2ee 100644 --- a/test/CodeGenCXX/debug-info-template.cpp +++ b/test/CodeGenCXX/debug-info-template.cpp @@ -74,7 +74,12 @@ // CHECK: [[TGIARG1]] = {{.*}}metadata !"", metadata [[CONST_GUID_PTR:![0-9]*]], { i32, i16, i16, [8 x i8] }* @_GUID_12345678_1234_1234_1234_1234567890ab, {{.*}} ; [ DW_TAG_template_value_parameter ] // CHECK: [[CONST_GUID_PTR]] = {{.*}}, metadata [[CONST_GUID:![0-9]*]]} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [from ] // CHECK: [[CONST_GUID]] = {{.*}}, metadata [[GUID:![0-9]*]]} ; [ DW_TAG_const_type ] [line 0, size 0, align 0, offset 0] [from _GUID] -// CHECK: [[GUID]] = {{.*}} ; [ DW_TAG_structure_type ] [_GUID] [line 100, size 0, align 0, offset 0] [decl] +// CHECK: [[GUID]] = {{.*}} ; [ DW_TAG_structure_type ] [_GUID] + +// CHECK: metadata [[PTOARGS:![0-9]*]]} ; [ DW_TAG_structure_type ] [PaddingAtEndTemplate<&PaddedObj>] +// CHECK: [[PTOARGS]] = metadata !{metadata [[PTOARG1:![0-9]*]]} +// CHECK: [[PTOARG1]] = {{.*}}metadata !"", metadata [[CONST_PADDINGATEND_PTR:![0-9]*]], { i32, i8, [3 x i8] }* @PaddedObj, {{.*}} ; [ DW_TAG_template_value_parameter ] +// CHECK: [[CONST_PADDINGATEND_PTR]] = {{.*}} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [from PaddingAtEnd] struct foo { char pad[8]; // make the member pointer to 'e' a bit more interesting (nonzero) int e; @@ -104,3 +109,16 @@ struct tmpl_guid { struct __declspec(uuid("{12345678-1234-1234-1234-1234567890ab}")) uuid; tmpl_guid<&__uuidof(uuid)> tgi; + +struct PaddingAtEnd { + int i; + char c; +}; + +PaddingAtEnd PaddedObj = {}; + +template +struct PaddingAtEndTemplate { +}; + +PaddingAtEndTemplate<&PaddedObj> PaddedTemplateObj;