FileX移植及简单分析

一、写在开头

FIleX的移植比较简单,只需要实现Azure RTOS FileX 文档中第五章的“FileX的I/O驱动程序”即可。
对于初次接触FAT文件系统的同学,建议了解下MBR、DPT和DBR,对于理解FileX的移植原理很有帮助。可参考下面两篇文章:

https://blog.csdn.net/guanyasu/article/details/52695086?spm=1001.2014.3001.5501
https://blog.csdn.net/guanyasu/article/details/52739695

二、平台介绍

硬件平台:STM32L475VET6;
ThreadX版本:6.1.3;
FileX版本:6.1.3;
基础工程:实现SD卡扇区的读和写功能(SPI接口/SDIO接口均可)

三、移植

1、首先移植ThreadX系统,ThreadX的移植可参考上一篇文章

2、复制FileX/common和FileX/ports/cortex_m4/gun(没有ac5版本,只有gun)到基础工程

3、在基础工程中添加FileX文件以及头文件路径

4、编写FileX的I/O驱动程序
FileX的I/O驱动程序只需要实现下面5个case即可:
FX_DRIVER_INIT:初始化
FX_DRIVER_READ:读扇区
FX_DRIVER_WRITE:写扇区
FX_DRIVER_BOOT_READ:读boot区
FX_DRIVER_BOOT_WRITE:写boot区
读操作:调用基础工程中的SD卡的读扇区函数
写操作:调用基础工程中的SD卡的写扇区函数

这里简单介绍下SD的空间分配:
①SD卡的0扇区是MBR+DPT,后面跟n个保留扇区
②接下来是DBR扇区(也就是FileX中的BOOT区),后面跟m个保留扇区
③再接下来是文件分配表,占x扇区
④文件分配表后面就是用户数据区了

再简单介绍下FileX的启动过程:
①首先发出初始化请求,完成SD卡初始化
②然后读BOOT扇区,用于设置结构体FX_MEDIA中的成员
③之后用户数据的读写,即FX_DRIVER_READ和FX_DRIVER_WRITE
其中最重要的是第二步,第二步的关键是找到BOOT区(DBR扇区)地址。其方法为首先读取0扇区获取DPT,DPT的8~12字节即为DBR扇区地址。FileX提供了一个函数,可以从0扇区的内容中分离出DBR地址。

UINT _fx_partition_offset_calculate(void *partition_sector, UINT partition, ULONG *partition_start, ULONG *partition_size);

下面提供一个示例驱动:

UINT  _fx_partition_offset_calculate(void  *partition_sector, UINT partition, ULONG *partition_start, ULONG *partition_size);
		
VOID  _fx_sd_spi_driver(FX_MEDIA *media_ptr)
{
	ULONG       partition_start;
	ULONG       partition_size;
	
	switch(media_ptr->fx_media_driver_request)
	{
		case FX_DRIVER_INIT:
		{
			SD_Init();
			media_ptr->fx_media_driver_status =  FX_SUCCESS;
			break;
		}
		
		case FX_DRIVER_UNINIT:
		{
			media_ptr->fx_media_driver_status =  FX_SUCCESS;
			break;
		}
		
		case FX_DRIVER_READ:
		{
			SD_ReadDisk((uint8_t*)media_ptr->fx_media_driver_buffer, media_ptr->fx_media_driver_logical_sector + media_ptr->fx_media_hidden_sectors, media_ptr->fx_media_driver_sectors);
			media_ptr->fx_media_driver_status =  FX_SUCCESS;
			break;
		}
		
		case FX_DRIVER_WRITE:
		{
			SD_WriteDisk((uint8_t*)media_ptr->fx_media_driver_buffer, media_ptr->fx_media_driver_logical_sector + media_ptr->fx_media_hidden_sectors, media_ptr->fx_media_driver_sectors);
			media_ptr->fx_media_driver_status =  FX_SUCCESS;
			break;
		}
		
		case FX_DRIVER_FLUSH:
		{
			media_ptr->fx_media_driver_status =  FX_SUCCESS;
			break;
		}

		case FX_DRIVER_ABORT:
		{
			media_ptr->fx_media_driver_status =  FX_SUCCESS;
			break;
		}
		
		case FX_DRIVER_BOOT_READ:
		{
			SD_ReadDisk((uint8_t*)media_ptr->fx_media_driver_buffer, 0, 1);		//读0扇区,获得MBR+DPT数据
			_fx_partition_offset_calculate(media_ptr -> fx_media_driver_buffer, 0,\
			 &partition_start, &partition_size);		//从0扇区数据中获得boot区地址和大小
			SD_ReadDisk((uint8_t*)media_ptr->fx_media_driver_buffer, partition_start, 1);		//读boot区
			media_ptr->fx_media_driver_status =  FX_SUCCESS;
			break;
		}
		
		case FX_DRIVER_BOOT_WRITE:
		{
			SD_WriteDisk((uint8_t*)media_ptr->fx_media_driver_buffer, partition_start, 1);
			media_ptr->fx_media_driver_status =  FX_SUCCESS;
			break;
		}
		
		default:
		{
			media_ptr->fx_media_driver_status =  FX_IO_ERROR;
			break;
		}
	}
}

5、编写FileX应用程序测试。
下面提供一个简单的测试程序,将测试程序添加到ThreadX的任务中即可。

FX_MEDIA     sdio_disk; 
FX_FILE      fx_file;
uint32_t media_memory[1*1024];
char FsWriteBuf[1024] = {"1234567890\r\n"};

void you_thread_entry(ULONG thread_input)
{
	int status = 0;
	fx_system_initialize();
	status =  fx_media_open(&sdio_disk, "STM32_SDIO_DISK", _fx_sd_spi_driver, 0, media_memory, sizeof(media_memory));
	status =  fx_file_create(&sdio_disk, "armfly.txt");
	status =  fx_file_open(&sdio_disk, &fx_file, "armfly.txt", FX_OPEN_FOR_WRITE);
	status =  fx_file_write(&fx_file, FsWriteBuf, strlen(FsWriteBuf));
	status =  fx_file_close(&fx_file);
	status =  fx_media_flush(&sdio_disk);
	while(1)
	{
		tx_thread_sleep(1);
	}
}

记录一下踩过的坑

1、SD卡的前n个扇区为MBR扇区+(n-1)个保留扇区,紧接着才是DBR扇区+m个保留扇区。BOOT区就是DBR扇区,其不在SD卡的0扇区。
2、逻辑扇区media_ptr->fx_media_driver_logical_sector提供的是相对地址,相对于DBR扇区的地址。在读写SD卡物理扇区时,必须加上隐藏扇区大小。

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
### 回答1: STM32 FileX是一款嵌入式文件系统,专为STM32微控制器系列而设计和优化。它提供了一个强大而灵活的文件管理系统,适用于存储和管理嵌入式系统中的各种文件类型。 STM32 FileX具有以下特点和优势: 1. 系统资源占用低:FileX对内存资源的要求非常低,可以在有限的嵌入式系统中运行,而不会造成系统资源的浪费,从而使得STM32微控制器可以更加高效地执行其他任务。 2. 多种文件类型支持:FileX可以处理各种类型的文件,包括文本文件、二进制文件、图像文件等。它支持常见的文件操作,如打开、读取、写入、重命名、删除等,使得嵌入式系统可以灵活地处理不同类型的文件。 3. 文件系统安全性:FileX提供了数据完整性和文件系统安全性的保护机制。通过使用校验和、CRC校验、写入保护等技术,可以保证文件在读写过程中不会被破坏或损坏,确保数据的可靠性和完整性。 4. 支持多线程:FileX支持多线程操作,可以同时处理多个文件的读写操作。这在复杂的嵌入式系统中非常有用,可以提高系统的整体性能和效率。 5. 高度可配置:FileX可以根据具体的应用需求进行灵活的配置。用户可以根据需要选择适合的文件系统大小、块大小、簇大小等参数,以满足自己的存储容量和性能要求。 总的来说,STM32 FileX是一款功能强大、高效可靠的嵌入式文件系统。它在不占用过多系统资源的同时,提供了丰富的文件操作功能,可以满足各种嵌入式系统对文件管理的需求。无论是嵌入式设备的开发者还是应用工程师,都能够通过使用STM32 FileX轻松实现文件的存储、管理和操作。 ### 回答2: STM32 FileX是STMicroelectronics开发的一款嵌入式文件系统。它是专门为STM32微控制器设计的,提供了可靠的文件系统功能,能够在嵌入式系统中进行文件的读写和管理。 STM32 FileX具有以下特点和功能: 1. 高性能和低资源占用:STM32 FileX采用了高效的算法和数据结构,使其能够在嵌入式系统中快速且高效地进行文件的读写操作,并且占用的系统资源较少,有利于节省处理器的计算能力和内存空间。 2. 可靠的数据保护:STM32 FileX提供了可靠的数据保护机制,包括存储介质上的文件一致性检查、写操作的缓存管理、数据的完整性和可靠性验证等,能够有效地防止数据损坏和丢失,保证了数据的可靠性和一致性。 3. 多种文件系统支持:STM32 FileX支持多种文件系统,包括FAT12、FAT16、FAT32等,能够适应不同的应用需求和存储介质类型。 4. 灵活的文件管理功能:STM32 FileX提供了丰富的文件管理功能,包括文件的创建、打开、读写、删除等操作,能够方便地进行文件的管理和维护。 5. 完善的API接口和开发工具:STM32 FileX提供了完善的API接口和开发工具,使开发者能够快速地集成和使用该文件系统,提高开发效率。 6. 应用广泛:STM32 FileX适用于多种嵌入式应用场景,包括工业自动化、智能家居、车载娱乐系统、医疗设备等,能够满足不同领域的文件管理需求。 总的来说,STM32 FileX是一款高性能、可靠的嵌入式文件系统,能够方便地进行文件的读写和管理,适用于各种嵌入式系统的开发。 ### 回答3: STM32 FileX是一个嵌入式文件系统,专为STM32系列微控制器开发的。它是一个可靠、高效、安全的文件系统,能够管理和操作嵌入式系统中的文件和文件夹。 STM32 FileX提供了许多功能,包括文件的创建、读取、写入、删除等。用户可以通过简单的API来访问这些功能,并可以根据自己的需求进行定制。 STM32 FileX能够有效地管理嵌入式系统中的存储器资源。它支持不同类型的存储介质,如RAM、Flash、SD卡等。通过使用FileX,开发人员可以轻松地在嵌入式系统中添加文件系统,从而使得数据的存储和管理更加方便。 STM32 FileX具有很高的性能和可靠性。它采用了先进的文件索引技术,能够快速地定位文件和文件夹。同时,它还具备数据保护机制,能够确保文件的完整性和安全性。 STM32 FileX是易于使用和集成的。它提供了一个直观的编程接口,使开发人员能够快速地熟悉和使用。此外,它还提供了丰富的示例代码和文档,帮助开发人员更好地理解和使用该文件系统。 总之,STM32 FileX是一个专为STM32系列微控制器开发的嵌入式文件系统。它具有高效、可靠、安全的特性,能够方便地管理和操作嵌入式系统中的文件和文件夹。无论是存储数据,还是进行软件更新和配置,STM32 FileX都能够提供可靠的支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值