summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAaron Ballman <aaron@aaronballman.com>2018-12-21 19:16:38 +0000
committerAaron Ballman <aaron@aaronballman.com>2018-12-21 19:16:38 +0000
commit88b36702dc16d4ddf06136a1ca3a027c31c90c8f (patch)
tree14cc16b619fd19332627647bb277d4008f46c6f6
parent255b05820cb9b52099cc14257fcf599d97084650 (diff)
downloadbcm5719-llvm-88b36702dc16d4ddf06136a1ca3a027c31c90c8f.tar.gz
bcm5719-llvm-88b36702dc16d4ddf06136a1ca3a027c31c90c8f.zip
Switch from cast<> to dyn_cast<>.
This avoids a potential failed assertion that is happening on someone's out-of-tree build. llvm-svn: 349940
-rw-r--r--clang/utils/TableGen/ClangSACheckersEmitter.cpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/clang/utils/TableGen/ClangSACheckersEmitter.cpp b/clang/utils/TableGen/ClangSACheckersEmitter.cpp
index 4f20274334a..453dfe564bf 100644
--- a/clang/utils/TableGen/ClangSACheckersEmitter.cpp
+++ b/clang/utils/TableGen/ClangSACheckersEmitter.cpp
@@ -63,8 +63,11 @@ static inline uint64_t getValueFromBitsInit(const BitsInit *B) {
uint64_t Value = 0;
for (unsigned i = 0, e = B->getNumBits(); i != e; ++i) {
- const auto *Bit = cast<BitInit>(B->getBit(i));
- Value |= uint64_t(Bit->getValue()) << i;
+ const auto *Bit = dyn_cast<BitInit>(B->getBit(i));
+ if (Bit)
+ Value |= uint64_t(Bit->getValue()) << i;
+ else
+ PrintFatalError("Invalid bits");
}
return Value;
}
OpenPOWER on IntegriCloud