dfs_pcache.h 2.8 KB

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