# RA8P1 Titan Board 开发板 Filesystem 使用说明 **中文** | [**English**](./README_EN.md) ## 简介 FAL (Flash Abstraction Layer) Flash 抽象层,是对 Flash 及基于 Flash 的分区进行管理、操作的抽象层,对上层统一了 Flash 及 分区操作的 API (框架图如下所示),并具有以下特性: - 支持静态可配置的分区表,并可关联多个 Flash 设备; - 分区表支持 **自动装载** 。避免在多固件项目,分区表被多次定义的问题; - 代码精简,对操作系统 **无依赖** ,可运行于裸机平台,比如对资源有一定要求的 Bootloader; - 统一的操作接口。保证了文件系统、OTA、NVM(例如:[EasyFlash](https://github.com/armink-rtt-pkgs/EasyFlash)) 等对 Flash 有一定依赖的组件,底层 Flash 驱动的可重用性; - 自带基于 Finsh/MSH 的测试命令,可以通过 Shell 按字节寻址的方式操作(读写擦) Flash 或分区,方便开发者进行调试、测试; ![image-20250730135236514](figures/image-20250730135236514.png) 本示例中将使用 Titan Board 板载 Ospi Flash 结合 RT-Thread FAL 组件,使用 littlefs 构建文件系统。 ## 硬件说明 ![image-20250730135427623](figures/image-20250730135427623.png) ## 软件说明 本例程的文件系统初始化源码位于 `./board/ports/filesystem/drv_filesystem.c` 中: ```c /* * Copyright (c) 2006-2021, RT-Thread Development Team * * SPDX-License-Identifier: Apache-2.0 * * Change Logs: * Date Author Notes * 2018-12-13 balanceTWK add sdcard port file * 2021-05-10 Meco Man fix a bug that cannot use fatfs in the main thread at starting up * 2021-07-28 Meco Man implement romfs as the root filesystem */ #include #include #include #include #if DFS_FILESYSTEMS_MAX < 4 #error "Please define DFS_FILESYSTEMS_MAX more than 4" #endif #if DFS_FILESYSTEM_TYPES_MAX < 4 #error "Please define DFS_FILESYSTEM_TYPES_MAX more than 4" #endif #define DBG_TAG "app.filesystem" #define DBG_LVL DBG_INFO #include #ifdef BSP_USING_FS_AUTO_MOUNT #ifdef BSP_USING_SDCARD_FATFS static int onboard_sdcard_mount(void) { if (dfs_mount("sd", "/sdcard", "elm", 0, 0) == RT_EOK) { LOG_I("SD card mount to '/sdcard'"); } else { LOG_E("SD card mount to '/sdcard' failed!"); } return RT_EOK; } #endif /* BSP_USING_SDCARD_FATFS */ #endif /* BSP_USING_FS_AUTO_MOUNT */ #ifdef BSP_USING_FLASH_FS_AUTO_MOUNT #ifdef BSP_USING_FLASH_FATFS #define FS_PARTITION_NAME "filesystem" static int onboard_fal_mount(void) { /* 初始化 fal 功能 */ extern int fal_init(void); extern struct rt_device* fal_mtd_nor_device_create(const char *parition_name); fal_init (); /* 在 spi flash 中名为 "filesystem" 的分区上创建一个块设备 */ struct rt_device *mtd_dev = fal_mtd_nor_device_create (FS_PARTITION_NAME); if (mtd_dev == NULL) { LOG_E("Can't create a mtd device on '%s' partition.", FS_PARTITION_NAME); return -RT_ERROR; } else { LOG_D("Create a mtd device on the %s partition of flash successful.", FS_PARTITION_NAME); } /* 挂载 spi flash 中名为 "filesystem" 的分区上的文件系统 */ if (dfs_mount (FS_PARTITION_NAME, "/", "lfs", 0, 0) == 0) { LOG_I("Filesystem initialized!"); } else { dfs_mkfs ("lfs", FS_PARTITION_NAME); if (dfs_mount ("filesystem", "/", "lfs", 0, 0) == 0) { LOG_I("Filesystem initialized!"); } else { LOG_E("Failed to initialize filesystem!"); } } return RT_EOK; } #endif /*BSP_USING_FLASH_FATFS*/ #endif /*BSP_USING_FLASH_FS_AUTO_MOUNT*/ const struct romfs_dirent _romfs_root[] = { #ifdef BSP_USING_SDCARD_FATFS {ROMFS_DIRENT_DIR, "sdcard", RT_NULL, 0}, #endif #ifdef BSP_USING_FLASH_FATFS { ROMFS_DIRENT_DIR, "fal", RT_NULL, 0 }, #endif }; const struct romfs_dirent romfs_root = { ROMFS_DIRENT_DIR, "/", (rt_uint8_t*) _romfs_root, sizeof(_romfs_root) / sizeof(_romfs_root[0]) }; static int filesystem_mount(void) { #ifdef BSP_USING_FS if (dfs_mount(RT_NULL, "/", "rom", 0, &(romfs_root)) != 0) { LOG_E("rom mount to '/' failed!"); } /* 确保块设备注册成功之后再挂载文件系统 */ rt_thread_delay(500); #endif #ifdef BSP_USING_FS_AUTO_MOUNT onboard_sdcard_mount(); #endif /* BSP_USING_FS_AUTO_MOUNT */ #ifdef BSP_USING_FLASH_FS_AUTO_MOUNT onboard_fal_mount (); #endif return RT_EOK; } INIT_COMPONENT_EXPORT(filesystem_mount); ``` ## 编译&下载 * RT-Thread Studio:在RT-Thread Studio 的包管理器中下载 Titan Board 资源包,然后创建新工程,执行编译。 编译完成后,将开发板的 Jlink 接口与 PC 机连接,然后将固件下载至开发板。 ## 运行效果 按下复位按键重启开发板,观察开发板终端日志。 ![PixPin_2025-07-25_15-16-40](figures/PixPin_2025-07-25_15-16-40.png)