dfs_pcache.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. /*
  2. * Copyright (c) 2006-2023, 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. struct dfs_mmap
  26. {
  27. rt_list_t mmap_node;
  28. struct rt_aspace *aspace;
  29. void *vaddr;
  30. };
  31. struct dfs_page
  32. {
  33. rt_list_t space_node;
  34. rt_list_t dirty_node;
  35. struct util_avl_struct avl_node;
  36. rt_list_t mmap_head;
  37. rt_atomic_t ref_count;
  38. void *page;
  39. off_t fpos;
  40. size_t size;
  41. size_t len;
  42. int is_dirty;
  43. rt_tick_t tick_ms;
  44. struct dfs_aspace *aspace;
  45. };
  46. struct dfs_aspace_ops
  47. {
  48. ssize_t (*read)(struct dfs_file *file, struct dfs_page *page);
  49. ssize_t (*write)(struct dfs_page *page);
  50. };
  51. struct dfs_aspace
  52. {
  53. rt_list_t hash_node, cache_node;
  54. char *fullpath, *pathname;
  55. struct dfs_mnt *mnt;
  56. rt_list_t list_active, list_inactive;
  57. rt_list_t list_dirty;
  58. size_t pages_count;
  59. struct util_avl_root avl_root;
  60. struct dfs_page *avl_page;
  61. rt_bool_t is_active;
  62. struct rt_mutex lock;
  63. rt_atomic_t ref_count;
  64. struct dfs_vnode *vnode;
  65. const struct dfs_aspace_ops *ops;
  66. };
  67. #ifndef RT_PAGECACHE_HASH_NR
  68. #define RT_PAGECACHE_HASH_NR 1024
  69. #endif
  70. struct dfs_pcache
  71. {
  72. rt_list_t head[RT_PAGECACHE_HASH_NR];
  73. rt_list_t list_active, list_inactive;
  74. rt_atomic_t pages_count;
  75. struct rt_mutex lock;
  76. struct rt_messagequeue *mqueue;
  77. rt_tick_t last_time_wb;
  78. };
  79. struct dfs_aspace *dfs_aspace_create(struct dfs_dentry *dentry, struct dfs_vnode *vnode, const struct dfs_aspace_ops *ops);
  80. int dfs_aspace_destroy(struct dfs_aspace *aspace);
  81. int dfs_aspace_read(struct dfs_file *file, void *buf, size_t count, off_t *pos);
  82. int dfs_aspace_write(struct dfs_file *file, const void *buf, size_t count, off_t *pos);
  83. int dfs_aspace_flush(struct dfs_aspace *aspace);
  84. int dfs_aspace_clean(struct dfs_aspace *aspace);
  85. void *dfs_aspace_mmap(struct dfs_file *file, struct rt_varea *varea, void *vaddr);
  86. int dfs_aspace_unmap(struct dfs_file *file, struct rt_varea *varea);
  87. int dfs_aspace_page_unmap(struct dfs_file *file, struct rt_varea *varea, void *vaddr);
  88. int dfs_aspace_page_dirty(struct dfs_file *file, struct rt_varea *varea, void *vaddr);
  89. off_t dfs_aspace_fpos(struct rt_varea *varea, void *vaddr);
  90. void *dfs_aspace_vaddr(struct rt_varea *varea, off_t fpos);
  91. int dfs_aspace_mmap_read(struct dfs_file *file, struct rt_varea *varea, void *data);
  92. int dfs_aspace_mmap_write(struct dfs_file *file, struct rt_varea *varea, void *data);
  93. void dfs_pcache_release(size_t count);
  94. void dfs_pcache_unmount(struct dfs_mnt *mnt);
  95. void dfs_pcache_clean(struct dfs_mnt *mnt);
  96. #ifdef __cplusplus
  97. }
  98. #endif
  99. #endif
  100. #endif