dl-startup.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /*
  2. * Architecture specific code used by dl-startup.c
  3. */
  4. /* This code fixes the stack pointer so that the dynamic linker
  5. * can find argc, argv and auxvt (Auxillary Vector Table). */
  6. #ifdef __arch_v32
  7. __asm__("" \
  8. " .text\n" \
  9. " .globl _start\n" \
  10. " .type _start,@function\n" \
  11. " .hidden _start\n" \
  12. "_start:\n" \
  13. " move.d $sp,$r10\n" \
  14. " lapc _dl_start,$r9\n" \
  15. " jsr $r9\n" \
  16. " nop\n" \
  17. " moveq 0,$r8\n" \
  18. " jump $r10\n" \
  19. " move $r8,$srp\n" \
  20. " .size _start,.-_start\n" \
  21. " .previous\n" \
  22. );
  23. #else
  24. __asm__("" \
  25. " .text\n" \
  26. " .globl _start\n" \
  27. " .type _start,@function\n" \
  28. " .hidden _start\n" \
  29. "_start:\n" \
  30. " move.d $sp,$r10\n" \
  31. " move.d $pc,$r9\n" \
  32. " add.d _dl_start - ., $r9\n" \
  33. " jsr $r9\n" \
  34. " moveq 0,$r8\n" \
  35. " move $r8,$srp\n" \
  36. " jump $r10\n" \
  37. " .size _start,.-_start\n" \
  38. " .previous\n" \
  39. );
  40. #endif /* __arch_v32 */
  41. /* Get a pointer to the argv array. On many platforms this can be just
  42. * the address of the first argument, on other platforms we need to
  43. * do something a little more subtle here. */
  44. #define GET_ARGV(ARGVP, ARGS) ARGVP = (((unsigned long *) ARGS)+1)
  45. /* We can't call functions earlier in the dl startup process */
  46. #define NO_FUNCS_BEFORE_BOOTSTRAP
  47. /* Handle relocation of the symbols in the dynamic loader. */
  48. static __always_inline
  49. void PERFORM_BOOTSTRAP_RELOC(ELF_RELOC *rpnt, unsigned long *reloc_addr,
  50. unsigned long symbol_addr, unsigned long load_addr, Elf32_Sym *symtab)
  51. {
  52. switch (ELF_R_TYPE(rpnt->r_info)) {
  53. case R_CRIS_GLOB_DAT:
  54. case R_CRIS_JUMP_SLOT:
  55. case R_CRIS_32:
  56. *reloc_addr = symbol_addr;
  57. break;
  58. case R_CRIS_16_PCREL:
  59. *(short *) *reloc_addr = symbol_addr + rpnt->r_addend - *reloc_addr - 2;
  60. break;
  61. case R_CRIS_32_PCREL:
  62. *reloc_addr = symbol_addr + rpnt->r_addend - *reloc_addr - 4;
  63. break;
  64. case R_CRIS_NONE:
  65. break;
  66. case R_CRIS_RELATIVE:
  67. *reloc_addr = load_addr + rpnt->r_addend;
  68. break;
  69. default:
  70. _dl_exit(1);
  71. break;
  72. }
  73. }