mmu.h 2.2 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. * 2021-01-30 lizhirui first version
  9. */
  10. #ifndef __MMU_H__
  11. #define __MMU_H__
  12. #include "riscv.h"
  13. #include "riscv_mmu.h"
  14. struct mem_desc
  15. {
  16. rt_size_t vaddr_start;
  17. rt_size_t vaddr_end;
  18. rt_size_t paddr_start;
  19. rt_size_t attr;
  20. };
  21. #define GET_PF_ID(addr) ((addr) >> PAGE_OFFSET_BIT)
  22. #define GET_PF_OFFSET(addr) __MASKVALUE(addr,PAGE_OFFSET_MASK)
  23. #define GET_L1(addr) __PARTBIT(addr,VPN2_SHIFT,VPN2_BIT)
  24. #define GET_L2(addr) __PARTBIT(addr,VPN1_SHIFT,VPN1_BIT)
  25. #define GET_L3(addr) __PARTBIT(addr,VPN0_SHIFT,VPN0_BIT)
  26. #define GET_PPN(pte) (__PARTBIT(pte,PTE_PPN_SHIFT,PHYSICAL_ADDRESS_WIDTH_BITS - PTE_PPN_SHIFT))
  27. #define GET_PADDR(pte) (GET_PPN(pte) << PAGE_OFFSET_BIT)
  28. #define VPN_TO_PPN(vaddr,pv_off) (((rt_size_t)(vaddr)) + (pv_off))
  29. #define PPN_TO_VPN(paddr,pv_off) (((rt_size_t)(paddr)) - (pv_off))
  30. #define COMBINEVADDR(l1_off,l2_off,l3_off) (((l1_off) << VPN2_SHIFT) | ((l2_off) << VPN1_SHIFT) | ((l3_off) << VPN0_SHIFT))
  31. #define COMBINEPTE(paddr,attr) ((((paddr) >> PAGE_OFFSET_BIT) << PTE_PPN_SHIFT) | (attr))
  32. typedef struct
  33. {
  34. size_t *vtable;
  35. size_t vstart;
  36. size_t vend;
  37. size_t pv_off;
  38. }rt_mmu_info;
  39. void *rt_hw_mmu_tbl_get();
  40. void rt_hw_mmu_switch(void *mmu_table);
  41. int rt_hw_mmu_map_init(rt_mmu_info *mmu_info,void *v_address,rt_size_t size,rt_size_t *vtable,rt_size_t pv_off);
  42. void rt_hw_mmu_kernel_map_init(rt_mmu_info *mmu_info,rt_size_t vaddr_start,rt_size_t size);
  43. void *_rt_hw_mmu_map(rt_mmu_info *mmu_info,void *v_addr,void *p_addr,rt_size_t size,rt_size_t attr);
  44. void *_rt_hw_mmu_map_auto(rt_mmu_info *mmu_info,void *v_addr,rt_size_t size,rt_size_t attr);
  45. void _rt_hw_mmu_unmap(rt_mmu_info *mmu_info,void *v_addr,rt_size_t size);
  46. void *rt_hw_mmu_map(rt_mmu_info *mmu_info,void *v_addr,void *p_addr,rt_size_t size,rt_size_t attr);
  47. void *rt_hw_mmu_map_auto(rt_mmu_info *mmu_info,void *v_addr,rt_size_t size,rt_size_t attr);
  48. void rt_hw_mmu_unmap(rt_mmu_info *mmu_info,void *v_addr,rt_size_t size);
  49. void *_rt_hw_mmu_v2p(rt_mmu_info *mmu_info,void *v_addr);
  50. void *rt_hw_mmu_v2p(rt_mmu_info *mmu_info,void *v_addr);
  51. #endif