lwp_user_mm.h 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. /*
  2. * Copyright (c) 2006-2020, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2019-10-28 Jesven first version
  9. * 2021-02-12 lizhirui add 64-bit support for lwp_brk
  10. */
  11. #ifndef __LWP_USER_MM_H__
  12. #define __LWP_USER_MM_H__
  13. #include <rthw.h>
  14. #include <rtthread.h>
  15. #ifdef ARCH_MM_MMU
  16. #include <lwp.h>
  17. #include <mmu.h>
  18. #include <mm_aspace.h>
  19. #include <mm_fault.h>
  20. #include <mm_page.h>
  21. #ifdef __cplusplus
  22. extern "C" {
  23. #endif
  24. #define LWP_MAP_FLAG_NONE 0x0000
  25. #define LWP_MAP_FLAG_NOCACHE 0x0001
  26. int lwp_user_space_init(struct rt_lwp *lwp, rt_bool_t is_fork);
  27. void lwp_unmap_user_space(struct rt_lwp *lwp);
  28. int lwp_unmap_user(struct rt_lwp *lwp, void *va);
  29. void *lwp_map_user(struct rt_lwp *lwp, void *map_va, size_t map_size, rt_bool_t text);
  30. rt_varea_t lwp_map_user_varea(struct rt_lwp *lwp, void *map_va, size_t map_size);
  31. /* check LWP_MAP_FLAG_* */
  32. rt_varea_t lwp_map_user_varea_ext(struct rt_lwp *lwp, void *map_va, size_t map_size, size_t flags);
  33. void *lwp_map_user_phy(struct rt_lwp *lwp, void *map_va, void *map_pa, size_t map_size, rt_bool_t cached);
  34. int lwp_unmap_user_phy(struct rt_lwp *lwp, void *va);
  35. rt_base_t lwp_brk(void *addr);
  36. void* lwp_mmap2(void *addr, size_t length, int prot, int flags, int fd, off_t pgoffset);
  37. int lwp_munmap(void *addr);
  38. size_t lwp_get_from_user(void *dst, void *src, size_t size);
  39. size_t lwp_put_to_user(void *dst, void *src, size_t size);
  40. int lwp_user_accessable(void *addr, size_t size);
  41. size_t lwp_data_get(struct rt_lwp *lwp, void *dst, void *src, size_t size);
  42. size_t lwp_data_put(struct rt_lwp *lwp, void *dst, void *src, size_t size);
  43. void lwp_data_cache_flush(struct rt_lwp *lwp, void *vaddr, size_t size);
  44. static inline void *_lwp_v2p(struct rt_lwp *lwp, void *vaddr)
  45. {
  46. return rt_hw_mmu_v2p(lwp->aspace, vaddr);
  47. }
  48. static inline void *lwp_v2p(struct rt_lwp *lwp, void *vaddr)
  49. {
  50. RD_LOCK(lwp->aspace);
  51. void *paddr = _lwp_v2p(lwp, vaddr);
  52. RD_UNLOCK(lwp->aspace);
  53. return paddr;
  54. }
  55. #ifdef __cplusplus
  56. }
  57. #endif
  58. #endif
  59. #endif /*__LWP_USER_MM_H__*/