- Apr 13, 2016
-
-
Adhemerval Zanella authored
This patch implements the --dynamic-list option, which adds a list of global symbol that either should not be bounded by default definition when creating shared libraries, or add in dynamic symbol table in the case of creating executables. The patch modifies the ScriptParserBase class to use a list of Token instead of StringRef, which contains information if the token is a quoted or unquoted strings. It is used to use a faster search for exact match symbol name. The input file follow a similar format of linker script with some simplifications (it does not have scope or node names). It leads to a simplified parser define in DynamicList.{cpp,h}. Different from ld/gold neither glob pattern nor mangled names (extern 'C++') are currently supported. llvm-svn: 266227
-
- Apr 07, 2016
-
-
Rui Ueyama authored
start-lib and end-lib are options to link object files in the same semantics as archive files. If an object is in start-lib and end-lib, the object is linked only when the file is needed to resolve undefined symbols. That means, if an object is in start-lib and end-lib, it behaves as if it were in an archive file. In this patch, I introduced a new notion, LazyObjectFile. That is analogous to Archive file type, but that works for a single object file instead of for an archive file. http://reviews.llvm.org/D18814 llvm-svn: 265710
-
- Apr 01, 2016
-
-
Peter Collingbourne authored
Differential Revision: http://reviews.llvm.org/D18669 llvm-svn: 265073
-
- Mar 15, 2016
-
-
Rui Ueyama authored
Fixes pr26908. This patch is based on Filipe Cabecinhas' patch (http://reviews.llvm.org/D18167) http://reviews.llvm.org/D18169 llvm-svn: 263569
-
- Mar 02, 2016
-
-
Rui Ueyama authored
Now that DarwinLdDriver is the only derived class of Driver. This patch merges them and actually removed the class because they can now just be non-member functions. This change simplifies a common header, Driver.h. http://reviews.llvm.org/D17788 llvm-svn: 262502
-
- Feb 28, 2016
-
-
Rui Ueyama authored
llvm-svn: 262168
-
Rui Ueyama authored
llvm-svn: 262167
-
Rafael Espindola authored
llvm-svn: 262159
-
- Feb 11, 2016
-
-
Rui Ueyama authored
llvm-svn: 260598
-
- Feb 02, 2016
-
-
Rui Ueyama authored
http://reviews.llvm.org/D16668 llvm-svn: 259597
-
Rui Ueyama authored
This reverts r259395 which reverted r259143. llvm-svn: 259572
-
- Feb 01, 2016
-
-
Nico Weber authored
llvm-svn: 259395
-
- Jan 29, 2016
-
-
Rui Ueyama authored
This patch let the driver keep going until it parses all command line options. http://reviews.llvm.org/D16645 llvm-svn: 259143
-
- Jan 28, 2016
-
-
Rui Ueyama authored
In many situations, we don't want to exit at the first error even in the process model. For example, it is better to report all undefined symbols rather than reporting the first one that the linker picked up randomly. In order to handle such errors, we don't need to wrap everything with ErrorOr (thanks for David Blaikie for pointing this out!) Instead, we can set a flag to record the fact that we found an error and keep it going until it reaches a reasonable checkpoint. This idea should be applicable to other places. For example, we can ignore broken relocations and check for errors after visiting all relocs. In this patch, I rename error to fatal, and introduce another version of error which doesn't call exit. That function instead sets HasError to true. Once HasError becomes true, it stays true, so that we know that there was an error if it is true. I think introducing a non-noreturn error reporting function is by itself a good idea, and it looks to me that this also provides a gradual path towards lld-as-a-library (or at least embed-lld-to-your-program) without sacrificing code readability with lots of ErrorOr's. http://reviews.llvm.org/D16641 llvm-svn: 259069
-
- Jan 07, 2016
-
-
Rui Ueyama authored
llvm-svn: 257078
-
Rui Ueyama authored
createFiles was doing more than creating files despite its name. Now these things are moved to a new function. llvm-svn: 257077
-
- Jan 06, 2016
-
-
Rui Ueyama authored
Previously, we handle archive files with --whole-archive this way: create instances of ArchiveFile, call getMembers to obtain memory buffers of archive members, and create ObjectFiles for the members. We didn't call anything except getMembers if --whole-archive was specified. I noticed that we didn't actually have to create ArchiveFile instaces at all for that case. All we need is to get a list of memory buffers for members, which can be done by a non-member function. This patch removes getMembers member function from ArchiveFile. Also removed unnecessary code for memory management. llvm-svn: 256893
-
- Oct 12, 2015
-
-
Rafael Espindola authored
Now that the SymbolTable is templated, we don't need the ELFData class or multiple inheritance. llvm-svn: 250005
-
- Oct 11, 2015
-
-
Rui Ueyama authored
ArgParser was a class with only one member function, so it didn't have to be a class. llvm-svn: 249988
-
Rui Ueyama authored
In the linker script, -l and = have the same meaning as in the command line. In addition to that, if a path is not absolute, the path needs to be searched from the search paths. This patch implements them. llvm-svn: 249967
-
Rui Ueyama authored
llvm-svn: 249966
-
Rui Ueyama authored
Previously, each ArgParser owned a BumpPtrAllocator, and arguments parsed by an ArgParser would refer strings allocated using the BumpPtrAllocator only when response files were used. This could cause a subtle bug because such ownership was not obvious. This patch moves the ownership from ArgParser to Driver and make the ownership explicit. llvm-svn: 249963
-
Rui Ueyama authored
llvm-svn: 249962
-
- Oct 09, 2015
-
-
Rui Ueyama authored
SymbolTable was not a template class. Instead we had switch-case-based type dispatch to call desired functions. We had to do that because SymbolTable was created before we know what ELF type objects had been passed. Every time I tried to add a new function to the symbol table, I had to define a dispatcher which consist of a single switch statement. It also brought an restriction what the driver can do. For example, we cannot add undefined symbols before any files are added to the symbol table. That's because no symbols can be added until the symbol table knows the ELF type, but when it knows about that, it's too late. In this patch, the driver makes a decision on what ELF type objects are being handled. Then the driver creates a SymbolTable object for an appropriate ELF type. http://reviews.llvm.org/D13544 llvm-svn: 249902
-
- Oct 07, 2015
-
-
Denis Protivensky authored
Parse and apply emulation given with -m option. Check input files to match ELF type and machine architecture provided with -m. Differential Revision: http://reviews.llvm.org/D13055 llvm-svn: 249529
-
- Oct 01, 2015
-
-
Rui Ueyama authored
Opening a file and dispatching to readLinkerScript() or createFile() is a common operation. We want to use that at least from Driver and from LinkerScript. In COFF, we had the same problem. This patch resolves the problem in the same way as we did for COFF. Now, if you have a path that you want to open, just call Driver->addFile(StringRef). That function opens the file and handles that as if that were given by command line. This function is the only place we call identify_magic(). llvm-svn: 249023
-
- Sep 30, 2015
-
-
Rui Ueyama authored
This linker script parser and evaluator is powerful enough to read Linux's libc.so, which is (despite its name) a linker script that contains OUTPUT_FORMAT, GROUP and AS_NEEDED directives. The parser implemented in this patch is a recursive-descendent one. It does *not* construct an AST but consumes directives in place and sets the results to Symtab object, like what Driver is doing. This should be very fast since less objects are allocated, and this is also more readable. http://reviews.llvm.org/D13232 llvm-svn: 248918
-
Rui Ueyama authored
llvm-svn: 248877
-
- Sep 25, 2015
-
-
Rui Ueyama authored
http://reviews.llvm.org/D13148 llvm-svn: 248575
-
- Aug 14, 2015
-
-
Rafael Espindola authored
llvm-svn: 245050
-
- Aug 06, 2015
-
-
Rafael Espindola authored
llvm-svn: 244216
-
- Aug 04, 2015
-
-
Rafael Espindola authored
The writer is still hard coded to 64 bits le, but with this we can test for invalid ELF files. llvm-svn: 243993
-
- Jul 24, 2015
-
-
Michael J. Spencer authored
Differential Revision: http://reviews.llvm.org/D11188 llvm-svn: 243161
-
- Jul 14, 2015
-
-
Michael J. Spencer authored
llvm-svn: 242118
-
Michael J. Spencer authored
This is a direct port of the new PE/COFF linker to ELF. It can take a single object file and generate a valid executable that executes at the first byte in the text section. llvm-svn: 242088
-