lwp_arch_comm.h 1.6 KB

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