drv_filesystem.c 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2018-12-13 balanceTWK add sdcard port file
  9. * 2021-05-10 Meco Man fix a bug that cannot use fatfs in the main thread at starting up
  10. * 2021-07-28 Meco Man implement romfs as the root filesystem
  11. */
  12. #include <rtthread.h>
  13. #include <dfs_romfs.h>
  14. #include <dfs_fs.h>
  15. #include <dfs_file.h>
  16. #if DFS_FILESYSTEMS_MAX < 4
  17. #error "Please define DFS_FILESYSTEMS_MAX more than 4"
  18. #endif
  19. #if DFS_FILESYSTEM_TYPES_MAX < 4
  20. #error "Please define DFS_FILESYSTEM_TYPES_MAX more than 4"
  21. #endif
  22. #define DBG_TAG "app.filesystem"
  23. #define DBG_LVL DBG_INFO
  24. #include <rtdbg.h>
  25. #ifdef BSP_USING_FS_AUTO_MOUNT
  26. #ifdef BSP_USING_SDCARD_FATFS
  27. static int onboard_sdcard_mount(void)
  28. {
  29. if (dfs_mount("sd0", "/sdcard", "elm", 0, 0) == RT_EOK)
  30. {
  31. LOG_I("SD card mount to '/sdcard'");
  32. }
  33. else
  34. {
  35. LOG_E("SD card mount to '/sdcard' failed!");
  36. }
  37. return RT_EOK;
  38. }
  39. #endif /* BSP_USING_SDCARD_FATFS */
  40. #endif /* BSP_USING_FS_AUTO_MOUNT */
  41. #ifdef BSP_USING_FLASH_FS_AUTO_MOUNT
  42. #ifdef BSP_USING_FLASH_FATFS
  43. #define FS_PARTITION_NAME "filesystem"
  44. static int onboard_fal_mount(void)
  45. {
  46. /* 初始化 fal 功能 */
  47. extern int fal_init(void);
  48. extern struct rt_device *fal_blk_device_create(const char *parition_name);
  49. fal_init();
  50. /* 在 spi flash 中名为 "filesystem" 的分区上创建一个块设备 */
  51. struct rt_device *flash_dev = fal_blk_device_create(FS_PARTITION_NAME);
  52. if (flash_dev == NULL)
  53. {
  54. LOG_E("Can't create a block device on '%s' partition.", FS_PARTITION_NAME);
  55. }
  56. else
  57. {
  58. LOG_D("Create a block device on the %s partition of flash successful.", FS_PARTITION_NAME);
  59. }
  60. /* 挂载 spi flash 中名为 "filesystem" 的分区上的文件系统 */
  61. if (dfs_mount(flash_dev->parent.name, "/fal", "elm", 0, 0) == 0)
  62. {
  63. LOG_I("Filesystem initialized!");
  64. }
  65. else
  66. {
  67. LOG_E("Failed to initialize filesystem!");
  68. LOG_D("You should create a filesystem on the block device first!");
  69. }
  70. return RT_EOK;
  71. }
  72. #endif /*BSP_USING_FLASH_FATFS*/
  73. #endif /*BSP_USING_FLASH_FS_AUTO_MOUNT*/
  74. const struct romfs_dirent _romfs_root[] =
  75. {
  76. #ifdef BSP_USING_SDCARD_FATFS
  77. {ROMFS_DIRENT_DIR, "sdcard", RT_NULL, 0},
  78. #endif
  79. #ifdef BSP_USING_FLASH_FATFS
  80. {ROMFS_DIRENT_DIR, "fal", RT_NULL, 0},
  81. #endif
  82. };
  83. const struct romfs_dirent romfs_root =
  84. {
  85. ROMFS_DIRENT_DIR, "/", (rt_uint8_t *)_romfs_root, sizeof(_romfs_root) / sizeof(_romfs_root[0])
  86. };
  87. static int filesystem_mount(void)
  88. {
  89. #ifdef BSP_USING_FS
  90. if (dfs_mount(RT_NULL, "/", "rom", 0, &(romfs_root)) != 0)
  91. {
  92. LOG_E("rom mount to '/' failed!");
  93. }
  94. /* 确保块设备注册成功之后再挂载文件系统 */
  95. rt_thread_delay(500);
  96. #endif
  97. #ifdef BSP_USING_FS_AUTO_MOUNT
  98. onboard_sdcard_mount();
  99. #endif /* BSP_USING_FS_AUTO_MOUNT */
  100. #ifdef BSP_USING_FLASH_FS_AUTO_MOUNT
  101. onboard_fal_mount();
  102. #endif
  103. return RT_EOK;
  104. }
  105. INIT_APP_EXPORT(filesystem_mount);