[llvm] r245862 - [PPC64LE] Fix PR24546 - Swap optimization and debug values

Hans Wennborg via llvm-commits llvm-commits at lists.llvm.org
Wed Aug 26 16:19:53 PDT 2015


Hi Hal,

While there will be an rc4, I would rather not merge this as it's late
in the process and I want to keep the number of merges to a minimum.
It will be an excellent patch to get for 3.7.1.

Thanks,
Hans

On Mon, Aug 24, 2015 at 4:54 PM, Hans Wennborg <hans at chromium.org> wrote:
> OK, it's on my list.
>
> Thanks,
> Hans
>
> On Mon, Aug 24, 2015 at 12:31 PM, Hal Finkel <hfinkel at anl.gov> wrote:
>> Hi Hans,
>>
>> If there's another RC, please pull this in too.
>>
>> Thanks again,
>> Hal
>>
>> ----- Original Message -----
>>> From: "Bill Schmidt via llvm-commits" <llvm-commits at lists.llvm.org>
>>> To: llvm-commits at lists.llvm.org
>>> Sent: Monday, August 24, 2015 2:27:28 PM
>>> Subject: [llvm] r245862 - [PPC64LE] Fix PR24546 - Swap optimization and debug values
>>>
>>> Author: wschmidt
>>> Date: Mon Aug 24 14:27:27 2015
>>> New Revision: 245862
>>>
>>> URL: http://llvm.org/viewvc/llvm-project?rev=245862&view=rev
>>> Log:
>>> [PPC64LE] Fix PR24546 - Swap optimization and debug values
>>>
>>> This patch fixes PR24546, which demonstrates a segfault during the
>>> VSX
>>> swap removal pass.  The problem is that debug value instructions were
>>> not excluded from the list of instructions to be analyzed for webs of
>>> related computation.  I've added the test case from the PR as a crash
>>> test in test/CodeGen/PowerPC.
>>>
>>> Added:
>>>     llvm/trunk/test/CodeGen/PowerPC/pr24546.ll
>>> Modified:
>>>     llvm/trunk/lib/Target/PowerPC/PPCVSXSwapRemoval.cpp
>>>
>>> Modified: llvm/trunk/lib/Target/PowerPC/PPCVSXSwapRemoval.cpp
>>> URL:
>>> http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/PowerPC/PPCVSXSwapRemoval.cpp?rev=245862&r1=245861&r2=245862&view=diff
>>> ==============================================================================
>>> --- llvm/trunk/lib/Target/PowerPC/PPCVSXSwapRemoval.cpp (original)
>>> +++ llvm/trunk/lib/Target/PowerPC/PPCVSXSwapRemoval.cpp Mon Aug 24
>>> 14:27:27 2015
>>> @@ -245,6 +245,9 @@ bool PPCVSXSwapRemoval::gatherVectorInst
>>>    for (MachineBasicBlock &MBB : *MF) {
>>>      for (MachineInstr &MI : MBB) {
>>>
>>> +      if (MI.isDebugValue())
>>> +        continue;
>>> +
>>>        bool RelevantInstr = false;
>>>        bool Partial = false;
>>>
>>>
>>> Added: llvm/trunk/test/CodeGen/PowerPC/pr24546.ll
>>> URL:
>>> http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/PowerPC/pr24546.ll?rev=245862&view=auto
>>> ==============================================================================
>>> --- llvm/trunk/test/CodeGen/PowerPC/pr24546.ll (added)
>>> +++ llvm/trunk/test/CodeGen/PowerPC/pr24546.ll Mon Aug 24 14:27:27
>>> 2015
>>> @@ -0,0 +1,116 @@
>>> +; RUN: llc -mcpu=pwr8 -mtriple=powerpc64le-unknown-linux-gnu < %s
>>> +
>>> +; Verify that we no longer crash in VSX swap removal when debug
>>> values
>>> +; are in the code stream.
>>> +
>>> + at php_intpow10.powers = external unnamed_addr constant [23 x double],
>>> align 8
>>> +
>>> +; Function Attrs: nounwind
>>> +define double @_php_math_round(double %value, i32 signext %places,
>>> i32 signext %mode) #0 {
>>> +entry:
>>> +  br i1 undef, label %if.then, label %if.else, !dbg !32
>>> +
>>> +if.then:                                          ; preds = %entry
>>> +  %conv = sitofp i32 undef to double, !dbg !34
>>> +  br i1 undef, label %if.then.i, label %if.end.i, !dbg !36
>>> +
>>> +if.then.i:                                        ; preds = %if.then
>>> +  %call.i = tail call double @pow(double 1.000000e+01, double undef)
>>> #3, !dbg !39
>>> +  br label %php_intpow10.exit, !dbg !41
>>> +
>>> +if.end.i:                                         ; preds = %if.then
>>> +  %0 = load double, double* undef, align 8, !dbg !42, !tbaa !43
>>> +  br label %php_intpow10.exit, !dbg !47
>>> +
>>> +php_intpow10.exit:                                ; preds =
>>> %if.end.i, %if.then.i
>>> +  %retval.0.i = phi double [ %call.i, %if.then.i ], [ %0, %if.end.i
>>> ], !dbg !48
>>> +  tail call void @llvm.dbg.value(metadata double %retval.0.i, i64 0,
>>> metadata !15, metadata !49), !dbg !50
>>> +  %div = fdiv double %conv, %retval.0.i, !dbg !51
>>> +  br label %if.end.15, !dbg !52
>>> +
>>> +if.else:                                          ; preds = %entry
>>> +  %mul = fmul double %value, undef, !dbg !53
>>> +  br label %if.end.15
>>> +
>>> +if.end.15:                                        ; preds =
>>> %if.else, %php_intpow10.exit
>>> +  %tmp_value.1 = phi double [ %div, %php_intpow10.exit ], [ %mul,
>>> %if.else ]
>>> +  ret double %tmp_value.1, !dbg !57
>>> +}
>>> +
>>> +declare signext i32 @php_intlog10abs(...) #1
>>> +
>>> +declare signext i32 @php_round_helper(...) #1
>>> +
>>> +; Function Attrs: nounwind
>>> +declare double @pow(double, double) #0
>>> +
>>> +; Function Attrs: nounwind readnone
>>> +declare void @llvm.dbg.value(metadata, i64, metadata, metadata) #2
>>> +
>>> +attributes #0 = { nounwind "disable-tail-calls"="false"
>>> "less-precise-fpmad"="false" "no-frame-pointer-elim"="true"
>>> "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false"
>>> "no-nans-fp-math"="false" "stack-protector-buffer-size"="8"
>>> "target-cpu"="ppc64le"
>>> "target-features"="+altivec,+bpermd,+crypto,+direct-move,+extdiv,+power8-vector,+vsx,-qpx"
>>> "unsafe-fp-math"="false" "use-soft-float"="false" }
>>> +attributes #1 = { "disable-tail-calls"="false"
>>> "less-precise-fpmad"="false" "no-frame-pointer-elim"="true"
>>> "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false"
>>> "no-nans-fp-math"="false" "stack-protector-buffer-size"="8"
>>> "target-cpu"="ppc64le"
>>> "target-features"="+altivec,+bpermd,+crypto,+direct-move,+extdiv,+power8-vector,+vsx,-qpx"
>>> "unsafe-fp-math"="false" "use-soft-float"="false" }
>>> +attributes #2 = { nounwind readnone }
>>> +attributes #3 = { nounwind }
>>> +
>>> +!llvm.dbg.cu = !{!0}
>>> +!llvm.module.flags = !{!29, !30}
>>> +!llvm.ident = !{!31}
>>> +
>>> +!0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1,
>>> producer: "clang version 3.8.0
>>> (git://github.com/llvm-mirror/clang.git
>>> e0848b6353721eb1b278a5bbea257bbf6316251e)
>>> (git://github.com/llvm-mirror/llvm.git
>>> 8724a428dfd5e78d7865bb01783708e83f9ed128)", isOptimized: true,
>>> runtimeVersion: 0, emissionKind: 1, enums: !2, retainedTypes: !3,
>>> subprograms: !5, globals: !23)
>>> +!1 = !DIFile(filename: "testcase.i", directory: "/tmp/glibc.build")
>>> +!2 = !{}
>>> +!3 = !{!4}
>>> +!4 = !DIBasicType(name: "double", size: 64, align: 64, encoding:
>>> DW_ATE_float)
>>> +!5 = !{!6, !18}
>>> +!6 = !DISubprogram(name: "_php_math_round", scope: !1, file: !1,
>>> line: 15, type: !7, isLocal: false, isDefinition: true, scopeLine:
>>> 16, flags: DIFlagPrototyped, isOptimized: true, function: double
>>> (double, i32, i32)* @_php_math_round, variables: !10)
>>> +!7 = !DISubroutineType(types: !8)
>>> +!8 = !{!4, !4, !9, !9}
>>> +!9 = !DIBasicType(name: "int", size: 32, align: 32, encoding:
>>> DW_ATE_signed)
>>> +!10 = !{!11, !12, !13, !14, !15, !16, !17}
>>> +!11 = !DILocalVariable(name: "value", arg: 1, scope: !6, file: !1,
>>> line: 15, type: !4)
>>> +!12 = !DILocalVariable(name: "places", arg: 2, scope: !6, file: !1,
>>> line: 15, type: !9)
>>> +!13 = !DILocalVariable(name: "mode", arg: 3, scope: !6, file: !1,
>>> line: 15, type: !9)
>>> +!14 = !DILocalVariable(name: "f1", scope: !6, file: !1, line: 17,
>>> type: !4)
>>> +!15 = !DILocalVariable(name: "f2", scope: !6, file: !1, line: 17,
>>> type: !4)
>>> +!16 = !DILocalVariable(name: "tmp_value", scope: !6, file: !1, line:
>>> 18, type: !4)
>>> +!17 = !DILocalVariable(name: "precision_places", scope: !6, file:
>>> !1, line: 19, type: !9)
>>> +!18 = !DISubprogram(name: "php_intpow10", scope: !1, file: !1, line:
>>> 1, type: !19, isLocal: true, isDefinition: true, scopeLine: 2,
>>> flags: DIFlagPrototyped, isOptimized: true, variables: !21)
>>> +!19 = !DISubroutineType(types: !20)
>>> +!20 = !{!4, !9}
>>> +!21 = !{!22}
>>> +!22 = !DILocalVariable(name: "power", arg: 1, scope: !18, file: !1,
>>> line: 1, type: !9)
>>> +!23 = !{!24}
>>> +!24 = !DIGlobalVariable(name: "powers", scope: !18, file: !1, line:
>>> 3, type: !25, isLocal: true, isDefinition: true, variable: [23 x
>>> double]* @php_intpow10.powers)
>>> +!25 = !DICompositeType(tag: DW_TAG_array_type, baseType: !26, size:
>>> 1472, align: 64, elements: !27)
>>> +!26 = !DIDerivedType(tag: DW_TAG_const_type, baseType: !4)
>>> +!27 = !{!28}
>>> +!28 = !DISubrange(count: 23)
>>> +!29 = !{i32 2, !"Dwarf Version", i32 4}
>>> +!30 = !{i32 2, !"Debug Info Version", i32 3}
>>> +!31 = !{!"clang version 3.8.0
>>> (git://github.com/llvm-mirror/clang.git
>>> e0848b6353721eb1b278a5bbea257bbf6316251e)
>>> (git://github.com/llvm-mirror/llvm.git
>>> 8724a428dfd5e78d7865bb01783708e83f9ed128)"}
>>> +!32 = !DILocation(line: 21, column: 32, scope: !33)
>>> +!33 = distinct !DILexicalBlock(scope: !6, file: !1, line: 21,
>>> column: 6)
>>> +!34 = !DILocation(line: 22, column: 15, scope: !35)
>>> +!35 = distinct !DILexicalBlock(scope: !33, file: !1, line: 21,
>>> column: 67)
>>> +!36 = !DILocation(line: 8, column: 16, scope: !37, inlinedAt: !38)
>>> +!37 = distinct !DILexicalBlock(scope: !18, file: !1, line: 8,
>>> column: 6)
>>> +!38 = distinct !DILocation(line: 23, column: 8, scope: !35)
>>> +!39 = !DILocation(line: 9, column: 10, scope: !40, inlinedAt: !38)
>>> +!40 = distinct !DILexicalBlock(scope: !37, file: !1, line: 8,
>>> column: 31)
>>> +!41 = !DILocation(line: 9, column: 3, scope: !40, inlinedAt: !38)
>>> +!42 = !DILocation(line: 11, column: 9, scope: !18, inlinedAt: !38)
>>> +!43 = !{!44, !44, i64 0}
>>> +!44 = !{!"double", !45, i64 0}
>>> +!45 = !{!"omnipotent char", !46, i64 0}
>>> +!46 = !{!"Simple C/C++ TBAA"}
>>> +!47 = !DILocation(line: 11, column: 2, scope: !18, inlinedAt: !38)
>>> +!48 = !DILocation(line: 23, column: 8, scope: !35)
>>> +!49 = !DIExpression()
>>> +!50 = !DILocation(line: 17, column: 13, scope: !6)
>>> +!51 = !DILocation(line: 24, column: 25, scope: !35)
>>> +!52 = !DILocation(line: 25, column: 2, scope: !35)
>>> +!53 = !DILocation(line: 27, column: 22, scope: !54)
>>> +!54 = distinct !DILexicalBlock(scope: !55, file: !1, line: 26,
>>> column: 20)
>>> +!55 = distinct !DILexicalBlock(scope: !56, file: !1, line: 26,
>>> column: 7)
>>> +!56 = distinct !DILexicalBlock(scope: !33, file: !1, line: 25,
>>> column: 9)
>>> +!57 = !DILocation(line: 32, column: 2, scope: !6)
>>>
>>>
>>> _______________________________________________
>>> llvm-commits mailing list
>>> llvm-commits at lists.llvm.org
>>> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits
>>>
>>
>> --
>> Hal Finkel
>> Assistant Computational Scientist
>> Leadership Computing Facility
>> Argonne National Laboratory


More information about the llvm-commits mailing list