Skip to content
Snippets Groups Projects
  1. Apr 19, 2020
    • Ahmed Abd El Mawgood's avatar
      Implement code that use .init_array and .fini_array · 6aeb2d6f
      Ahmed Abd El Mawgood authored
      This patch implements ld.so code that makes use of both .init_array and
      .fini_array. .init_array is fully utilized and is used in the correct
      manner. However .fini_array is not used yet although the function that
      runs .fini_array exists
      6aeb2d6f
    • Ahmed Abd El Mawgood's avatar
      Catch circular dependency when resolving loading shared libraries · cc7ff54d
      Ahmed Abd El Mawgood authored
      This patch implements tree-based data-structure for catching circular
      dependency where libA.so will depen on arbitrarily long chain (including
      zero length) of libNs.so one of which will depend on libA.so again. The
      main intention of this patch was merely capturing the dependency tree to
      prioterize which Elf's .init_array and which .fini_array should run
      first, but as a side effect it can capture circular dependencies as well.
      cc7ff54d
  2. Apr 13, 2020
  3. Apr 07, 2020
    • Ahmed Abd El Mawgood's avatar
      Use Kernel mapped binaries when available. · cc305fc5
      Ahmed Abd El Mawgood authored
      At least in linux kernel, assuming that a.out is an elf that is linked
      against relibc's own ld.so. When a user attempts `./a.out`, Linux kernel
      will map `./a.out`, then map `ld.so` and jump into ld.so entry point.
      In relibc ld.so will simply ignore the kernel mapped a.out and create
      its own mapping. This patch forces relic ld.so to use the already mapped
      `a.out` when ever possible. This would normally have slight performance
      improvement (especially that currently relibc doesn't map a.out but
      instead copy the data into empty mmaped memory).
      
      The real motivation behind this patch is while impelemnting Runtime
      linker debugging protocol for relibc. part of the protocol is ld.so
      inseting address of some ld.so managed data structure into .dynamic
      seciton of a.out then the debugger would check it there. The thing is
      that debuggers have information about the kernel loaded ./a.out and they
      check that one specifically which is in our case totally ignored by
      relibc.
      cc305fc5
  4. Mar 08, 2020
    • Ahmed Abd El Mawgood's avatar
      Resolve Both strong and weak symbols · 4860ab12
      Ahmed Abd El Mawgood authored
      This patch keep 2 lists, one for strong symbols and one for weak
      symbols. First it will check for the symbol to be resolved in the strong
      symbols' list, if it is not there it will then check in the weak symbol
      list.
      4860ab12
  5. Mar 07, 2020
    • Ahmed Abd El Mawgood's avatar
      Refactor Linker::Link · 04ea2f93
      Ahmed Abd El Mawgood authored
      This patch does basically two things:
      - First make `global` variable not public, And make it accessable via a
      function `get_sym`.
      - Isolate the procedure that collect global symbols into single function
      that does that and call it `collect_syms`.
      
      The motivation of this patch is the second one where this procedure is
      extended, thus it needs a seamless way to access those symbols
      04ea2f93
  6. Feb 29, 2020
  7. Feb 24, 2020
  8. Dec 19, 2019
  9. Dec 18, 2019
  10. Dec 17, 2019
  11. Dec 15, 2019
  12. Dec 07, 2019
  13. Dec 01, 2019
  14. Aug 04, 2019
  15. Jul 04, 2019
  16. May 11, 2019
  17. Apr 21, 2019
  18. Apr 15, 2019
  19. Apr 14, 2019
  20. Apr 13, 2019
Loading