summaryrefslogtreecommitdiffstats
path: root/llvm/support/tools/TableGen/CodeEmitterGen.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-08-01 04:46:24 +0000
committerChris Lattner <sabre@nondot.org>2003-08-01 04:46:24 +0000
commit2e69d4a1e8187fea005da2d7af3231f067e05c1d (patch)
tree21834599f27f0ee4fddc79bf4fb526a02bf811da /llvm/support/tools/TableGen/CodeEmitterGen.cpp
parent1f2f5c839210e5ace02e6632798d86b6a9d9c367 (diff)
downloadbcm5719-llvm-2e69d4a1e8187fea005da2d7af3231f067e05c1d.tar.gz
bcm5719-llvm-2e69d4a1e8187fea005da2d7af3231f067e05c1d.zip
Add new getValueAsBitsInit 'high-level' method
llvm-svn: 7467
Diffstat (limited to 'llvm/support/tools/TableGen/CodeEmitterGen.cpp')
-rw-r--r--llvm/support/tools/TableGen/CodeEmitterGen.cpp11
1 files changed, 2 insertions, 9 deletions
diff --git a/llvm/support/tools/TableGen/CodeEmitterGen.cpp b/llvm/support/tools/TableGen/CodeEmitterGen.cpp
index 0619967f770..dc61f8f507f 100644
--- a/llvm/support/tools/TableGen/CodeEmitterGen.cpp
+++ b/llvm/support/tools/TableGen/CodeEmitterGen.cpp
@@ -26,14 +26,7 @@ void CodeEmitterGen::run(std::ostream &o) {
o << " case " << Namespace << R->getName() << ": {\n"
<< " DEBUG(std::cerr << \"Emitting " << R->getName() << "\\n\");\n";
- const RecordVal *InstVal = R->getValue("Inst");
- if (!InstVal)
- throw std::string("No 'Inst' record found in target description file!");
-
- Init *InitVal = InstVal->getValue();
- assert(dynamic_cast<BitsInit*>(InitVal) &&
- "Can only handle undefined bits<> types!");
- BitsInit *BI = (BitsInit*)InitVal;
+ BitsInit *BI = R->getValueAsBitsInit("Inst");
unsigned Value = 0;
const std::vector<RecordVal> &Vals = R->getValues();
@@ -50,7 +43,7 @@ void CodeEmitterGen::run(std::ostream &o) {
}
DEBUG(o << "\n");
- DEBUG(o << " // " << *InstVal << "\n");
+ DEBUG(o << " // " << *R->getValue("Inst") << "\n");
o << " Value = " << Value << "U;\n\n";
// Loop over all of the fields in the instruction adding in any
OpenPOWER on IntegriCloud