aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2004-09-13 23:44:23 +0000
committerReid Spencer <rspencer@reidspencer.com>2004-09-13 23:44:23 +0000
commite59eaf407a675845e278c2769e3dbed9f1daae8c (patch)
tree30cd08523ff58bc894ac77a55f0b027c2a73f24d /lib
parentb9210123a9a006c5efe7feb70242c502433e780f (diff)
downloadexternal_llvm-e59eaf407a675845e278c2769e3dbed9f1daae8c.zip
external_llvm-e59eaf407a675845e278c2769e3dbed9f1daae8c.tar.gz
external_llvm-e59eaf407a675845e278c2769e3dbed9f1daae8c.tar.bz2
Add support for the link-time pass list to Modules.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@16321 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/AsmParser/Lexer.l1
-rw-r--r--lib/AsmParser/llvmAsmParser.y17
-rw-r--r--lib/VMCore/AsmWriter.cpp14
-rw-r--r--lib/VMCore/Module.cpp6
4 files changed, 37 insertions, 1 deletions
diff --git a/lib/AsmParser/Lexer.l b/lib/AsmParser/Lexer.l
index 45361bd..9290cf1 100644
--- a/lib/AsmParser/Lexer.l
+++ b/lib/AsmParser/Lexer.l
@@ -195,6 +195,7 @@ not { return NOT; } /* Deprecated, turned into XOR */
target { return TARGET; }
triple { return TRIPLE; }
deplibs { return DEPLIBS; }
+passes { return PASSES; }
endian { return ENDIAN; }
pointersize { return POINTERSIZE; }
little { return LITTLE; }
diff --git a/lib/AsmParser/llvmAsmParser.y b/lib/AsmParser/llvmAsmParser.y
index 1fd8782..aec7b38 100644
--- a/lib/AsmParser/llvmAsmParser.y
+++ b/lib/AsmParser/llvmAsmParser.y
@@ -910,7 +910,7 @@ Module *llvm::RunVMAsmParser(const std::string &Filename, FILE *F) {
%token DECLARE GLOBAL CONSTANT VOLATILE
%token TO DOTDOTDOT NULL_TOK CONST INTERNAL LINKONCE WEAK APPENDING
%token OPAQUE NOT EXTERNAL TARGET TRIPLE ENDIAN POINTERSIZE LITTLE BIG
-%token DEPLIBS
+%token DEPLIBS PASSES
// Basic Block Terminating Operators
%token <TermOpVal> RET BR SWITCH INVOKE UNWIND
@@ -1484,6 +1484,8 @@ ConstPool : ConstPool OptAssign TYPE TypesV { // Types can be defined in the co
}
| ConstPool DEPLIBS '=' LibrariesDefinition {
}
+ | ConstPool PASSES '=' PassesDefinition {
+ }
| /* empty: end of list */ {
};
@@ -1522,6 +1524,19 @@ LibList : LibList ',' STRINGCONSTANT {
}
;
+PassesDefinition : '[' PassList ']';
+PassList : PassList ',' STRINGCONSTANT {
+ CurModule.CurrentModule->addLibrary($3);
+ free($3);
+ }
+ | STRINGCONSTANT {
+ CurModule.CurrentModule->addLibrary($1);
+ free($1);
+ }
+ | /* empty: end of list */ {
+ }
+ ;
+
//===----------------------------------------------------------------------===//
// Rules to match Function Headers
//===----------------------------------------------------------------------===//
diff --git a/lib/VMCore/AsmWriter.cpp b/lib/VMCore/AsmWriter.cpp
index 0c4a1f7..7f862df 100644
--- a/lib/VMCore/AsmWriter.cpp
+++ b/lib/VMCore/AsmWriter.cpp
@@ -777,6 +777,20 @@ void AssemblyWriter::printModule(const Module *M) {
}
Out << " ]\n";
}
+
+ // Loop over the link time pass list and emit them
+ Module::pass_iterator PI = M->pass_begin();
+ Module::pass_iterator PE = M->pass_end();
+ if (LI != LE) {
+ Out << "passes = [\n";
+ while (LI != LE) {
+ Out << "\"" << *LI << "\"";
+ ++LI;
+ if (LI != LE)
+ Out << ",\n";
+ }
+ Out << " ]\n";
+ }
// Loop over the symbol table, emitting all named constants...
printSymbolTable(M->getSymbolTable());
diff --git a/lib/VMCore/Module.cpp b/lib/VMCore/Module.cpp
index d8caf7f..1dae14e 100644
--- a/lib/VMCore/Module.cpp
+++ b/lib/VMCore/Module.cpp
@@ -270,6 +270,12 @@ std::string Module::getTypeName(const Type *Ty) const {
return ""; // Must not have found anything...
}
+void Module::removePass(const std::string& Lib) {
+ PassListType::iterator I = find(PassList.begin(),PassList.end(),Lib);
+ if (I != PassList.end())
+ PassList.erase(I);
+}
+
//===----------------------------------------------------------------------===//
// Other module related stuff.