riscv_mmu.h 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  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. * 2021-05-03 lizhirui porting to c906
  10. */
  11. #ifndef __RISCV_MMU_H__
  12. #define __RISCV_MMU_H__
  13. #include <rthw.h>
  14. #include <rtthread.h>
  15. #include "riscv.h"
  16. #undef PAGE_SIZE
  17. /* C-SKY extend */
  18. #define PTE_SEC (1UL << 59) /* Security */
  19. #define PTE_SHARE (1UL << 60) /* Shareable */
  20. #define PTE_BUF (1UL << 61) /* Bufferable */
  21. #define PTE_CACHE (1UL << 62) /* Cacheable */
  22. #define PTE_SO (1UL << 63) /* Strong Order */
  23. #define PAGE_OFFSET_SHIFT 0
  24. #define PAGE_OFFSET_BIT 12
  25. #define PAGE_SIZE __SIZE(PAGE_OFFSET_BIT)
  26. #define PAGE_OFFSET_MASK __MASK(PAGE_OFFSET_BIT)
  27. #define VPN0_SHIFT (PAGE_OFFSET_SHIFT + PAGE_OFFSET_BIT)
  28. #define VPN0_BIT 9
  29. #define VPN1_SHIFT (VPN0_SHIFT + VPN0_BIT)
  30. #define VPN1_BIT 9
  31. #define VPN2_SHIFT (VPN1_SHIFT + VPN1_BIT)
  32. #define VPN2_BIT 9
  33. #define PPN0_SHIFT (PAGE_OFFSET_SHIFT + PAGE_OFFSET_BIT)
  34. #define PPN0_BIT 9
  35. #define PPN1_SHIFT (PPN0_SHIFT + PPN0_BIT)
  36. #define PPN1_BIT 9
  37. #define PPN2_SHIFT (PPN1_SHIFT + PPN1_BIT)
  38. #define PPN2_BIT 26
  39. #define L1_PAGE_SIZE __SIZE(PAGE_OFFSET_BIT + VPN0_BIT + VPN1_BIT)
  40. #define L2_PAGE_SIZE __SIZE(PAGE_OFFSET_BIT + VPN0_BIT)
  41. #define L3_PAGE_SIZE __SIZE(PAGE_OFFSET_BIT)
  42. #define ARCH_ADDRESS_WIDTH_BITS 64
  43. #define PHYSICAL_ADDRESS_WIDTH_BITS 56
  44. #define PAGE_ATTR_NEXT_LEVEL (0)
  45. #define PAGE_ATTR_RWX (PTE_X | PTE_W | PTE_R)
  46. #define PAGE_ATTR_READONLY (PTE_R)
  47. #define PAGE_ATTR_READEXECUTE (PTE_X | PTE_R)
  48. #define PAGE_ATTR_USER (PTE_U)
  49. #define PAGE_ATTR_SYSTEM (0)
  50. #define PAGE_DEFAULT_ATTR_LEAF (PAGE_ATTR_RWX | PAGE_ATTR_USER | PTE_V | PTE_G | PTE_SHARE | PTE_BUF | PTE_CACHE | PTE_A | PTE_D)
  51. #define PAGE_DEFAULT_ATTR_NEXT (PAGE_ATTR_NEXT_LEVEL | PTE_V | PTE_G | PTE_SHARE | PTE_BUF | PTE_CACHE | PTE_A | PTE_D)
  52. #define PAGE_IS_LEAF(pte) __MASKVALUE(pte,PAGE_ATTR_RWX)
  53. #define PTE_USED(pte) __MASKVALUE(pte,PTE_V)
  54. #define mmu_flush_tlb() do{asm volatile("sfence.vma x0,x0");}while(0)
  55. //compatible to rt-smart new version
  56. #define MMU_MAP_K_DEVICE (PAGE_ATTR_RWX | PTE_V | PTE_G | PTE_SO | PTE_BUF | PTE_A | PTE_D)
  57. #define MMU_MAP_K_RWCB (PAGE_ATTR_RWX | PTE_V | PTE_G | PTE_SHARE | PTE_BUF | PTE_CACHE | PTE_A | PTE_D)
  58. #define ARCH_PAGE_SIZE PAGE_SIZE
  59. #define ARCH_PAGE_MASK (ARCH_PAGE_SIZE - 1)
  60. #define ARCH_PAGE_SHIFT PAGE_OFFSET_BIT
  61. void mmu_set_pagetable(rt_ubase_t addr);
  62. void mmu_enable_user_page_access();
  63. void mmu_disable_user_page_access();
  64. #endif