mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-02 07:11:49 +00:00
Okay, the list of link-time passes wasn't such a hot idea. Its prone to
error. We'll strategize on this when we have multiple front ends to deal with. For now llvm-ld just runs a standard set of transforms. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@16333 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
44da7d7976
commit
1c7b907325
@ -49,7 +49,6 @@ public:
|
||||
typedef iplist<GlobalVariable> GlobalListType;
|
||||
typedef iplist<Function> FunctionListType;
|
||||
typedef SetVector<std::string> LibraryListType;
|
||||
typedef std::vector<std::string> PassListType;
|
||||
|
||||
// Global Variable iterators...
|
||||
typedef GlobalListType::iterator giterator;
|
||||
@ -66,9 +65,6 @@ public:
|
||||
// Library list iterators
|
||||
typedef LibraryListType::const_iterator lib_iterator;
|
||||
|
||||
// Link-time Pass list iterators
|
||||
typedef PassListType::const_iterator pass_iterator;
|
||||
|
||||
enum Endianness { AnyEndianness, LittleEndian, BigEndian };
|
||||
enum PointerSize { AnyPointerSize, Pointer32, Pointer64 };
|
||||
|
||||
@ -76,7 +72,6 @@ private:
|
||||
GlobalListType GlobalList; // The Global Variables in the module
|
||||
FunctionListType FunctionList; // The Functions in the module
|
||||
LibraryListType LibraryList; // The Libraries needed by the module
|
||||
PassListType PassList; // The Passes needed by the module at link time
|
||||
SymbolTable *SymTab; // Symbol Table for the module
|
||||
std::string ModuleID; // Human readable identifier for the module
|
||||
std::string TargetTriple; // Platform target triple Module compiled on
|
||||
@ -252,27 +247,6 @@ public:
|
||||
/// @brief Get all the libraries
|
||||
inline const LibraryListType& getLibraries() const { return LibraryList; }
|
||||
|
||||
//===--------------------------------------------------------------------===//
|
||||
// Access functions for Link-time pass list
|
||||
|
||||
/// @brief Get a constant iterator to beginning of pass list.
|
||||
inline pass_iterator pass_begin() const { return PassList.begin(); }
|
||||
|
||||
/// @brief Get a constant iterator to end of pass list.
|
||||
inline pass_iterator pass_end() const { return PassList.end(); }
|
||||
|
||||
/// @brief Returns the number of items in the list of passes.
|
||||
inline unsigned pass_size() const { return PassList.size(); }
|
||||
|
||||
/// @brief Add a library to the list of passes
|
||||
inline void addPass(const std::string& Pass){ PassList.push_back(Pass); }
|
||||
|
||||
/// @brief Remove a library from the list of passes
|
||||
void removePass(const std::string& Lib);
|
||||
|
||||
/// @brief Get all the passes
|
||||
inline const PassListType& getPasses() const { return PassList; }
|
||||
|
||||
//===--------------------------------------------------------------------===//
|
||||
// Utility functions for printing and dumping Module objects
|
||||
|
||||
|
@ -195,7 +195,6 @@ 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; }
|
||||
|
@ -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 PASSES
|
||||
%token DEPLIBS
|
||||
|
||||
// Basic Block Terminating Operators
|
||||
%token <TermOpVal> RET BR SWITCH INVOKE UNWIND
|
||||
@ -1484,8 +1484,6 @@ ConstPool : ConstPool OptAssign TYPE TypesV { // Types can be defined in the co
|
||||
}
|
||||
| ConstPool DEPLIBS '=' LibrariesDefinition {
|
||||
}
|
||||
| ConstPool PASSES '=' PassesDefinition {
|
||||
}
|
||||
| /* empty: end of list */ {
|
||||
};
|
||||
|
||||
@ -1524,19 +1522,6 @@ 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
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
@ -778,20 +778,6 @@ 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 = [ ";
|
||||
while (LI != LE) {
|
||||
Out << '"' << *LI << '"';
|
||||
++LI;
|
||||
if (LI != LE)
|
||||
Out << ", ";
|
||||
}
|
||||
Out << " ]\n";
|
||||
}
|
||||
|
||||
// Loop over the symbol table, emitting all named constants.
|
||||
printSymbolTable(M->getSymbolTable());
|
||||
|
||||
|
@ -270,13 +270,6 @@ 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.
|
||||
//
|
||||
|
Loading…
Reference in New Issue
Block a user