diff options
author | Dale Johannesen <dalej@apple.com> | 2009-09-25 18:00:35 +0000 |
---|---|---|
committer | Dale Johannesen <dalej@apple.com> | 2009-09-25 18:00:35 +0000 |
commit | a318d91a1e29a87dd8687d7e07549fb3e4405b89 (patch) | |
tree | f444c7fe1c1f4650b2ded3d9bc21ddd3df22e3bf /llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuild.cpp | |
parent | 0a4c44bdf4d0f5e095f5f208163030e4d7b9baea (diff) | |
download | bcm5719-llvm-a318d91a1e29a87dd8687d7e07549fb3e4405b89.tar.gz bcm5719-llvm-a318d91a1e29a87dd8687d7e07549fb3e4405b89.zip |
Make sure sin, cos, sqrt calls are marked readonly
before producing FSIN, FCOS, FSQRT. If they aren't
so marked we have to assume they might set errno.
llvm-svn: 82781
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuild.cpp')
-rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuild.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuild.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuild.cpp index 8431e20d831..a27fbe68adc 100644 --- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuild.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuild.cpp @@ -4561,7 +4561,8 @@ void SelectionDAGLowering::visitCall(CallInst &I) { } else if (Name == "sin" || Name == "sinf" || Name == "sinl") { if (I.getNumOperands() == 2 && // Basic sanity checks. I.getOperand(1)->getType()->isFloatingPoint() && - I.getType() == I.getOperand(1)->getType()) { + I.getType() == I.getOperand(1)->getType() && + I.onlyReadsMemory()) { SDValue Tmp = getValue(I.getOperand(1)); setValue(&I, DAG.getNode(ISD::FSIN, getCurDebugLoc(), Tmp.getValueType(), Tmp)); @@ -4570,7 +4571,8 @@ void SelectionDAGLowering::visitCall(CallInst &I) { } else if (Name == "cos" || Name == "cosf" || Name == "cosl") { if (I.getNumOperands() == 2 && // Basic sanity checks. I.getOperand(1)->getType()->isFloatingPoint() && - I.getType() == I.getOperand(1)->getType()) { + I.getType() == I.getOperand(1)->getType() && + I.onlyReadsMemory()) { SDValue Tmp = getValue(I.getOperand(1)); setValue(&I, DAG.getNode(ISD::FCOS, getCurDebugLoc(), Tmp.getValueType(), Tmp)); @@ -4579,7 +4581,8 @@ void SelectionDAGLowering::visitCall(CallInst &I) { } else if (Name == "sqrt" || Name == "sqrtf" || Name == "sqrtl") { if (I.getNumOperands() == 2 && // Basic sanity checks. I.getOperand(1)->getType()->isFloatingPoint() && - I.getType() == I.getOperand(1)->getType()) { + I.getType() == I.getOperand(1)->getType() && + I.onlyReadsMemory()) { SDValue Tmp = getValue(I.getOperand(1)); setValue(&I, DAG.getNode(ISD::FSQRT, getCurDebugLoc(), Tmp.getValueType(), Tmp)); |