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

Hans Wennborg via llvm-commits llvm-commits at lists.llvm.org
Mon Aug 24 16:54:29 PDT 2015


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