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

Hans Wennborg via llvm-commits llvm-commits at lists.llvm.org
Thu Sep 10 15:23:53 PDT 2015


+Tom for 3.7.1

On Wed, Aug 26, 2015 at 4:19 PM, Hans Wennborg <hans at chromium.org> wrote:
> 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