aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Criswell <criswell@uiuc.edu>2003-10-24 13:28:12 +0000
committerJohn Criswell <criswell@uiuc.edu>2003-10-24 13:28:12 +0000
commitee03f83e84f6ee2d4ddb4c28aeef2291d46c27af (patch)
tree7e8ac9fb06c26898fbf9d1d3668b7f29e2fb14aa
parent732c775d44ecd838ffc428a1821f87b8d4f69a6e (diff)
Merged revision 1.21.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_1@9462 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Analysis/IPA/FindUsedTypes.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/lib/Analysis/IPA/FindUsedTypes.cpp b/lib/Analysis/IPA/FindUsedTypes.cpp
index ad548d0f9a..91b599017e 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<Type>(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.