luat_fskv.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. #include "luat_base.h"
  2. #include "luat_fskv.h"
  3. #include "luat_malloc.h"
  4. #include "luat_msgbus.h"
  5. #include "luat_sfd.h"
  6. #define LUAT_LOG_TAG "fskv"
  7. #include "luat_log.h"
  8. #include "lfs.h"
  9. // TODO 应该对接vfs, 而非直接对接lfs
  10. extern luat_sfd_lfs_t* sfd_lfs;
  11. int luat_fskv_del(const char* key) {
  12. lfs_remove(&sfd_lfs->lfs, key);
  13. return 0;
  14. }
  15. int luat_fskv_set(const char* key, void* data, size_t len) {
  16. lfs_file_t fd = {0};
  17. int ret = 0;
  18. ret = lfs_file_open(&sfd_lfs->lfs, &fd, key, LFS_O_WRONLY | LFS_O_CREAT | LFS_O_TRUNC);
  19. if (ret != LFS_ERR_OK) {
  20. return -1;
  21. }
  22. ret = lfs_file_write(&sfd_lfs->lfs, &fd, data, len);
  23. lfs_file_close(&sfd_lfs->lfs, &fd);
  24. return ret;
  25. }
  26. int luat_fskv_get(const char* key, void* data, size_t len) {
  27. lfs_file_t fd = {0};
  28. int ret = 0;
  29. ret = lfs_file_open(&sfd_lfs->lfs, &fd, key, LFS_O_RDONLY);
  30. if (ret != LFS_ERR_OK) {
  31. return 0;
  32. }
  33. ret = lfs_file_read(&sfd_lfs->lfs, &fd, data, len);
  34. lfs_file_close(&sfd_lfs->lfs, &fd);
  35. return ret > 0 ? ret : 0;
  36. }
  37. int luat_fskv_clear(void) {
  38. int ret = 0;
  39. ret = lfs_format(&sfd_lfs->lfs, &sfd_lfs->conf);
  40. if (ret != LFS_ERR_OK) {
  41. LLOGE("fskv clear ret %d", ret);
  42. return ret;
  43. }
  44. ret = lfs_mount(&sfd_lfs->lfs, &sfd_lfs->conf);
  45. if (ret != LFS_ERR_OK) {
  46. LLOGE("fskv reinit ret %d", ret);
  47. return ret;
  48. }
  49. return 0;
  50. }
  51. int luat_fskv_stat(size_t *using_sz, size_t *total, size_t *kv_count) {
  52. *using_sz = lfs_fs_size(&sfd_lfs->lfs) * LFS_BLOCK_DEVICE_ERASE_SIZE;
  53. *total = LFS_BLOCK_DEVICE_TOTOAL_SIZE;
  54. lfs_dir_t dir = {0};
  55. int ret = lfs_dir_open(&sfd_lfs->lfs, &dir, "");
  56. if (ret != LFS_ERR_OK) {
  57. LLOGW("lfs_dir_open ret %d", ret);
  58. return -1;
  59. }
  60. size_t count = 0;
  61. struct lfs_info info = {0};
  62. while (1) {
  63. ret = lfs_dir_read(&sfd_lfs->lfs, &dir, &info);
  64. if (ret > 0) {
  65. if (info.type == LFS_TYPE_REG)
  66. count ++;
  67. }
  68. else
  69. break;
  70. }
  71. lfs_dir_close(&sfd_lfs->lfs, &dir);
  72. *kv_count = count;
  73. return 0;
  74. }
  75. int luat_fskv_size(const char* key, char buff[4]) {
  76. lfs_file_t fd = {0};
  77. int ret = 0;
  78. ret = lfs_file_open(&sfd_lfs->lfs, &fd, key, LFS_O_RDONLY);
  79. if (ret != LFS_ERR_OK) {
  80. return 0;
  81. }
  82. ret = lfs_file_size(&sfd_lfs->lfs, &fd);
  83. if (ret > 1 && ret < 256) {
  84. int ret2 = lfs_file_read(&sfd_lfs->lfs, &fd, buff, ret);
  85. if (ret2 != ret) {
  86. ret = -2; // 读取失败,肯定有问题
  87. }
  88. }
  89. lfs_file_close(&sfd_lfs->lfs, &fd);
  90. return ret;
  91. }
  92. int luat_fskv_next(char* buff, size_t offset) {
  93. lfs_dir_t dir = {0};
  94. struct lfs_info info = {0};
  95. int ret = lfs_dir_open(&sfd_lfs->lfs, &dir, "");
  96. if (ret != LFS_ERR_OK) {
  97. LLOGW("lfs_dir_open ret %d", ret);
  98. return -1;
  99. }
  100. ret = lfs_dir_seek(&sfd_lfs->lfs, &dir, offset);
  101. if (ret != LFS_ERR_OK) {
  102. lfs_dir_close(&sfd_lfs->lfs, &dir);
  103. return -2;
  104. }
  105. ret = lfs_dir_read(&sfd_lfs->lfs, &dir, &info);
  106. if (ret != LFS_ERR_OK) {
  107. lfs_dir_close(&sfd_lfs->lfs, &dir);
  108. return -3;
  109. }
  110. memcpy(buff, info.name, strlen(info.name) + 1);
  111. lfs_dir_close(&sfd_lfs->lfs, &dir);
  112. return 0;
  113. }