diff options
| author | Jingyue Wu <jingyue@google.com> | 2015-02-02 20:41:11 +0000 |
|---|---|---|
| committer | Jingyue Wu <jingyue@google.com> | 2015-02-02 20:41:11 +0000 |
| commit | 49a766e46885570266a06b6bf8fbd5ee31783d8a (patch) | |
| tree | b6344b5c1a9ad86333b7afadcd33ad42fd4e382a /llvm/lib/Transforms | |
| parent | 46fe4a640df16fb8071627b20ca42c676bbf9a0d (diff) | |
| download | bcm5719-llvm-49a766e46885570266a06b6bf8fbd5ee31783d8a.tar.gz bcm5719-llvm-49a766e46885570266a06b6bf8fbd5ee31783d8a.zip | |
Resurrect the assertion removed by r227717
Summary: MSVC can compile "LoopID->getOperand(0) == LoopID" when LoopID is MDNode*.
Test Plan: no regression
Reviewers: mkuper
Subscribers: jholewinski, llvm-commits
Differential Revision: http://reviews.llvm.org/D7327
llvm-svn: 227853
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/LoopUnrollPass.cpp | 11 | ||||
| -rw-r--r-- | llvm/lib/Transforms/Utils/LoopUnroll.cpp | 7 |
2 files changed, 9 insertions, 9 deletions
diff --git a/llvm/lib/Transforms/Scalar/LoopUnrollPass.cpp b/llvm/lib/Transforms/Scalar/LoopUnrollPass.cpp index 9a5f088bc2b..2c7f55d3a14 100644 --- a/llvm/lib/Transforms/Scalar/LoopUnrollPass.cpp +++ b/llvm/lib/Transforms/Scalar/LoopUnrollPass.cpp @@ -231,11 +231,10 @@ static unsigned ApproximateLoopSize(const Loop *L, unsigned &NumCalls, // Returns the loop hint metadata node with the given name (for example, // "llvm.loop.unroll.count"). If no such metadata node exists, then nullptr is // returned. -static const MDNode *GetUnrollMetadataForLoop(const Loop *L, StringRef Name) { - MDNode *LoopID = L->getLoopID(); - if (!LoopID) - return nullptr; - return GetUnrollMetadata(LoopID, Name); +static MDNode *GetUnrollMetadataForLoop(const Loop *L, StringRef Name) { + if (MDNode *LoopID = L->getLoopID()) + return GetUnrollMetadata(LoopID, Name); + return nullptr; } // Returns true if the loop has an unroll(full) pragma. @@ -251,7 +250,7 @@ static bool HasUnrollDisablePragma(const Loop *L) { // If loop has an unroll_count pragma return the (necessarily // positive) value from the pragma. Otherwise return 0. static unsigned UnrollCountPragmaValue(const Loop *L) { - const MDNode *MD = GetUnrollMetadataForLoop(L, "llvm.loop.unroll.count"); + MDNode *MD = GetUnrollMetadataForLoop(L, "llvm.loop.unroll.count"); if (MD) { assert(MD->getNumOperands() == 2 && "Unroll count hint metadata should have two operands."); diff --git a/llvm/lib/Transforms/Utils/LoopUnroll.cpp b/llvm/lib/Transforms/Utils/LoopUnroll.cpp index 0ee2fee41dd..accb7316cab 100644 --- a/llvm/lib/Transforms/Utils/LoopUnroll.cpp +++ b/llvm/lib/Transforms/Utils/LoopUnroll.cpp @@ -553,16 +553,17 @@ bool llvm::UnrollLoop(Loop *L, unsigned Count, unsigned TripCount, /// Given an llvm.loop loop id metadata node, returns the loop hint metadata /// node with the given name (for example, "llvm.loop.unroll.count"). If no /// such metadata node exists, then nullptr is returned. -const MDNode *llvm::GetUnrollMetadata(const MDNode *LoopID, StringRef Name) { +MDNode *llvm::GetUnrollMetadata(MDNode *LoopID, StringRef Name) { // First operand should refer to the loop id itself. assert(LoopID->getNumOperands() > 0 && "requires at least one operand"); + assert(LoopID->getOperand(0) == LoopID && "invalid loop id"); for (unsigned i = 1, e = LoopID->getNumOperands(); i < e; ++i) { - const MDNode *MD = dyn_cast<MDNode>(LoopID->getOperand(i)); + MDNode *MD = dyn_cast<MDNode>(LoopID->getOperand(i)); if (!MD) continue; - const MDString *S = dyn_cast<MDString>(MD->getOperand(0)); + MDString *S = dyn_cast<MDString>(MD->getOperand(0)); if (!S) continue; |

