dfs_pcache.h 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. /*
  2. * Copyright (c) 2006-2025 RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2023-05-05 RTT Implement dentry in dfs v2.0
  9. */
  10. #ifndef DFS_PAGE_CACHE_H__
  11. #define DFS_PAGE_CACHE_H__
  12. #include <rtthread.h>
  13. #ifdef RT_USING_PAGECACHE
  14. #include <dfs_file.h>
  15. #include <avl.h>
  16. #ifdef __cplusplus
  17. extern "C"
  18. {
  19. #endif
  20. struct rt_varea;
  21. struct rt_aspace;
  22. struct dfs_vnode;
  23. struct dfs_dentry;
  24. struct dfs_aspace;
  25. /* Memory mapping structure for page cache */
  26. struct dfs_mmap
  27. {
  28. rt_list_t mmap_node; /* List node for address space's mmap list */
  29. struct rt_aspace *aspace; /* Address space this mapping belongs to */
  30. void *vaddr; /* Virtual address where the page is mapped */
  31. };
  32. /* Page structure for file system page cache */
  33. struct dfs_page
  34. {
  35. rt_list_t space_node; /* Node for address space's page list */
  36. rt_list_t dirty_node; /* Node for dirty page list */
  37. struct util_avl_struct avl_node; /* Node for AVL tree in address space */
  38. rt_list_t mmap_head; /* Head of memory mappings list */
  39. rt_atomic_t ref_count; /* Reference count for this page */
  40. void *page; /* Pointer to physical page data */
  41. off_t fpos; /* File position this page represents */
  42. size_t size; /* Total size of the page */
  43. size_t len; /* Valid data length in the page */
  44. int is_dirty; /* Dirty flag indicating if page needs writeback */
  45. rt_tick_t tick_ms; /* Last access timestamp */
  46. struct dfs_aspace *aspace; /* Address space this page belongs to */
  47. };
  48. /* Address space operations interface */
  49. struct dfs_aspace_ops
  50. {
  51. ssize_t (*read)(struct dfs_file *file, struct dfs_page *page); /* Read operation for page cache */
  52. ssize_t (*write)(struct dfs_page *page); /* Write operation for page cache */
  53. };
  54. /* Address space structure for page cache management */
  55. struct dfs_aspace
  56. {
  57. rt_list_t hash_node, cache_node; /* Nodes for hash table and cache lists */
  58. char *fullpath, *pathname; /* Full path and relative path strings */
  59. struct dfs_mnt *mnt; /* Mount point this space belongs to */
  60. rt_list_t list_active, list_inactive; /* Active and inactive page lists */
  61. rt_list_t list_dirty; /* Dirty page list */
  62. size_t pages_count; /* Total pages in this space */
  63. struct util_avl_root avl_root; /* AVL tree root for page lookup */
  64. struct dfs_page *avl_page; /* Current AVL tree page */
  65. rt_bool_t is_active; /* Active/inactive status flag */
  66. struct rt_mutex lock; /* Mutex for thread safety */
  67. rt_atomic_t ref_count; /* Reference counter */
  68. struct dfs_vnode *vnode; /* Associated vnode */
  69. const struct dfs_aspace_ops *ops; /* Operations interface */
  70. };
  71. #ifndef RT_PAGECACHE_HASH_NR
  72. #define RT_PAGECACHE_HASH_NR 1024
  73. #endif
  74. /* Global page cache management structure */
  75. struct dfs_pcache
  76. {
  77. rt_list_t head[RT_PAGECACHE_HASH_NR]; /* Hash table buckets for address spaces */
  78. rt_list_t list_active, list_inactive; /* Active and inactive space lists */
  79. rt_atomic_t pages_count; /* Total cached pages count */
  80. struct rt_mutex lock; /* Global lock for thread safety */
  81. struct rt_messagequeue *mqueue; /* Message queue for sending GC/WB command.*/
  82. rt_tick_t last_time_wb; /* Last writeback timestamp */
  83. };
  84. struct dfs_aspace *dfs_aspace_create(struct dfs_dentry *dentry, struct dfs_vnode *vnode, const struct dfs_aspace_ops *ops);
  85. int dfs_aspace_destroy(struct dfs_aspace *aspace);
  86. int dfs_aspace_read(struct dfs_file *file, void *buf, size_t count, off_t *pos);
  87. int dfs_aspace_write(struct dfs_file *file, const void *buf, size_t count, off_t *pos);
  88. int dfs_aspace_flush(struct dfs_aspace *aspace);
  89. int dfs_aspace_clean(struct dfs_aspace *aspace);
  90. void *dfs_aspace_mmap(struct dfs_file *file, struct rt_varea *varea, void *vaddr);
  91. int dfs_aspace_unmap(struct dfs_file *file, struct rt_varea *varea);
  92. int dfs_aspace_page_unmap(struct dfs_file *file, struct rt_varea *varea, void *vaddr);
  93. int dfs_aspace_page_dirty(struct dfs_file *file, struct rt_varea *varea, void *vaddr);
  94. off_t dfs_aspace_fpos(struct rt_varea *varea, void *vaddr);
  95. void *dfs_aspace_vaddr(struct rt_varea *varea, off_t fpos);
  96. int dfs_aspace_mmap_read(struct dfs_file *file, struct rt_varea *varea, void *data);
  97. int dfs_aspace_mmap_write(struct dfs_file *file, struct rt_varea *varea, void *data);
  98. void dfs_pcache_release(size_t count);
  99. void dfs_pcache_unmount(struct dfs_mnt *mnt);
  100. void dfs_pcache_clean(struct dfs_mnt *mnt);
  101. #ifdef __cplusplus
  102. }
  103. #endif
  104. #endif
  105. #endif