dfs_vnode.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  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 Bernard Implement vnode in dfs v2.0
  9. */
  10. #include <dfs_file.h>
  11. #include <dfs_mnt.h>
  12. #define DBG_TAG "DFS.vnode"
  13. #define DBG_LVL DBG_WARNING
  14. #include <rtdbg.h>
  15. int dfs_vnode_init(struct dfs_vnode *vnode, int type, const struct dfs_file_ops *fops)
  16. {
  17. if (vnode)
  18. {
  19. rt_memset(vnode, 0, sizeof(struct dfs_vnode));
  20. vnode->type = type;
  21. rt_atomic_store(&(vnode->ref_count), 1);
  22. vnode->mnt = RT_NULL;
  23. vnode->fops = fops;
  24. }
  25. return 0;
  26. }
  27. struct dfs_vnode *dfs_vnode_create(void)
  28. {
  29. struct dfs_vnode *vnode = rt_calloc(1, sizeof(struct dfs_vnode));
  30. if (!vnode)
  31. {
  32. LOG_E("create a vnode failed.");
  33. return RT_NULL;
  34. }
  35. rt_atomic_store(&(vnode->ref_count), 1);
  36. LOG_I("create a vnode: %p", vnode);
  37. return vnode;
  38. }
  39. int dfs_vnode_destroy(struct dfs_vnode* vnode)
  40. {
  41. rt_err_t ret = RT_EOK;
  42. if (vnode)
  43. {
  44. ret = dfs_file_lock();
  45. if (ret == RT_EOK)
  46. {
  47. if (rt_atomic_load(&(vnode->ref_count)) == 1)
  48. {
  49. LOG_I("free a vnode: %p", vnode);
  50. if (vnode->mnt)
  51. {
  52. DLOG(msg, "vnode", vnode->mnt->fs_ops->name, DLOG_MSG, "fs_ops->free_vnode");
  53. vnode->mnt->fs_ops->free_vnode(vnode);
  54. }
  55. else
  56. {
  57. DLOG(msg, "vnode", "vnode", DLOG_MSG, "destroy vnode(mnt=NULL)");
  58. }
  59. dfs_file_unlock();
  60. rt_free(vnode);
  61. }
  62. else
  63. {
  64. dfs_file_unlock();
  65. }
  66. }
  67. }
  68. return 0;
  69. }
  70. struct dfs_vnode *dfs_vnode_ref(struct dfs_vnode *vnode)
  71. {
  72. if (vnode)
  73. {
  74. rt_atomic_add(&(vnode->ref_count), 1);
  75. DLOG(note, "vnode", "vnode ref_count=%d", rt_atomic_load(&(vnode->ref_count)));
  76. }
  77. return vnode;
  78. }
  79. void dfs_vnode_unref(struct dfs_vnode *vnode)
  80. {
  81. rt_err_t ret = RT_EOK;
  82. if (vnode)
  83. {
  84. ret = dfs_file_lock();
  85. if (ret == RT_EOK)
  86. {
  87. rt_atomic_sub(&(vnode->ref_count), 1);
  88. DLOG(note, "vnode", "vnode ref_count=%d", rt_atomic_load(&(vnode->ref_count)));
  89. if (rt_atomic_load(&(vnode->ref_count)) == 0)
  90. {
  91. LOG_I("free a vnode: %p", vnode);
  92. DLOG(msg, "vnode", "vnode", DLOG_MSG, "free vnode, ref_count=0");
  93. if (vnode->mnt)
  94. {
  95. DLOG(msg, "vnode", vnode->mnt->fs_ops->name, DLOG_MSG, "fs_ops->free_vnode");
  96. vnode->mnt->fs_ops->free_vnode(vnode);
  97. }
  98. dfs_file_unlock();
  99. rt_free(vnode);
  100. }
  101. else
  102. {
  103. dfs_file_unlock();
  104. DLOG(note, "vnode", "vnode ref_count=%d", rt_atomic_load(&(vnode->ref_count)));
  105. }
  106. }
  107. }
  108. return;
  109. }