diff options
| author | Chris Lattner <sabre@nondot.org> | 2010-09-07 20:01:38 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2010-09-07 20:01:38 +0000 |
| commit | 6e27b3e0041802907194e6e4a00ac038d603759f (patch) | |
| tree | 0e295f429fa43dea5e9106c0b53956c925cbbf80 /llvm/test/Transforms | |
| parent | 5444b36e014d7d518b832a9e41153487d53b358a (diff) | |
| download | bcm5719-llvm-6e27b3e0041802907194e6e4a00ac038d603759f.tar.gz bcm5719-llvm-6e27b3e0041802907194e6e4a00ac038d603759f.zip | |
Fix a serious performance regression introduced by r108687 on linux:
turning (fptrunc (sqrt (fpext x))) -> (sqrtf x) is great, but we have
to delete the original sqrt as well. Not doing so causes us to do
two sqrt's when building with -fmath-errno (the default on linux).
llvm-svn: 113260
Diffstat (limited to 'llvm/test/Transforms')
| -rw-r--r-- | llvm/test/Transforms/InstCombine/sqrt.ll | 22 |
1 files changed, 19 insertions, 3 deletions
diff --git a/llvm/test/Transforms/InstCombine/sqrt.ll b/llvm/test/Transforms/InstCombine/sqrt.ll index 65053820482..69e511bfb3b 100644 --- a/llvm/test/Transforms/InstCombine/sqrt.ll +++ b/llvm/test/Transforms/InstCombine/sqrt.ll @@ -1,16 +1,32 @@ ; RUN: opt -S -instcombine %s | FileCheck %s -define float @foo(float %x) nounwind readnone ssp { +define float @test1(float %x) nounwind readnone ssp { entry: +; CHECK: @test1 ; CHECK-NOT: fpext ; CHECK-NOT: sqrt( ; CHECK: sqrtf( ; CHECK-NOT: fptrunc %conv = fpext float %x to double ; <double> [#uses=1] - %call = tail call double @sqrt(double %conv) nounwind ; <double> [#uses=1] + %call = tail call double @sqrt(double %conv) readnone nounwind ; <double> [#uses=1] %conv1 = fptrunc double %call to float ; <float> [#uses=1] ; CHECK: ret float ret float %conv1 } -declare double @sqrt(double) readnone +declare double @sqrt(double) + +; PR8096 +define float @test2(float %x) nounwind readnone ssp { +entry: +; CHECK: @test2 +; CHECK-NOT: fpext +; CHECK-NOT: sqrt( +; CHECK: sqrtf( +; CHECK-NOT: fptrunc + %conv = fpext float %x to double ; <double> [#uses=1] + %call = tail call double @sqrt(double %conv) nounwind ; <double> [#uses=1] + %conv1 = fptrunc double %call to float ; <float> [#uses=1] +; CHECK: ret float + ret float %conv1 +} |

