lwp_arch_comm.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  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. */
  9. #ifndef __LWP_ARCH_COMM__
  10. #define __LWP_ARCH_COMM__
  11. #include <mm_aspace.h>
  12. #include <rtthread.h>
  13. #include <mmu.h>
  14. /**
  15. * APIs that must port to all architectures
  16. */
  17. /* syscall handlers */
  18. void arch_clone_exit(void);
  19. void arch_fork_exit(void);
  20. void arch_syscall_exit();
  21. void arch_ret_to_user();
  22. /* ELF relocation */
  23. #ifdef ARCH_MM_MMU
  24. struct rt_lwp;
  25. void arch_elf_reloc(rt_aspace_t aspace, void *text_start, void *rel_dyn_start, size_t rel_dyn_size, void *got_start, size_t got_size, void *dynsym);
  26. #else
  27. void arch_elf_reloc(void *text_start, void *rel_dyn_start, size_t rel_dyn_size, void *got_start, size_t got_size, void *dynsym);
  28. #endif
  29. /* User entry. enter user program code for the first time */
  30. void arch_crt_start_umode(void *args, const void *text, void *ustack, void *user_stack);
  31. void arch_start_umode(void *args, const void *text, void *ustack, void *k_stack);
  32. /* lwp create and setup */
  33. int arch_set_thread_context(void (*exit)(void), void *new_thread_stack,
  34. void *user_stack, void **thread_sp);
  35. void *arch_get_user_sp(void);
  36. /* user space setup and control */
  37. int arch_user_space_init(struct rt_lwp *lwp);
  38. void arch_user_space_vtable_free(struct rt_lwp *lwp);
  39. void *arch_kernel_mmu_table_get(void);
  40. void arch_kuser_init(rt_aspace_t aspace, void *vectors);
  41. int arch_expand_user_stack(void *addr);
  42. /* thread id register */
  43. void arch_set_thread_area(void *p);
  44. void* arch_get_tidr(void);
  45. void arch_set_tidr(void *p);
  46. #endif /* __LWP_ARCH_COMM__ */