Skip to content
  1. Feb 22, 2017
  2. Jan 12, 2017
  3. Nov 24, 2016
  4. Nov 23, 2016
    • Rui Ueyama's avatar
      Limit default maximum number of errors to 20. · ac95f6bf
      Rui Ueyama authored
      This is in the context of https://llvm.org/bugs/show_bug.cgi?id=31109.
      When LLD prints out errors for relocations, it tends to print out
      extremely large number of errors (like millions) because it would
      print out one error per relocation.
      
      This patch makes LLD bail out if it prints out more than 20 errors.
      You can configure the limitation using -error-limit argument.
      -error-limit=0 means no limit.
      
      I chose the flag name because Clang has the same feature as -ferror-limit.
      "f" doesn't make sense to us, so I omitted it.
      
      Differential Revision: https://reviews.llvm.org/D26981
      
      llvm-svn: 287789
      ac95f6bf
  5. Nov 16, 2016
  6. Nov 12, 2016
  7. Oct 27, 2016
    • Rafael Espindola's avatar
      Use fewer allocators. · a8631e38
      Rafael Espindola authored
      Instead of having 3 section allocators per file, have 3 for all files.
      
      This is a substantial performance improvement for some cases. Linking
      chromium without gc speeds up by 1.065x.
      
      This requires using _exit in fatal since we have to avoid destructing
      an InputSection if fatal is called from the constructor.
      
      Thanks to Rui for the suggestion.
      
      llvm-svn: 285290
      a8631e38
  8. Oct 19, 2016
  9. Oct 07, 2016
  10. Oct 06, 2016
  11. Sep 29, 2016
  12. Sep 16, 2016
  13. Jul 15, 2016
  14. Jul 14, 2016
  15. Jun 29, 2016
  16. May 04, 2016
  17. May 03, 2016
    • Rafael Espindola's avatar
      Produce cpio files for --reproduce. · 1dd2b3d1
      Rafael Espindola authored
      We want --reproduce to
      
      * not rewrite scripts and thin archives
      * work with absolute paths
      
      Given that, it pretty much has to create a full directory tree. On windows that
      is problematic because of the very short maximum path limit. On most cases
      users can still work around it with "--repro c:\r", but that is annoying and
      not viable for automated testing.
      
      We then need to produce some form of archive with the files. The first option
      that comes to mind is .a files since we already have code for writing them.
      There are a few problems with them
      
      The format has a dedicated string table, so we cannot start writing it until
      all members are known.
      Regular implementations don't support creating directories. We could make
      llvm-ar support that, but that is probably not a good idea.
      The next natural option would be tar. The problem is that to support long path
      names (which is how this started) it needs a "pax extended header" making this
      an annoying format to write.
      
      The next option I looked at seems a natural fit: cpio files.
      
      They are available on pretty much every unix, support directories and long path
      names and are really easy to write. The only slightly annoying part is a
      terminator, but at least gnu cpio only prints a warning if it is missing, which
      is handy for crashes. This patch still makes an effort to always create it.
      
      llvm-svn: 268404
      1dd2b3d1
  18. Apr 20, 2016
  19. Mar 13, 2016
    • Rui Ueyama's avatar
      Remove dead code. · 860b13fc
      Rui Ueyama authored
      llvm-svn: 263363
      860b13fc
    • Rui Ueyama's avatar
      Do not return a bool value from error(). · 6eafa7fb
      Rui Ueyama authored
      error returned true if there was an error. This allows us to replace
      the code like this
      
        if (EC) {
          error(EC, "something failed");
          return;
        }
      
      with
      
        if (error(EC, "something failed"))
          return;
      
      I thought that that was a good idea, but it turned out that we only
      have two places to use this pattern. So this patch removes that feature.
      
      llvm-svn: 263362
      6eafa7fb
  20. Mar 03, 2016
  21. Feb 28, 2016
  22. Feb 25, 2016
  23. Feb 02, 2016
  24. Feb 01, 2016
  25. Jan 29, 2016
Loading