Skip to content
  1. Dec 07, 2017
  2. Nov 13, 2017
  3. Oct 26, 2017
    • Bob Haarman's avatar
      [lld] unified COFF and ELF error handling on new Common/ErrorHandler · b8a59c8a
      Bob Haarman authored
      Summary:
      The COFF linker and the ELF linker have long had similar but separate
      Error.h and Error.cpp files to implement error handling. This change
      introduces new error handling code in Common/ErrorHandler.h, changes the
      COFF and ELF linkers to use it, and removes the old, separate
      implementations.
      
      Reviewers: ruiu
      
      Reviewed By: ruiu
      
      Subscribers: smeenai, jyknight, emaste, sdardis, nemanjai, nhaehnle, mgorny, javed.absar, kbarton, fedor.sergeev, llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D39259
      
      llvm-svn: 316624
      b8a59c8a
  4. Oct 24, 2017
  5. Oct 03, 2017
  6. Oct 02, 2017
    • Simon Atanasyan's avatar
      [MIPS] Fix PLT entries generation in case of linking regular and microMIPS code · 649e4d32
      Simon Atanasyan authored
      Currently LLD calls the `isMicroMips` routine to determine type of PLT entries
      needs to be generated: regular or microMIPS. This routine checks ELF
      header flags in the `FirstObj` to retrieve type of linked object files.
      So if the first file does not contain microMIPS code, LLD will generate
      PLT entries with regular (non-microMIPS) code only.
      
      Ideally, if a PLT entry is referenced by microMIPS code only this entry
      should contain microMIPS code, if a PLT entry is referenced by regular
      code this entry should contain regular code. In a "mixed" case the PLT
      entry can be either microMIPS or regular, but each "cross-mode-call" has
      additional cost.
      
      It's rather difficult to implement this ideal solution. But we can
      assume that if there is an input object file with microMIPS code, the
      most part of the code is microMIPS too. So we need to deduce type of PLT
      entries based on finally calculated ELF header flags and do not check
      only the first input object file.
      
      This change implements this.
        - The `getMipsEFlags` renamed to the `calcMipsEFlags`. The function
          called from the `LinkerDriver::link`. Result is stored in
          the Configuration::MipsEFlags field.
        - The `isMicroMips` and `isMipsR6` routines access the `MipsEFlags`
          field to get and check calculated ELF flags.
        - New types of PLT records created when necessary.
      
      Differential revision: https://reviews.llvm.org/D37747
      
      llvm-svn: 314675
      649e4d32
  7. Sep 19, 2017
  8. Jul 27, 2017
    • Rui Ueyama's avatar
      Rename ObjectFile -> ObjFile. · 709fb2bb
      Rui Ueyama authored
      Rename it because it was too easy to conflict with llvm::object::ObjectFile
      which broke buildbots several times.
      
      llvm-svn: 309199
      709fb2bb
  9. Jul 26, 2017
  10. Jul 18, 2017
  11. Jun 19, 2017
  12. Jun 07, 2017
  13. Nov 05, 2016
    • Simon Atanasyan's avatar
      [ELF][MIPS] N32 ABI support · 9e0297b8
      Simon Atanasyan authored
      In short the patch introduces support for linking object file conform
      MIPS N32 ABI [1]. This ABI is similar to N64 ABI but uses 32-bit
      pointer size.
      
      The most non-trivial requirement of this ABI is one more relocation
      packing format. N64 ABI puts multiple relocation type into the single
      relocation record. The N32 ABI uses series of successive relocations
      with the same offset for this purpose. In this patch, new function
      `mergeMipsN32RelTypes` handle this case and "convert" N32 relocation to
      the N64 relocation so the rest of the code keep unchanged.
      
      For now, linker does not support series of relocations applied to sections
      without SHF_ALLOC bit. Probably later I will add the support or insert
      some sort of assert into the `relocateNonAlloc` routine to catch this
      case.
      
      [1] ftp://www.linux-mips.org/pub/linux/mips/doc/ABI/MIPS-N32-ABI-Handbook.pdf
      
      Differential revision: https://reviews.llvm.org/D26298
      
      llvm-svn: 286052
      9e0297b8
  14. Oct 04, 2016
  15. Sep 29, 2016
  16. 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
  17. Aug 12, 2016
  18. Aug 11, 2016
  19. Aug 10, 2016
    • Simon Atanasyan's avatar
      [ELF][MIPS] Take into account combination of EF_MIPS_ARCH and EF_MIPS_MACH... · 9ef1215c
      Simon Atanasyan authored
      [ELF][MIPS] Take into account combination of EF_MIPS_ARCH and EF_MIPS_MACH flags while checking ISA compatibility
      
      MIPS ISA encoded using two ELF flags: general architecture flag like
      EF_MIPS_ARCH_32, EF_MIPS_ARCH_64R6 etc and optional machine variant flag
      like EF_MIPS_MACH_4111, EF_MIPS_MACH_OCTEON3 etc. When we check
      compatibility between two input files and deduce ELF flags for generated
      output we need to take into account both of these flags.
      
      llvm-svn: 278230
      9ef1215c
  20. Aug 08, 2016
    • Rui Ueyama's avatar
      Refactor getMipsEFlags. · 31f32fa6
      Rui Ueyama authored
      Previously, we incrementally updated the reuslting flag as we check
      file flags, so it was not very clear who is updating what flags.
      This patch makes them pure functions -- that has no side effect and
      don't update arguments to improve readability.
      
      Now each function construct a patial result, and all resutls are then
      bitwise-OR'ed to construct the final result.
      
      This patch also creates a new file, Mips.cpp, to move all these
      MIPS functions to a separate file.
      
      Differential Revision: https://reviews.llvm.org/D23249
      
      llvm-svn: 278042
      31f32fa6
Loading