summaryrefslogtreecommitdiff
path: root/lib/CodeGen/StackProtector.cpp
diff options
context:
space:
mode:
authorMichael Gottesman <mgottesman@apple.com>2013-08-20 08:56:26 +0000
committerMichael Gottesman <mgottesman@apple.com>2013-08-20 08:56:26 +0000
commitd4f478899e6229648f94c4aa70256986cdc6ee18 (patch)
tree0179001f855f75bb351501284773c1be70d30dc8 /lib/CodeGen/StackProtector.cpp
parentb99272a521ecffe8d021306713bd51fafc85721e (diff)
downloadllvm-d4f478899e6229648f94c4aa70256986cdc6ee18.tar.gz
llvm-d4f478899e6229648f94c4aa70256986cdc6ee18.tar.bz2
llvm-d4f478899e6229648f94c4aa70256986cdc6ee18.tar.xz
[stackprotector] Small Bit of computation hoisting.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@188771 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/StackProtector.cpp')
-rw-r--r--lib/CodeGen/StackProtector.cpp10
1 files changed, 5 insertions, 5 deletions
diff --git a/lib/CodeGen/StackProtector.cpp b/lib/CodeGen/StackProtector.cpp
index 2cd2219ac9..86ca53dba4 100644
--- a/lib/CodeGen/StackProtector.cpp
+++ b/lib/CodeGen/StackProtector.cpp
@@ -387,7 +387,8 @@ static bool CreatePrologue(Function *F, Module *M, ReturnInst *RI,
/// value. It calls __stack_chk_fail if they differ.
bool StackProtector::InsertStackProtectors() {
bool HasPrologue = false;
- bool SupportsSelectionDAGSP = false;
+ bool SupportsSelectionDAGSP =
+ EnableSelectionDAGSP && !TM->Options.EnableFastISel;
AllocaInst *AI = 0; // Place on stack that stores the stack guard.
Value *StackGuardVar = 0; // The stack guard variable.
@@ -398,12 +399,11 @@ bool StackProtector::InsertStackProtectors() {
if (!HasPrologue) {
HasPrologue = true;
- SupportsSelectionDAGSP = CreatePrologue(F, M, RI, TLI, Trip, AI,
- StackGuardVar);
+ SupportsSelectionDAGSP &= CreatePrologue(F, M, RI, TLI, Trip, AI,
+ StackGuardVar);
}
- if (EnableSelectionDAGSP && !TM->Options.EnableFastISel &&
- SupportsSelectionDAGSP) {
+ if (SupportsSelectionDAGSP) {
// Since we have a potential tail call, insert the special stack check
// intrinsic.
Instruction *InsertionPt = 0;