summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms/Utils/LoopUnroll.cpp
diff options
context:
space:
mode:
authorJingyue Wu <jingyue@google.com>2015-02-02 20:41:11 +0000
committerJingyue Wu <jingyue@google.com>2015-02-02 20:41:11 +0000
commit49a766e46885570266a06b6bf8fbd5ee31783d8a (patch)
treeb6344b5c1a9ad86333b7afadcd33ad42fd4e382a /llvm/lib/Transforms/Utils/LoopUnroll.cpp
parent46fe4a640df16fb8071627b20ca42c676bbf9a0d (diff)
downloadbcm5719-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/Utils/LoopUnroll.cpp')
-rw-r--r--llvm/lib/Transforms/Utils/LoopUnroll.cpp7
1 files changed, 4 insertions, 3 deletions
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;
OpenPOWER on IntegriCloud