Skip to content
  1. Feb 27, 2017
  2. Feb 24, 2017
  3. Feb 23, 2017
  4. Feb 22, 2017
  5. Feb 21, 2017
    • George Rimar's avatar
      [ELF] - Postpone evaluation of LMA offset. · ae4761c1
      George Rimar authored
      Previously we evaluated the values of LMA incorrectly for next cases:
      
      .text : AT(ADDR(.text) - 0xffffffff80000000) { ... }
      .data : AT(ADDR(.data) - 0xffffffff80000000) { ... }
      .init.begin : AT(ADDR(.init.begin) - 0xffffffff80000000) { ... }
      
      Reason was that we evaluated offset when VA was not assigned. For case above
      we ended up with 3 loads that has similar LMA and it was incorrect.
      That is critical for linux kernel.
      
      Patch updates the offset after VA calculation. That fixes the issue.
      
      Differential revision: https://reviews.llvm.org/D30163
      
      llvm-svn: 295722
      ae4761c1
    • George Rimar's avatar
      [ELF] - Improve diagnostic messages for move location counter errors. · 2ee2d2dc
      George Rimar authored
      Previously LLD would error out just "ld.lld: error: unable to move location counter backward"
      What does not really reveal the place of issue,
      Patch adds location to the output.
      
      Differential revision: https://reviews.llvm.org/D30187
      
      llvm-svn: 295720
      2ee2d2dc
  6. Feb 17, 2017
    • Rafael Espindola's avatar
      Diagnose another case of the location counter moving backwards. · 679828ff
      Rafael Espindola authored
      This case should be possible to handle, but it is hard:
      
      * In order to create program headers correctly, we have to scan the
        sections in the order they are in the file.
      
      * To find that order, we have to "execute" the linker script.
      
      * The linker script can contain SIZEOF_HEADERS.
      
      So to support this we have to start with a guess of how many headers
      we need (3), run the linker script and try to create the program
      headers. If it turns out we need more headers, we run the script again
      with a larger SIZEOF_HEADERS.
      
      Also, running the linker script depends on knowing the size of the
      sections, so we have to finalize them. But creating the program
      headers can change the value stored in some sections, so we have to
      split size finalization and content finalization.
      
      Looks like the last part is also needed for range extension thunks, so
      we might support this at some point. For now just report an error
      instead of producing broken files.
      
      llvm-svn: 295458
      679828ff
    • Rafael Espindola's avatar
      Reject moving the location counter backwards. · 4cd7352c
      Rafael Espindola authored
      We were only checking when the assignment was inside a section.
      
      llvm-svn: 295454
      4cd7352c
  7. Feb 16, 2017
  8. Jan 26, 2017
  9. Jan 24, 2017
  10. Dec 22, 2016
  11. Dec 21, 2016
  12. Dec 19, 2016
  13. Dec 09, 2016
  14. Dec 08, 2016
    • Rafael Espindola's avatar
      Change the implementation of --dynamic-list to use linker script parsing. · d0ebd84c
      Rafael Espindola authored
      The feature is documented as
      -----------------------------
      The format of the dynamic list is the same as the version node
      without scope and node name.  See *note VERSION:: for more
      information.
      --------------------------------
      
      And indeed qt uses a dynamic list with an 'extern "C++"' in it. With
      this patch we support that
      
      The change to gc-sections-shared makes us match bfd. Just because we
      kept bar doesn't mean it has to be in the dynamic symbol table.
      
      The changes to invalid-dynamic-list.test and reproduce.s are because
      of the new parser.
      
      The changes to version-script.s are the only case where we change
      behavior with regards to bfd, but I would like to see a mix of
      --version-script and --dynamic-list used in the wild before
      complicating the code.
      
      llvm-svn: 289082
      d0ebd84c
  15. Dec 05, 2016
  16. Nov 28, 2016
  17. Nov 21, 2016
    • Rui Ueyama's avatar
      Add comments. · 0b1b695a
      Rui Ueyama authored
      This patch rearranges code a bit to make it easy to explain.
      
      llvm-svn: 287515
      0b1b695a
  18. Nov 19, 2016
  19. Nov 18, 2016
  20. Nov 17, 2016
    • Rui Ueyama's avatar
      Allow SIZEOF() command on nonexistent section. · edf75e79
      Rui Ueyama authored
      Linker script doesn't create a section if it has no content. So the following
      script doesn't create .norelocs section if it doesn't have any .rel* sections.
      
        .norelocs : { *(.rel*) }
      
      Later, if you assert that the size of .norelocs is 0, LLD printed out
      an error message, because it didn't allow calling SIZEOF() on nonexistent
      sections.
      
      This patch allows SIZEOF() on nonexistent sections, so that you can do
      something like this.
      
        ASSERT(SIZEOF(.norelocs), "shouldn't contain .rel sections!")
      
      Note that this behavior is compatible with GNU.
      
      Differential Revision: https://reviews.llvm.org/D26810
      
      llvm-svn: 287257
      edf75e79
  21. Nov 16, 2016
  22. Nov 14, 2016
  23. Nov 10, 2016
  24. Nov 05, 2016
  25. Nov 03, 2016
  26. Oct 31, 2016
    • Rafael Espindola's avatar
      The expr '.' is not absolute. · b0de56b5
      Rafael Espindola authored
      With this patch we keep track of the fact that . is a position in the
      file and therefore not absolute. This allow us to compute relative
      relocations that involve symbol that are defined in linker scripts
      with '.'.
      
      This fixes https://llvm.org/bugs/show_bug.cgi?id=30406
      
      There is still more work to track absoluteness over the various
      expressions, but this should unblock linking the EFI bootloader.
      
      llvm-svn: 285641
      b0de56b5
    • Rafael Espindola's avatar
      Delay computation of IsAbsolute. · 2f831dca
      Rafael Espindola authored
      We parse linker scripts very early, but whether an expression is
      absolute or not can depend on a symbol defined in a .o. Given that, we
      have to delay the computation of IsAbsolute. We can do that by storing
      an AST when parsing or by also making IsAbsolute a function like we do
      for the expression value. This patch implements the second option.
      
      llvm-svn: 285628
      2f831dca
    • Rafael Espindola's avatar
      Move IsAbsolute from SymbolAssignment to Expr. · f661393a
      Rafael Espindola authored
      And as a token of the new feature, make ALIGNOF always absolute.
      
      This is a step in making it possible to have non absolute symbols out
      of output sections.
      
      llvm-svn: 285608
      f661393a
  27. Oct 28, 2016
    • Rui Ueyama's avatar
      Consolidate BumpPtrAllocators. · 55518e7d
      Rui Ueyama authored
      Previously, we have a lot of BumpPtrAllocators, but all these
      allocators virtually have the same lifetime because they are
      not freed until the linker finishes its job. This patch aggregates
      them into a single allocator.
      
      Differential revision: https://reviews.llvm.org/D26042
      
      llvm-svn: 285452
      55518e7d
  28. Oct 14, 2016
  29. Oct 06, 2016
Loading