Skip to content
  1. Jul 17, 2016
    • Rui Ueyama's avatar
      Remove duplicate public specifier. · bef5d16a
      Rui Ueyama authored
      llvm-svn: 275714
      bef5d16a
    • Rui Ueyama's avatar
      Print out file names for common symbols for --trace-symbol. · 2a7c1c15
      Rui Ueyama authored
      Previously, there was no way to get a file name for a DefinedCommon
      symbol. This patch adds it.
      
      llvm-svn: 275712
      2a7c1c15
    • Rui Ueyama's avatar
      Handle versioned symbols efficiently. · 663b8c27
      Rui Ueyama authored
      Versions can be assigned to symbols in two different ways.
      One is the usual version scripts, and the other is special
      symbol suffix '@'. If a symbol contains '@', the string after
      that is considered to specify a version name.
      
      Previously, we look for '@' for all symbols.
      
      Anything that works on every symbol can be expensive because
      the linker has to handle a lot of symbols. The search for '@'
      was not an exception.
      
      In this patch, I made two optimizations.
      
      The first optimization is to handle '@' only when at least one
      version is defined. If no versions are defined, no versions can
      be assigned to any symbols, so it's waste of time to search for '@'.
      
      The second optimization is to scan only suffixes of symbol names
      instead of entire symbol names. Symbol names can be very long, but
      symbol versions are usually short, so scanning entire symbol names
      is waste of time, too.
      
      There are some error cases which we no longer be able to detect
      with this patch. I don't think it's a major drawback because they
      are minor errors. Speed is more important.
      
      This change improves LLD with debug info self-link time from
      6.6993 seconds to 6.3426 seconds (or -5.3%).
      
      Differential Revision: https://reviews.llvm.org/D22433
      
      llvm-svn: 275711
      663b8c27
    • Rui Ueyama's avatar
      Add a pointer to a source file to SymbolBody. · 434b5617
      Rui Ueyama authored
      Previously, each subclass of SymbolBody had a pointer to a source
      file from which it was created. So, there was no single way to get
      a source file for a symbol. We had getSourceFile<ELFT>(), but the
      function was a bit inconvenient as it's a template.
      
      This patch makes SymbolBody have a pointer to a source file.
      If a symbol is not created from a file, the pointer has a nullptr.
      
      llvm-svn: 275701
      434b5617
  2. Jul 16, 2016
    • Rui Ueyama's avatar
      Rename Version VersionDefinition. · bc94dd9b
      Rui Ueyama authored
      The identifier `Version` was used too often in the code to handle
      symbol versions. The struct that contains version definitions is
      named `Version`. Local variables for version ID are named `Version`.
      Local varaible for version string are named `Version`.
      
      This patch give them different names.
      
      llvm-svn: 275673
      bc94dd9b
  3. Jul 08, 2016
    • Rui Ueyama's avatar
      Attempt to fix buildbots. · 8c8db476
      Rui Ueyama authored
      llvm-svn: 274917
      8c8db476
    • Rafael Espindola's avatar
      fix use of uninitialized. · 6091492e
      Rafael Espindola authored
      llvm-svn: 274909
      6091492e
    • Rui Ueyama's avatar
      Fix memory leak. · 8b8d0055
      Rui Ueyama authored
      Symbol's dtors are not called because they are allocated using
      BumpPtrAllocators. So, members of std::unique_ptr type are not
      freed when symbols are deallocated.
      
      This patch is to allocate Thunks using BumpPtrAllocators.
      
      llvm-svn: 274896
      8b8d0055
    • Peter Smith's avatar
      Recommit R274836 Add Thunk support framework for ARM and Mips · fb05cd99
      Peter Smith authored
      The TinyPtrVector of const Thunk<ELFT>* in InputSections.h can cause 
      build failures on certain compiler/library combinations when Thunk<ELFT> 
      is not a complete type or is an abstract class. Fixed by making Thunk<ELFT>
      non Abstract.
      
      type or is an abstract class 
      
      llvm-svn: 274863
      fb05cd99
    • Peter Smith's avatar
      Revert R274836 Add Thunk support framework for ARM and Mips · eeb82744
      Peter Smith authored
      This seems to be causing a buildbot failure on lld-x86_64-freebsd. Will
      reproduce locally and fix. 
      
      llvm-svn: 274841
      eeb82744
    • Peter Smith's avatar
      Add Thunk support framework for ARM and Mips · de01b98a
      Peter Smith authored
          
          Generalise the Mips LA25 Thunk code and implement ARM and Thumb
          interworking Thunks.
          
          - Introduce a new module Thunks.cpp to store the Target Specific Thunk
            implementations.
          - DefinedRegular and Shared have a ThunkData field to record Thunk.
          - A Target can have more than one type of Thunk.
          - Support PC-relative calls to Thunks.
          - Support Thunks to PLT entries.
          - Existing Mips LA25 Thunk code integrated.
          - Support for ARMv7A interworking Thunks.
          
          Limitations:
          - Only one Thunk per SymbolBody, this is sufficient for all currently
            implemented Thunks.
          - ARM thunks assume presence of V6T2 MOVT and MOVW instructions.
      
          Differential revision: http://reviews.llvm.org/D21891
      
      llvm-svn: 274836
      de01b98a
    • Rui Ueyama's avatar
      Move demangle() from Symbols.cpp to Strings.cpp. · f4d9338d
      Rui Ueyama authored
      Symbols.cpp contains functions to handle ELF symbols.
      demangle() function is essentially a function to work on a
      string rather than on an ELF symbol. So Strings.cpp is a
      better place to put that function.
      
      This change also make demangle to demangle symbols unconditionally.
      Previously, it demangled symbols only when Config->Demangle is true.
      
      llvm-svn: 274804
      f4d9338d
  4. Jun 28, 2016
    • George Rimar's avatar
      [ELF] - Implemented support of default/non-default symbols versions · 43651586
      George Rimar authored
      t is possible to create new version of symbol instead of depricated one
      using combination of version script and asm commands. For example:
      
      __asm__(".symver b_1,b@LIBSAMPLE_1.0");
      int b_1() { return 10; }
      __asm__(".symver b_2,b@@LIBSAMPLE_2.0");
      int b_2() { return 20; }
      
      This code makes b_2() to be default implementation for b().
      b_1() is used for compatibility with binaries compiled against
      library of older version LIBSAMPLE_1.0.
      
      This patch implements support for above functionality in lld.
      
      Differential revision: http://reviews.llvm.org/D21681
      
      llvm-svn: 274002
      43651586
  5. Jun 20, 2016
  6. Jun 19, 2016
    • Simon Atanasyan's avatar
      [ELF][MIPS] Support GOT entries for non-preemptible symbols with different addends · 4132511c
      Simon Atanasyan authored
      There are two motivations for this patch. The first one is a preparation
      for support MIPS TLS relocations. It might sound like a joke but for GOT
      entries related to TLS relocations MIPS ABI uses almost regular approach
      with creation of dynamic relocations for each GOT enty etc. But we need
      to separate these 'regular' TLS related entries from MIPS specific local
      and global parts of GOT. ABI declare simple solution - all TLS related
      entries allocated at the end of GOT after local/global parts. The second
      motivation it to support GOT relocations for non-preemptible symbols
      with addends. If we have more than one GOT relocations against symbol S
      with different addends we need to create GOT entries for each unique
      Symbol/Addend pairs.
      
      So we store all MIPS GOT entries in separate containers. For non-preemptible
      symbols we have to maintain two data structures. The first one is MipsLocal
      vector. Each entry corresponds to the GOT entry from the 'local' part
      of the GOT contains the symbol's address plus addend. The second one
      is MipsLocalMap. It is a map from Symbol/Addend pair to the GOT index.
      
      Differential Revision: http://reviews.llvm.org/D21297
      
      llvm-svn: 273127
      4132511c
  7. Jun 14, 2016
  8. Jun 05, 2016
  9. May 24, 2016
  10. May 03, 2016
  11. May 02, 2016
  12. May 01, 2016
    • Peter Collingbourne's avatar
      Further MSVC appeasement. · f643fc10
      Peter Collingbourne authored
      llvm-svn: 268185
      f643fc10
    • Peter Collingbourne's avatar
      Try to fix MSVC build. · 6e862bbf
      Peter Collingbourne authored
      llvm-svn: 268182
      6e862bbf
    • Peter Collingbourne's avatar
      ELF: New symbol table design. · 4f952706
      Peter Collingbourne authored
      This patch implements a new design for the symbol table that stores
      SymbolBodies within a memory region of the Symbol object. Symbols are mutated
      by constructing SymbolBodies in place over existing SymbolBodies, rather
      than by mutating pointers. As mentioned in the initial proposal [1], this
      memory layout helps reduce the cache miss rate by improving memory locality.
      
      Performance numbers:
      
                 old(s) new(s)
      Without debug info:
      chrome      7.178  6.432 (-11.5%)
      LLVMgold.so 0.505  0.502 (-0.5%)
      clang       0.954  0.827 (-15.4%)
      llvm-as     0.052  0.045 (-15.5%)
      With debug info:
      scylla      5.695  5.613 (-1.5%)
      clang      14.396 14.143 (-1.8%)
      
      Performance counter results show that the fewer required indirections is
      indeed the cause of the improved performance. For example, when linking
      chrome, stalled cycles decreases from 14,556,444,002 to 12,959,238,310, and
      instructions per cycle increases from 0.78 to 0.83. We are also executing
      many fewer instructions (15,516,401,933 down to 15,002,434,310), probably
      because we spend less time allocating SymbolBodies.
      
      The new mechanism by which symbols are added to the symbol table is by calling
      add* functions on the SymbolTable.
      
      In this patch, I handle local symbols by storing them inside "unparented"
      SymbolBodies. This is suboptimal, but if we do want to try to avoid allocating
      these SymbolBodies, we can probably do that separately.
      
      I also removed a few members from the SymbolBody class that were only being
      used to pass information from the input file to the symbol table.
      
      This patch implements the new design for the ELF linker only. I intend to
      prepare a similar patch for the COFF linker.
      
      [1] http://lists.llvm.org/pipermail/llvm-dev/2016-April/098832.html
      
      Differential Revision: http://reviews.llvm.org/D19752
      
      llvm-svn: 268178
      4f952706
  13. Apr 28, 2016
    • Rui Ueyama's avatar
      Remove Size from Undefined symbol. · 62ee16fa
      Rui Ueyama authored
      There seems to be no reason to keep st_size of undefined symbols.
      This patch removes the member for it. This patch will change outputs
      in cases that undefined symbols are copied to output, but I think
      this is unimportant.
      
      Differential Revision: http://reviews.llvm.org/D19574
      
      llvm-svn: 267826
      62ee16fa
  14. Apr 27, 2016
  15. Apr 26, 2016
  16. Apr 22, 2016
    • Peter Collingbourne's avatar
      ELF: Implement basic support for --version-script. · 66ac1d61
      Peter Collingbourne authored
      This patch only implements support for version scripts of the form:
        { [ global: symbol1; symbol2; [...]; symbolN; ] local: *; };
      No wildcards are supported, other than for the local entry. Symbol versioning
      is also not supported.
      
      It works by introducing a new Symbol flag which tracks whether a symbol
      appears in the global section of a version script.
      
      This patch also simplifies the logic in SymbolBody::isPreemptible(), and
      teaches it to handle the case where symbols with default visibility in DSOs
      do not appear in the dynamic symbol table because of a version script.
      
      Fixes PR27482.
      
      Differential Revision: http://reviews.llvm.org/D19430
      
      llvm-svn: 267208
      66ac1d61
    • Peter Collingbourne's avatar
      ELF: Move Visibility, IsUsedInRegularObj and MustBeInDynSym flags to Symbol. · dadcc17e
      Peter Collingbourne authored
      These are properties of a symbol name, rather than a particular instance
      of a symbol in an object file. We can simplify the code by collecting these
      properties in Symbol.
      
      The MustBeInDynSym flag has been renamed ExportDynamic, as its semantics
      have been changed to be the same as those of --dynamic-list and
      --export-dynamic-symbol, which do not cause hidden symbols to be exported.
      
      Differential Revision: http://reviews.llvm.org/D19400
      
      llvm-svn: 267183
      dadcc17e
  17. Apr 21, 2016
    • Rafael Espindola's avatar
      Internalize linkonce_odr more often. · 4d480ed5
      Rafael Espindola authored
      Since there is a copy in every translation unit that uses them, they can
      be omitted from the symbol table if the address is not significant.
      
      This still doesn't catch as many cases as the gold plugin. The
      difference is that we check canBeOmittedFromSymbolTable in each file and
      use lazy loading which limits what it can do. Gold checks it in the merged file.
      
      I think the correct way of getting the same results as gold is just to
      cache in the IR the result of canBeOmittedFromSymbolTable.
      
      llvm-svn: 267063
      4d480ed5
    • Rui Ueyama's avatar
      Remove SymPair and instead use two DefinedRegulars instead. · 467dbdd0
      Rui Ueyama authored
      I noticed that I was looking for the definition of SymPair when hacking
      the Writer, only to find that it is just a pair of DefinedRegular symbols.
      I don't think it provides more values than the cost of using brainpower
      to memorize the type. I didn't roll back r266317, which introduced SymPair,
      because the patch removes code repetitions. I ported that change to new
      code.
      
      llvm-svn: 267047
      467dbdd0
    • Rafael Espindola's avatar
      Start adding support for internalizing shared libraries. · ae605c1b
      Rafael Espindola authored
      llvm-svn: 267045
      ae605c1b
  18. Apr 14, 2016
  19. Apr 13, 2016
Loading