[llvm] r207777 - PR19623: Implement typedefs of void.

David Blaikie dblaikie at gmail.com
Thu May 1 11:38:48 PDT 2014


On Thu, May 1, 2014 at 11:24 AM, Robinson, Paul
<Paul_Robinson at playstation.sony.com> wrote:
>> -----Original Message-----
>> From: llvm-commits-bounces at cs.uiuc.edu [mailto:llvm-commits-
>> bounces at cs.uiuc.edu] On Behalf Of David Blaikie
>>
>> Author: dblaikie
>> Date: Thu May  1 12:56:13 2014
>> New Revision: 207777
>>
>> URL: http://llvm.org/viewvc/llvm-project?rev=207777&view=rev
>> Log:
>> PR19623: Implement typedefs of void.
>>
>> This the LLVM portion that will allow Clang and other frontends to emit
>> typedefs of void by providing a null type for the typedef's underlying
>> type.
>>
>> Added:
>>     llvm/trunk/test/DebugInfo/typedef.ll
>> Modified:
>>     llvm/trunk/lib/IR/DIBuilder.cpp
>>
>> Modified: llvm/trunk/lib/IR/DIBuilder.cpp
>> URL: http://llvm.org/viewvc/llvm-
>> project/llvm/trunk/lib/IR/DIBuilder.cpp?rev=207777&r1=207776&r2=207777&v
>> iew=diff
>> ========================================================================
>> ======
>> --- llvm/trunk/lib/IR/DIBuilder.cpp (original)
>> +++ llvm/trunk/lib/IR/DIBuilder.cpp Thu May  1 12:56:13 2014
>> @@ -355,7 +355,6 @@ DIDerivedType DIBuilder::createReference
>>  DIDerivedType DIBuilder::createTypedef(DIType Ty, StringRef Name,
>> DIFile File,
>>                                         unsigned LineNo, DIDescriptor
>> Context) {
>>    // typedefs are encoded in DIDerivedType format.
>> -  assert(Ty.isType() && "Invalid typedef type!");
>>    Value *Elts[] = {
>>      GetTagConstant(VMContext, dwarf::DW_TAG_typedef),
>>      File.getFileNode(),
>>
>> Added: llvm/trunk/test/DebugInfo/typedef.ll
>> URL: http://llvm.org/viewvc/llvm-
>> project/llvm/trunk/test/DebugInfo/typedef.ll?rev=207777&view=auto
>> ========================================================================
>> ======
>> --- llvm/trunk/test/DebugInfo/typedef.ll (added)
>> +++ llvm/trunk/test/DebugInfo/typedef.ll Thu May  1 12:56:13 2014
>> @@ -0,0 +1,32 @@
>> +; REQUIRES: object-emission
>> +
>> +; RUN: %llc_dwarf -O0 -filetype=obj < %s | llvm-dwarfdump -debug-
>> dump=info - | FileCheck %s
>> +
>> +; From source:
>> +; typedef void x;
>> +; x *y;
>> +
>> +; Check that a typedef with no DW_TAG_type is produced. The absence of
>> a type is used to imply the 'void' type.
>> +
>> +; CHECK: DW_TAG_typedef
>> +; CHECK-NOT: DW_TAG_type
>
> Should be DW_AT_type here?

Indeed. r207782.

Thanks!

- David

>
>> +; CHECK: {{DW_TAG|NULL}}
>> +
>> + at y = global i8* null, align 8
>> +
>> +!llvm.dbg.cu = !{!0}
>> +!llvm.module.flags = !{!8, !9}
>> +!llvm.ident = !{!10}
>> +
>> +!0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang
>> version 3.5.0 ", i1 false, metadata !"", i32 0, metadata !2, metadata
>> !2, metadata !2, metadata !3, metadata !2, metadata !"", i32 1} ; [
>> DW_TAG_compile_unit ] [/tmp/dbginfo/typedef.cpp] [DW_LANG_C_plus_plus]
>> +!1 = metadata !{metadata !"typedef.cpp", metadata !"/tmp/dbginfo"}
>> +!2 = metadata !{}
>> +!3 = metadata !{metadata !4}
>> +!4 = metadata !{i32 786484, i32 0, null, metadata !"y", metadata !"y",
>> metadata !"", metadata !5, i32 2, metadata !6, i32 0, i32 1, i8** @y,
>> null} ; [ DW_TAG_variable ] [y] [line 2] [def]
>> +!5 = metadata !{i32 786473, metadata !1}          ; [ DW_TAG_file_type
>> ] [/tmp/dbginfo/typedef.cpp]
>> +!6 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64,
>> i64 64, i64 0, i32 0, metadata !7} ; [ DW_TAG_pointer_type ] [line 0,
>> size 64, align 64, offset 0] [from x]
>> +!7 = metadata !{i32 786454, metadata !1, null, metadata !"x", i32 1,
>> i64 0, i64 0, i64 0, i32 0, null} ; [ DW_TAG_typedef ] [x] [line 1, size
>> 0, align 0, offset 0] [from ]
>> +!8 = metadata !{i32 2, metadata !"Dwarf Version", i32 4}
>> +!9 = metadata !{i32 1, metadata !"Debug Info Version", i32 1}
>> +!10 = metadata !{metadata !"clang version 3.5.0 "}
>> +
>>
>>
>> _______________________________________________
>> llvm-commits mailing list
>> llvm-commits at cs.uiuc.edu
>> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
>
>



More information about the llvm-commits mailing list