summaryrefslogtreecommitdiff
path: root/utils/TableGen/AsmWriterEmitter.cpp
diff options
context:
space:
mode:
authorBill Wendling <isanbard@gmail.com>2011-04-08 04:08:57 +0000
committerBill Wendling <isanbard@gmail.com>2011-04-08 04:08:57 +0000
commitdd099e1e5519d718b572ff2b42b2a3581b66b5dd (patch)
treee75ad67a78dcee748808a1cb652a87af25282384 /utils/TableGen/AsmWriterEmitter.cpp
parent3dcac711c0444445d99b54665b0898240c242ebf (diff)
downloadllvm-dd099e1e5519d718b572ff2b42b2a3581b66b5dd.tar.gz
llvm-dd099e1e5519d718b572ff2b42b2a3581b66b5dd.tar.bz2
llvm-dd099e1e5519d718b572ff2b42b2a3581b66b5dd.tar.xz
Only emit the AvailableFeatures variable if it's used.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@129124 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils/TableGen/AsmWriterEmitter.cpp')
-rw-r--r--utils/TableGen/AsmWriterEmitter.cpp11
1 files changed, 7 insertions, 4 deletions
diff --git a/utils/TableGen/AsmWriterEmitter.cpp b/utils/TableGen/AsmWriterEmitter.cpp
index 534f20f1eb..05bc113c37 100644
--- a/utils/TableGen/AsmWriterEmitter.cpp
+++ b/utils/TableGen/AsmWriterEmitter.cpp
@@ -625,10 +625,10 @@ public:
unsigned getOpIndex(StringRef Op) { return OpMap[Op]; }
bool isOpMapped(StringRef Op) { return OpMap.find(Op) != OpMap.end(); }
- void print(raw_ostream &O) {
+ bool print(raw_ostream &O) {
if (Conds.empty() && ReqFeatures.empty()) {
O.indent(6) << "return true;\n";
- return;
+ return false;
}
O << "if (";
@@ -675,6 +675,7 @@ public:
O.indent(6) << "break;\n";
O.indent(4) << '}';
+ return !ReqFeatures.empty();
}
bool operator==(const IAPrinter &RHS) {
@@ -937,6 +938,7 @@ void AsmWriterEmitter::EmitPrintAliasInstruction(raw_ostream &O) {
std::string Cases;
raw_string_ostream CasesO(Cases);
+ bool NeedAvailableFeatures = false;
for (std::map<std::string, std::vector<IAPrinter*> >::iterator
I = IAPrinterMap.begin(), E = IAPrinterMap.end(); I != E; ++I) {
@@ -967,7 +969,7 @@ void AsmWriterEmitter::EmitPrintAliasInstruction(raw_ostream &O) {
II = UniqueIAPs.begin(), IE = UniqueIAPs.end(); II != IE; ++II) {
IAPrinter *IAP = *II;
CasesO.indent(4);
- IAP->print(CasesO);
+ NeedAvailableFeatures |= IAP->print(CasesO);
CasesO << '\n';
}
@@ -983,7 +985,8 @@ void AsmWriterEmitter::EmitPrintAliasInstruction(raw_ostream &O) {
O.indent(2) << "StringRef AsmString;\n";
O.indent(2) << "std::map<StringRef, unsigned> OpMap;\n";
- O.indent(2) << "unsigned AvailableFeatures = getAvailableFeatures();\n\n";
+ if (NeedAvailableFeatures)
+ O.indent(2) << "unsigned AvailableFeatures = getAvailableFeatures();\n\n";
O.indent(2) << "switch (MI->getOpcode()) {\n";
O.indent(2) << "default: return true;\n";
O << CasesO.str();