From: Chris Lattner Date: Thu, 23 Oct 2003 19:30:30 +0000 (+0000) Subject: Fix bug: CBackend/2003-10-23-UnusedType.ll and hopefully 252.eon X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=472a7ef1cb9cca42cc26baea1acc4c80b5836a58;p=oota-llvm.git Fix bug: CBackend/2003-10-23-UnusedType.ll and hopefully 252.eon git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@9441 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/IPA/FindUsedTypes.cpp b/lib/Analysis/IPA/FindUsedTypes.cpp index ad548d0f9ae..91b599017e1 100644 --- a/lib/Analysis/IPA/FindUsedTypes.cpp +++ b/lib/Analysis/IPA/FindUsedTypes.cpp @@ -41,12 +41,22 @@ void FindUsedTypes::IncorporateType(const Type *Ty) { IncorporateType(*I); } +void FindUsedTypes::IncorporateSymbolTable(const SymbolTable &ST) { + SymbolTable::const_iterator TI = ST.find(Type::TypeTy); + if (TI == ST.end()) return; // No named types + + for (SymbolTable::type_const_iterator I = TI->second.begin(), + E = TI->second.end(); I != E; ++I) + IncorporateType(cast(I->second)); +} // run - This incorporates all types used by the specified module // bool FindUsedTypes::run(Module &m) { UsedTypes.clear(); // reset if run multiple times... + IncorporateSymbolTable(m.getSymbolTable()); + // Loop over global variables, incorporating their types for (Module::const_giterator I = m.gbegin(), E = m.gend(); I != E; ++I) IncorporateType(I->getType()); @@ -54,6 +64,7 @@ bool FindUsedTypes::run(Module &m) { for (Module::iterator MI = m.begin(), ME = m.end(); MI != ME; ++MI) { IncorporateType(MI->getType()); const Function &F = *MI; + IncorporateSymbolTable(F.getSymbolTable()); // Loop over all of the instructions in the function, adding their return // type as well as the types of their operands.