<p dir="ltr"><br>
On Jul 27, 2013 7:18 AM, "Benjamin Kramer" <<a href="mailto:benny.kra@googlemail.com">benny.kra@googlemail.com</a>> wrote:<br>
><br>
> Author: d0k<br>
> Date: Sat Jul 27 09:14:43 2013<br>
> New Revision: 187304<br>
><br>
> URL: <a href="http://llvm.org/viewvc/llvm-project?rev=187304&view=rev">http://llvm.org/viewvc/llvm-project?rev=187304&view=rev</a><br>
> Log:<br>
> DwarfDebug: MD5 is always little endian, bswap on big endian platforms.<br>
><br>
> This makes LLVM emit the same signature regardless of host and target endianess.<br>
><br>
> Added:<br>
>     llvm/trunk/test/DebugInfo/generate-odr-hash.ll<br>
>       - copied, changed from r187303, llvm/trunk/test/DebugInfo/X86/generate-odr-hash.ll<br>
> Removed:<br>
>     llvm/trunk/test/DebugInfo/X86/generate-odr-hash.ll<br>
> Modified:<br>
>     llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp<br>
><br>
> Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp?rev=187304&r1=187303&r2=187304&view=diff">http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp?rev=187304&r1=187303&r2=187304&view=diff</a><br>

> ==============================================================================<br>
> --- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp (original)<br>
> +++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp Sat Jul 27 09:14:43 2013<br>
> @@ -1059,8 +1059,9 @@ static void addDIEODRSignature(MD5 &Hash<br>
>    Hash.final(Result);<br>
><br>
>    // ... take the least significant 8 bytes and store those as the attribute.<br>
> -  uint64_t Signature;<br>
> -  memcpy(&Signature, &Result[8], 8);<br>
> +  // Our MD5 implementation always returns its results in little endian, swap<br>
> +  // bytes appropriately.<br>
> +  uint64_t Signature = *reinterpret_cast<support::ulittle64_t *>(Result + 8);</p>
<p dir="ltr">This is technically type punning UB right? Are we just punting on that in llvm in general (I know we have type punning violations already)?</p>
<p dir="ltr">Personally I wouldn't mind a shift based reading or a memcpy+byteswapping (which is just some shifting around anyway)</p>
<p dir="ltr">Thanks for spotting/finding/fixing this, though</p>
<p dir="ltr">><br>
>    // FIXME: This should be added onto the type unit, not the type, but this<br>
>    // works as an intermediate stage.<br>
><br>
> Removed: llvm/trunk/test/DebugInfo/X86/generate-odr-hash.ll<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/X86/generate-odr-hash.ll?rev=187303&view=auto">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/X86/generate-odr-hash.ll?rev=187303&view=auto</a><br>

> ==============================================================================<br>
> --- llvm/trunk/test/DebugInfo/X86/generate-odr-hash.ll (original)<br>
> +++ llvm/trunk/test/DebugInfo/X86/generate-odr-hash.ll (removed)<br>
> @@ -1,116 +0,0 @@<br>
> -; REQUIRES: object-emission<br>
> -<br>
> -; RUN: llc %s -o %t -filetype=obj -O0 -generate-odr-hash<br>
> -; RUN: llvm-dwarfdump -debug-dump=info %t | FileCheck %s<br>
> -;<br>
> -; Generated from:<br>
> -;<br>
> -; struct bar {};<br>
> -; struct bar b;<br>
> -; void foo(void) {<br>
> -;   struct baz {};<br>
> -;   baz b;<br>
> -; }<br>
> -; namespace echidna {<br>
> -; namespace capybara {<br>
> -; namespace mongoose {<br>
> -; class fluffy {<br>
> -;   int a;<br>
> -;   int b;<br>
> -; };<br>
> -; fluffy animal;<br>
> -; }<br>
> -; }<br>
> -; }<br>
> -; namespace {<br>
> -; struct walrus {};<br>
> -; }<br>
> -; walrus w;<br>
> -<br>
> -; Check that we generate a hash for bar, that it is a particular value and<br>
> -; that we don't generate a hash for baz or walrus.<br>
> -; CHECK: DW_TAG_structure_type<br>
> -; CHECK-NEXT: debug_str{{.*}}"bar"<br>
> -; CHECK: DW_AT_GNU_odr_signature [DW_FORM_data8] (0x200520c0d5b90eff)<br>
> -; CHECK: DW_TAG_namespace<br>
> -; CHECK-NEXT: debug_str{{.*}}"echidna"<br>
> -; CHECK: DW_TAG_namespace<br>
> -; CHECK-NEXT: debug_str{{.*}}"capybara"<br>
> -; CHECK: DW_TAG_namespace<br>
> -; CHECK-NEXT: debug_str{{.*}}"mongoose"<br>
> -; CHECK: DW_TAG_class_type<br>
> -; CHECK-NEXT: debug_str{{.*}}"fluffy"<br>
> -; CHECK: DW_AT_GNU_odr_signature [DW_FORM_data8]   (0x9a0124d5a0c21c52)<br>
> -; CHECK: DW_TAG_structure_type<br>
> -; CHECK-NEXT: debug_str{{.*}}"baz"<br>
> -; CHECK-NOT: DW_AT_GNU_odr_signature<br>
> -; FIXME: we may want to generate debug info for walrus, but still no hash.<br>
> -; CHECK-NOT: debug_str{{.*}}"walrus"<br>
> -<br>
> -<br>
> -%struct.bar = type { i8 }<br>
> -%"class.echidna::capybara::mongoose::fluffy" = type { i32, i32 }<br>
> -%struct.baz = type { i8 }<br>
> -<br>
> -@b = global %struct.bar zeroinitializer, align 1<br>
> -@_ZN7echidna8capybara8mongoose6animalE = global %"class.echidna::capybara::mongoose::fluffy" zeroinitializer, align 4<br>
> -<br>
> -; Function Attrs: nounwind uwtable<br>
> -define void @_Z3foov() #0 {<br>
> -entry:<br>
> -  %b = alloca %struct.baz, align 1<br>
> -  call void @llvm.dbg.declare(metadata !{%struct.baz* %b}, metadata !32), !dbg !40<br>
> -  ret void, !dbg !41<br>
> -}<br>
> -<br>
> -; Function Attrs: nounwind readnone<br>
> -declare void @llvm.dbg.declare(metadata, metadata) #1<br>
> -<br>
> -attributes #0 = { nounwind uwtable "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf"="true" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }<br>

> -attributes #1 = { nounwind readnone }<br>
> -<br>
> -!<a href="http://llvm.dbg.cu">llvm.dbg.cu</a> = !{!0}<br>
> -!llvm.module.flags = !{!31}<br>
> -<br>
> -!0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.4 (trunk 187152) (llvm/trunk 187150)", i1 false, metadata !"", i32 0, metadata !2, metadata !2, metadata !3, metadata !8, metadata !2, metadata !""} ; [ DW_TAG_compile_unit ] [/usr/local/google/home/echristo/tmp/bar.cpp] [DW_LANG_C_plus_plus]<br>

> -!1 = metadata !{metadata !"bar.cpp", metadata !"/usr/local/google/home/echristo/tmp"}<br>
> -!2 = metadata !{i32 0}<br>
> -!3 = metadata !{metadata !4}<br>
> -!4 = metadata !{i32 786478, metadata !1, metadata !5, metadata !"foo", metadata !"foo", metadata !"_Z3foov", i32 6, metadata !6, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, void ()* @_Z3foov, null, null, metadata !2, i32 6} ; [ DW_TAG_subprogram ] [line 6] [def] [foo]<br>

> -!5 = metadata !{i32 786473, metadata !1}          ; [ DW_TAG_file_type ] [/usr/local/google/home/echristo/tmp/bar.cpp]<br>
> -!6 = metadata !{i32 786453, i32 0, i32 0, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !7, i32 0, i32 0} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]<br>
> -!7 = metadata !{null}<br>
> -!8 = metadata !{metadata !9, metadata !17}<br>
> -!9 = metadata !{i32 786484, i32 0, null, metadata !"b", metadata !"b", metadata !"", metadata !5, i32 4, metadata !10, i32 0, i32 1, %struct.bar* @b, null} ; [ DW_TAG_variable ] [b] [line 4] [def]<br>

> -!10 = metadata !{i32 786451, metadata !1, null, metadata !"bar", i32 1, i64 8, i64 8, i32 0, i32 0, null, metadata !11, i32 0, null, null} ; [ DW_TAG_structure_type ] [bar] [line 1, size 8, align 8, offset 0] [def] [from ]<br>

> -!11 = metadata !{metadata !12}<br>
> -!12 = metadata !{i32 786478, metadata !1, metadata !10, metadata !"bar", metadata !"bar", metadata !"", i32 1, metadata !13, i1 false, i1 false, i32 0, i32 0, null, i32 320, i1 false, null, null, i32 0, metadata !16, i32 1} ; [ DW_TAG_subprogram ] [line 1] [bar]<br>

> -!13 = metadata !{i32 786453, i32 0, i32 0, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !14, i32 0, i32 0} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]<br>
> -!14 = metadata !{null, metadata !15}<br>
> -!15 = metadata !{i32 786447, i32 0, i32 0, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 1088, metadata !10} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [artificial] [from bar]<br>
> -!16 = metadata !{i32 786468}<br>
> -!17 = metadata !{i32 786484, i32 0, metadata !18, metadata !"animal", metadata !"animal", metadata !"_ZN7echidna8capybara8mongoose6animalE", metadata !5, i32 20, metadata !21, i32 0, i32 1, %"class.echidna::capybara::mongoose::fluffy"* @_ZN7echidna8capybara8mongoose6animalE, null} ; [ DW_TAG_variable ] [animal] [line 20] [def]<br>

> -!18 = metadata !{i32 786489, metadata !1, metadata !19, metadata !"mongoose", i32 14} ; [ DW_TAG_namespace ] [mongoose] [line 14]<br>
> -!19 = metadata !{i32 786489, metadata !1, metadata !20, metadata !"capybara", i32 13} ; [ DW_TAG_namespace ] [capybara] [line 13]<br>
> -!20 = metadata !{i32 786489, metadata !1, null, metadata !"echidna", i32 12} ; [ DW_TAG_namespace ] [echidna] [line 12]<br>
> -!21 = metadata !{i32 786434, metadata !1, metadata !18, metadata !"fluffy", i32 15, i64 64, i64 32, i32 0, i32 0, null, metadata !22, i32 0, null, null} ; [ DW_TAG_class_type ] [fluffy] [line 15, size 64, align 32, offset 0] [def] [from ]<br>

> -!22 = metadata !{metadata !23, metadata !25, metadata !26}<br>
> -!23 = metadata !{i32 786445, metadata !1, metadata !21, metadata !"a", i32 16, i64 32, i64 32, i64 0, i32 1, metadata !24} ; [ DW_TAG_member ] [a] [line 16, size 32, align 32, offset 0] [private] [from int]<br>

> -!24 = metadata !{i32 786468, null, null, metadata !"int", i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ] [int] [line 0, size 32, align 32, offset 0, enc DW_ATE_signed]<br>
> -!25 = metadata !{i32 786445, metadata !1, metadata !21, metadata !"b", i32 17, i64 32, i64 32, i64 32, i32 1, metadata !24} ; [ DW_TAG_member ] [b] [line 17, size 32, align 32, offset 32] [private] [from int]<br>

> -!26 = metadata !{i32 786478, metadata !1, metadata !21, metadata !"fluffy", metadata !"fluffy", metadata !"", i32 15, metadata !27, i1 false, i1 false, i32 0, i32 0, null, i32 320, i1 false, null, null, i32 0, metadata !30, i32 15} ; [ DW_TAG_subprogram ] [line 15] [fluffy]<br>

> -!27 = metadata !{i32 786453, i32 0, i32 0, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !28, i32 0, i32 0} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]<br>
> -!28 = metadata !{null, metadata !29}<br>
> -!29 = metadata !{i32 786447, i32 0, i32 0, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 1088, metadata !21} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [artificial] [from fluffy]<br>

> -!30 = metadata !{i32 786468}<br>
> -!31 = metadata !{i32 2, metadata !"Dwarf Version", i32 3}<br>
> -!32 = metadata !{i32 786688, metadata !4, metadata !"b", metadata !5, i32 9, metadata !33, i32 0, i32 0} ; [ DW_TAG_auto_variable ] [b] [line 9]<br>
> -!33 = metadata !{i32 786451, metadata !1, metadata !4, metadata !"baz", i32 7, i64 8, i64 8, i32 0, i32 0, null, metadata !34, i32 0, null, null} ; [ DW_TAG_structure_type ] [baz] [line 7, size 8, align 8, offset 0] [def] [from ]<br>

> -!34 = metadata !{metadata !35}<br>
> -!35 = metadata !{i32 786478, metadata !1, metadata !33, metadata !"baz", metadata !"baz", metadata !"", i32 7, metadata !36, i1 false, i1 false, i32 0, i32 0, null, i32 320, i1 false, null, null, i32 0, metadata !39, i32 7} ; [ DW_TAG_subprogram ] [line 7] [baz]<br>

> -!36 = metadata !{i32 786453, i32 0, i32 0, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !37, i32 0, i32 0} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]<br>
> -!37 = metadata !{null, metadata !38}<br>
> -!38 = metadata !{i32 786447, i32 0, i32 0, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 1088, metadata !33} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [artificial] [from baz]<br>
> -!39 = metadata !{i32 786468}<br>
> -!40 = metadata !{i32 9, i32 0, metadata !4, null}<br>
> -!41 = metadata !{i32 10, i32 0, metadata !4, null}<br>
><br>
> Copied: llvm/trunk/test/DebugInfo/generate-odr-hash.ll (from r187303, llvm/trunk/test/DebugInfo/X86/generate-odr-hash.ll)<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/generate-odr-hash.ll?p2=llvm/trunk/test/DebugInfo/generate-odr-hash.ll&p1=llvm/trunk/test/DebugInfo/X86/generate-odr-hash.ll&r1=187303&r2=187304&rev=187304&view=diff">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/generate-odr-hash.ll?p2=llvm/trunk/test/DebugInfo/generate-odr-hash.ll&p1=llvm/trunk/test/DebugInfo/X86/generate-odr-hash.ll&r1=187303&r2=187304&rev=187304&view=diff</a><br>

> ==============================================================================<br>
>     (empty)<br>
><br>
><br>
> _______________________________________________<br>
> llvm-commits mailing list<br>
> <a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br>
> <a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br>
</p>