Skip to content
  1. Sep 29, 2016
  2. Sep 24, 2016
  3. Sep 14, 2016
    • Rui Ueyama's avatar
      Simplify InputFile ownership management. · 38dbd3ee
      Rui Ueyama authored
      Previously, all input files were owned by the symbol table.
      Files were created at various places, such as the Driver, the lazy
      symbols, or the bitcode compiler, and the ownership of new files
      was transferred to the symbol table using std::unique_ptr.
      All input files were then free'd when the symbol table is freed
      which is on program exit.
      
      I think we don't have to transfer ownership just to free all
      instance at once on exit.
      
      In this patch, all instances are automatically collected to a
      vector and freed on exit. In this way, we no longer have to
      use std::unique_ptr.
      
      Differential Revision: https://reviews.llvm.org/D24493
      
      llvm-svn: 281425
      38dbd3ee
  4. Aug 31, 2016
  5. Aug 30, 2016
  6. Jul 17, 2016
    • 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
  7. Jul 16, 2016
  8. Jul 15, 2016
  9. Jul 14, 2016
  10. Jun 22, 2016
  11. Jun 21, 2016
  12. Jun 11, 2016
  13. Jun 03, 2016
  14. Jun 01, 2016
  15. May 27, 2016
  16. May 15, 2016
  17. May 12, 2016
  18. May 11, 2016
  19. May 05, 2016
    • Peter Collingbourne's avatar
      ELF: Undefine all symbols, not just those that we expect to be defined. · 3ad1c1e2
      Peter Collingbourne authored
      This allows the combined LTO object to provide a definition with the same
      name as a symbol that was internalized without causing a duplicate symbol
      error. This normally happens during parallel codegen which externalizes
      originally-internal symbols, for example.
      
      In order to make this work, I needed to relax the undefined symbol error to
      only report an error for symbols that are used in regular objects.
      
      Differential Revision: http://reviews.llvm.org/D19954
      
      llvm-svn: 268649
      3ad1c1e2
  20. May 01, 2016
    • 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
  21. Apr 28, 2016
    • Rafael Espindola's avatar
      Use a single context for lto. · 156f4ee1
      Rafael Espindola authored
      Using multiple context used to be a really big memory saving because we
      could free memory from each file while the linker proceeded with the
      symbol resolution. We are getting lazier about reading data from the
      bitcode, so I was curious if this was still a good tradeoff.
      
      One thing that is a bit annoying is that we still have to copy the
      symbol names. The problem is that the names are stored in the Module and
      get freed when we move the module bits during linking.
      
      Long term I think the solution is to add a symbol table to the bitcode.
      That way IRObject file will not need to use a Module or a Context and we
      can drop it while still keeping a StringRef to the names.
      
      This patch is still be an interesting medium term improvement.
      
      When linking llvm-as without debug info this patch is a small speedup:
      
      master: 29.861877513 seconds
      patch: 29.814533787 seconds
      
      With debug info the numbers are
      
      master: 34.765181469 seconds
      patch: 34.563351584 seconds
      
      The peak memory usage when linking llvm-as with debug info was
      
      master: 599.10MB
      patch: 600.13MB
      llvm-svn: 267921
      156f4ee1
    • Rafael Espindola's avatar
      Sort includes. NFC. · 9fdd071d
      Rafael Espindola authored
      llvm-svn: 267821
      9fdd071d
  22. Apr 22, 2016
  23. Apr 21, 2016
  24. Apr 18, 2016
  25. Apr 16, 2016
  26. Apr 12, 2016
  27. Apr 11, 2016
Loading