dl-startup.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. /*
  2. * Copyright (C) 2013 Imagination Technologies Ltd.
  3. *
  4. * Licensed under the LGPL v2.1 or later, see the file COPYING.LIB in this tarball.
  5. */
  6. /*
  7. * This code fixes the stack pointer so that the dynamic linker
  8. * can find argc, argv and auxvt (Auxillary Vector Table).
  9. */
  10. __asm__ (
  11. " .text\n"
  12. " .global __start\n"
  13. " .type __start,@function\n"
  14. " .hidden __start\n"
  15. "_start:\n"
  16. "__start:\n"
  17. " MSETL [A0StP++],D0Ar4,D0Ar2\n"
  18. " MOV D1Ar1,D0Ar2\n"
  19. " CALLR D1RtP,__dl_start\n"
  20. " GETL D0Ar2,D1Ar1,[A0StP+#-(1*8)]\n"
  21. " GETL D0Ar4,D1Ar3,[A0StP+#-(2*8)]\n"
  22. " SUB A0StP,A0StP,#(2*8)\n"
  23. " MOV PC,D0Re0\n"
  24. " .size __start,.-__start\n"
  25. " .previous\n"
  26. );
  27. /*
  28. * Get a pointer to the argv array. On many platforms this can be just
  29. * the address if the first argument, on other platforms we need to
  30. * do something a little more subtle here.
  31. */
  32. #define GET_ARGV(ARGVP, ARGS) ARGVP = (((unsigned long *) ARGS))
  33. /* Handle relocation of the symbols in the dynamic loader. */
  34. static inline
  35. void PERFORM_BOOTSTRAP_RELOC(ELF_RELOC *rpnt, unsigned long *reloc_addr,
  36. unsigned long symbol_addr, unsigned long load_addr, Elf32_Sym *symtab)
  37. {
  38. switch (ELF32_R_TYPE(rpnt->r_info)) {
  39. case R_METAG_GLOB_DAT:
  40. case R_METAG_JMP_SLOT:
  41. case R_METAG_ADDR32:
  42. *reloc_addr = symbol_addr;
  43. break;
  44. case R_METAG_RELATIVE:
  45. *reloc_addr = load_addr + rpnt->r_addend;
  46. break;
  47. case R_METAG_RELBRANCH:
  48. *reloc_addr = symbol_addr + rpnt->r_addend - *reloc_addr - 4;
  49. break;
  50. case R_METAG_NONE:
  51. break;
  52. default:
  53. _dl_exit(1);
  54. break;
  55. }
  56. }