diff options
author | Matt Arsenault <Matthew.Arsenault@amd.com> | 2023-04-29 19:31:01 -0400 |
---|---|---|
committer | Matt Arsenault <arsenm2@gmail.com> | 2023-05-18 08:04:38 +0100 |
commit | cac9e427eb1ff3dabda8ac08968b998c3bc5ab47 (patch) | |
tree | c15f5acf393da88296397dcc6ff761317994a55f /llvm/unittests/Analysis/ValueTrackingTest.cpp | |
parent | 60b8e3a66b64dfb7b7b9d1815018265fd38edaa4 (diff) | |
download | llvm-cac9e427eb1ff3dabda8ac08968b998c3bc5ab47.zip llvm-cac9e427eb1ff3dabda8ac08968b998c3bc5ab47.tar.gz llvm-cac9e427eb1ff3dabda8ac08968b998c3bc5ab47.tar.bz2 |
ValueTracking: Handle phi in computeKnownFPClass
Doesn't try the all the tricks computeKnownBits does.
Diffstat (limited to 'llvm/unittests/Analysis/ValueTrackingTest.cpp')
-rw-r--r-- | llvm/unittests/Analysis/ValueTrackingTest.cpp | 108 |
1 files changed, 108 insertions, 0 deletions
diff --git a/llvm/unittests/Analysis/ValueTrackingTest.cpp b/llvm/unittests/Analysis/ValueTrackingTest.cpp index c83fb62..3684f6f 100644 --- a/llvm/unittests/Analysis/ValueTrackingTest.cpp +++ b/llvm/unittests/Analysis/ValueTrackingTest.cpp @@ -1630,6 +1630,114 @@ TEST_F(ComputeKnownFPClassTest, FMulNoZero) { expectKnownFPClass(fcAllFlags, std::nullopt, A7); } +TEST_F(ComputeKnownFPClassTest, Phi) { + parseAssembly( + "define float @test(i1 %cond, float nofpclass(nan inf) %arg0, float nofpclass(nan) %arg1) {\n" + "entry:\n" + " br i1 %cond, label %bb0, label %bb1\n" + "bb0:\n" + " br label %ret\n" + "bb1:\n" + " br label %ret\n" + "ret:\n" + " %A = phi float [ %arg0, %bb0 ], [ %arg1, %bb1 ]\n" + " ret float %A\n" + "}\n"); + expectKnownFPClass(~fcNan, std::nullopt); +} + +TEST_F(ComputeKnownFPClassTest, PhiKnownSignFalse) { + parseAssembly( + "declare float @llvm.fabs.f32(float)" + "define float @test(i1 %cond, float nofpclass(nan) %arg0, float nofpclass(nan) %arg1) {\n" + "entry:\n" + " br i1 %cond, label %bb0, label %bb1\n" + "bb0:\n" + " %fabs.arg0 = call float @llvm.fabs.f32(float %arg0)\n" + " br label %ret\n" + "bb1:\n" + " %fabs.arg1 = call float @llvm.fabs.f32(float %arg1)\n" + " br label %ret\n" + "ret:\n" + " %A = phi float [ %fabs.arg0, %bb0 ], [ %fabs.arg1, %bb1 ]\n" + " ret float %A\n" + "}\n"); + expectKnownFPClass(fcPositive, false); +} + +TEST_F(ComputeKnownFPClassTest, PhiKnownSignTrue) { + parseAssembly( + "declare float @llvm.fabs.f32(float)" + "define float @test(i1 %cond, float nofpclass(nan) %arg0, float %arg1) {\n" + "entry:\n" + " br i1 %cond, label %bb0, label %bb1\n" + "bb0:\n" + " %fabs.arg0 = call float @llvm.fabs.f32(float %arg0)\n" + " %fneg.fabs.arg0 = fneg float %fabs.arg0\n" + " br label %ret\n" + "bb1:\n" + " %fabs.arg1 = call float @llvm.fabs.f32(float %arg1)\n" + " %fneg.fabs.arg1 = fneg float %fabs.arg1\n" + " br label %ret\n" + "ret:\n" + " %A = phi float [ %fneg.fabs.arg0, %bb0 ], [ %fneg.fabs.arg1, %bb1 ]\n" + " ret float %A\n" + "}\n"); + expectKnownFPClass(fcNegative | fcNan, true); +} + +TEST_F(ComputeKnownFPClassTest, UnreachablePhi) { + parseAssembly( + "define float @test(float %arg) {\n" + "entry:\n" + " ret float 0.0\n" + "unreachable:\n" + " %A = phi float\n" + " ret float %A\n" + "}\n"); + expectKnownFPClass(fcAllFlags, std::nullopt); +} + +TEST_F(ComputeKnownFPClassTest, SelfPhiOnly) { + parseAssembly( + "define float @test(float %arg) {\n" + "entry:\n" + " ret float 0.0\n" + "loop:\n" + " %A = phi float [ %A, %loop ]\n" + " br label %loop\n" + "}\n"); + expectKnownFPClass(fcAllFlags, std::nullopt); +} + +TEST_F(ComputeKnownFPClassTest, SelfPhiFirstArg) { + parseAssembly( + "define float @test(i1 %cond, float nofpclass(inf) %arg) {\n" + "entry:\n" + " br i1 %cond, label %loop, label %ret\n" + "loop:\n" + " %A = phi float [ %arg, %entry ], [ %A, %loop ]\n" + " br label %loop\n" + "ret:\n" + " ret float %A" + "}\n"); + expectKnownFPClass(~fcInf, std::nullopt); +} + +TEST_F(ComputeKnownFPClassTest, SelfPhiSecondArg) { + parseAssembly( + "define float @test(i1 %cond, float nofpclass(inf) %arg) {\n" + "entry:\n" + " br i1 %cond, label %loop, label %ret\n" + "loop:\n" + " %A = phi float [ %A, %loop ], [ %arg, %entry ]\n" + " br label %loop\n" + "ret:\n" + " ret float %A" + "}\n"); + expectKnownFPClass(~fcInf, std::nullopt); +} + TEST_F(ComputeKnownFPClassTest, CannotBeOrderedLessThanZero) { parseAssembly("define float @test(float %arg) {\n" " %A = fmul float %arg, %arg" |