x86.c 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2018/09/15 parai first version
  9. */
  10. #include "../dlmodule.h"
  11. #include "../dlelf.h"
  12. #ifdef __i386__
  13. #define DBG_TAG "kernel.module"
  14. #ifdef RT_DEBUG_MODULE
  15. #define DBG_LVL DBG_LOG
  16. #else
  17. #define DBG_LVL DBG_WARNING
  18. #endif /* defined (RT_DEBUG_MODULE) */
  19. #include <rtdbg.h>
  20. #define R_X86_64_GLOB_DAT 6 /* Create GOT entry */
  21. #define R_X86_64_JUMP_SLOT 7 /* Create PLT entry */
  22. #define R_X86_64_RELATIVE 8 /* Adjust by program base */
  23. int dlmodule_relocate(struct rt_dlmodule *module, Elf32_Rel *rel, Elf32_Addr sym_val)
  24. {
  25. Elf32_Addr *where, tmp;
  26. Elf32_Sword addend, offset;
  27. rt_uint32_t upper, lower, sign, j1, j2;
  28. where = (Elf32_Addr *)((rt_uint8_t *)module->mem_space
  29. + rel->r_offset
  30. - module->vstart_addr);
  31. switch (ELF32_R_TYPE(rel->r_info))
  32. {
  33. case R_X86_64_GLOB_DAT:
  34. case R_X86_64_JUMP_SLOT:
  35. *where = (Elf32_Addr)sym_val;
  36. LOG_D("R_X86_64_JUMP_SLOT: 0x%x -> 0x%x 0x%x",
  37. (uint32_t)where, *where, sym_val);
  38. break;
  39. case R_X86_64_RELATIVE:
  40. *where = (Elf32_Addr)sym_val + *where;
  41. LOG_D("R_X86_64_RELATIVE: 0x%x -> 0x%x 0x%x",
  42. (uint32_t)where, *where, sym_val);
  43. break;
  44. default:
  45. LOG_D("X86ELF: invalid relocate TYPE %d", ELF32_R_TYPE(rel->r_info));
  46. return -1;
  47. }
  48. return 0;
  49. }
  50. #endif