ThreadX + LevelX+ FileX在STM32+NorFlash的移植

ThreadX + LevelX+ FileX在STM32+NorFlash的移植

开发平台:

IDE:MDK + STM32Cubemx
MCU:STM32F767IGT6;
NorFlash:W25Q256;
SPI:四线。

本教程是基于STM32 + SPI NorFlash 完成的,此历程相对上一个LevelX的历程中增加了使用ThreadX 与FileX的支持,同时,SPI Flash驱动增加DMA收发支持。实际使用过程中与芯片没什么紧密关系,均可使用,也不局限与SPI NorFlash 。实际上无论什么接口、什么类型的FLASH,除移植过程中对接口操作进行修改其余均可参照此教程进行移植。这里仅仅使用 SPI NorFlash进行举例,其余均可举一反三进行对照移植。

关于SPI 的DMA支持可以直接看BSP驱动代码。

STM32CubeMX中NorFlash SPI的配置参数:

CubeMX的SPI5配置
CubeMX SPI5 DMA配置

移植操作(参考LevelX移植)

LevelX将一个NorFlash的物理Block(块)主动分成由N个每128字的大小的扇区组成,所用的NorFlash实际扇区一般都不等于128字即512字节,在移植过程中,只需要将操作的地址进行转换一下,至于绝对操作地址相关的接口即可。

本次增加了LevelX的移植操作,过程比较简单,具体可以在安富莱电子论坛中查找到ThreadX的移植操作。

FileX的移植主要是修改FileX的 DriverEntry入口,因为在LevelX的移植过程中,已经对SPI驱动层移植完毕,所以只用将LevelX的接口一FileX的驱动入口初始一下即可。这里粘贴一下修改完毕的代码:

FileX的Driver entry调用

    if(Nor_Format)
    {
        Nor_Format = 0;
		fx_media_format(&nor_disk,
								nor_flash_driver,   // Driver entry
								FX_NULL,                          // Unused
								media_memory,                     // Media buffer pointer
								sizeof(media_memory),             // Media buffer size
								"MY_NOR_DISK",                    // Volume Name
								1,                                // Number of FATs
								32,                               // Directory Entries
								0,                                // Hidden sectors
								(W25Q256FV_FLASH_SIZE / 512) - 1, // Total sectors
								512,            // Sector size
								8,                                // Sectors per cluster
								1,                                // Heads
								1);                               // Sectors per track
    }
    
    
            /* Open the NOR disk.  */
        status =  fx_media_open(&nor_disk, "NOR DISK", nor_flash_driver, FX_NULL, media_memory, sizeof(media_memory));

读写驱动移植

VOID  nor_flash_driver(FX_MEDIA *media_ptr)
{

UCHAR       *source_buffer;
UCHAR       *destination_buffer;
ULONG       logical_sector;
ULONG       i;
UINT        status;


    /* There are several useful/important pieces of information contained in the media
       structure, some of which are supplied by FileX and others are for the driver to
       setup. The following is a summary of the necessary FX_MEDIA structure members
       Media结构中包含了一些有用的/重要的信息,其中一些是由FileX提供的,另一些则是由驱动程序设置的。以下是必要的FX_MEDIA结构成员的概要。:

            FX_MEDIA Member                              Meaning

        fx_media_driver_request             FileX request type. Valid requests from FileX are
                                            as follows:

                                                    FX_DRIVER_READ
                                                    FX_DRIVER_WRITE
                                                    FX_DRIVER_FLUSH
                                                    FX_DRIVER_ABORT
                                                    FX_DRIVER_INIT
                                                    FX_DRIVER_BOOT_READ
                                                    FX_DRIVER_RELEASE_SECTORS
                                                    FX_DRIVER_BOOT_WRITE
                                                    FX_DRIVER_UNINIT

        fx_media_driver_status              This value is RETURNED by the driver. If the
                                            operation is successful, this field should be
                                            set to FX_SUCCESS for before returning. Otherwise,
                                            if an error occurred, this field should be set
                                            to FX_IO_ERROR.

        fx_media_driver_buffer              Pointer to buffer to read or write sector data.
                                            This is supplied by FileX.

        fx_media_driver_logical_sector      Logical sector FileX is requesting.

        fx_media_driver_sectors             Number of sectors FileX is requesting.


       The following is a summary of the optional FX_MEDIA structure members:

            FX_MEDIA Member                              Meaning

        fx_media_driver_info                指向任何附加信息或内存的指针。
                                            这对于驱动程序来说是可选的,由fx_media_open调用来设置。RAM磁盘使用这个指针作为RAM磁盘内存本身的指针。.

        fx_media_driver_write_protect       当介质被写保护时,DRIVER会将其设置为FX_TRUE。这通常在初始化时完成,但也可以在任何时候完成。.

        fx_media_driver_free_sector_update  当DRIVER需要知道集群何时被释放时,会将此设置为FX_TRUE。这对于FLASH损耗均衡驱动来说是很重要的.

        fx_media_driver_system_write        如果被写入的扇区是系统扇区,例如,启动、FAT或目录扇区,FileX将此标志设置为FX_TRUE。
                                            驱动程序可以选择使用这个标志来启动错误恢复逻辑,以获得更大的容错能力。.

        fx_media_driver_data_sector_read    如果被读取的扇区是文件数据扇区,即不是系统扇区,FileX将此标志设置为FX_TRUE。.

        fx_media_driver_sector_type         FileX将此变量设置为被读取或写入的扇区的特定类型。以下是扇区的类型:

                                                    FX_UNKNOWN_SECTOR
                                                    FX_BOOT_SECTOR
                                                    FX_FAT_SECTOR
                                                    FX_DIRECTORY_SECTOR
                                                    FX_DATA_SECTOR
    */
    /*处理媒体控制块中指定的驱动程序请求。*/
    switch(media_ptr -> fx_media_driver_request)
    {
        case FX_DRIVER_READ:
        {
            /* 设置目标缓冲区和逻辑扇区。*/
            logical_sector =      media_ptr -> fx_media_driver_logical_sector;
            destination_buffer =  (UCHAR *) media_ptr -> fx_media_driver_buffer;

            /*循环读取闪存中的扇区。 */
            for (i = 0; i < media_ptr -> fx_media_driver_sectors; i++)
            {
                /*从NOR闪存中读取一个扇区。*/
                status =  lx_nor_flash_sector_read(&nor_flash, logical_sector, destination_buffer);

                /*确定读取是否成功。 */
                if (status != LX_SUCCESS)
                {
                    /* Return an I/O error to FileX.  */
                    media_ptr -> fx_media_driver_status =  FX_IO_ERROR;
                    return;
                }
                /* 移动到下一个条目。*/
                logical_sector++;
                destination_buffer =  destination_buffer + 512;
            }
            /*驱动请求成功。 */
            media_ptr -> fx_media_driver_status =  FX_SUCCESS;
            break;
        }

        case FX_DRIVER_WRITE:
        {
            /*设置源缓冲区和逻辑扇区。*/
            logical_sector =      media_ptr -> fx_media_driver_logical_sector;
            source_buffer =       (UCHAR *) media_ptr -> fx_media_driver_buffer;

            /* 循环向闪存写入扇区。*/
            for (i = 0; i < media_ptr -> fx_media_driver_sectors; i++)
            {
                /*向NOR闪存写入一个扇区。*/
                status =  lx_nor_flash_sector_write(&nor_flash, logical_sector, source_buffer);

                /* Determine if the write was successful.
                确定写入是否成功。*/
                if (status != LX_SUCCESS)
                {
                    /* Return an I/O error to FileX.  */
                    media_ptr -> fx_media_driver_status =  FX_IO_ERROR;
                    return;
                }
                /* Move to the next entries.  */
                logical_sector++;
                source_buffer =  source_buffer + 512;
            }

            /* Successful driver request.  */
            media_ptr -> fx_media_driver_status =  FX_SUCCESS;
            break;
        }

        case FX_DRIVER_RELEASE_SECTORS:
        {

            /*设置逻辑扇区 */
            logical_sector =  media_ptr -> fx_media_driver_logical_sector;

            /*释放扇区:*/
            for (i = 0; i < media_ptr -> fx_media_driver_sectors; i++)
            {

                /* Release NOR flash sector.  */
                status =  lx_nor_flash_sector_release(&nor_flash, logical_sector);

                /* Determine if the sector release was successful.  */
                if (status != LX_SUCCESS)
                {
                    /* Return an I/O error to FileX.  */
                    media_ptr -> fx_media_driver_status =  FX_IO_ERROR;
                    return;
                }
                /* Move to the next entries.  */
                logical_sector++;
            }
            /* Successful driver request.  */
            media_ptr -> fx_media_driver_status =  FX_SUCCESS;
            break;
        }

        case FX_DRIVER_FLUSH:
        {
            /* Return driver success.  */
            media_ptr -> fx_media_driver_status =  FX_SUCCESS;
            break;
        }

        case FX_DRIVER_ABORT:
        {
            /* Return driver success.  */
            media_ptr -> fx_media_driver_status =  FX_SUCCESS;
            break;
        }

        case FX_DRIVER_INIT:
        {

            /* FLASH驱动程序负责设置媒体结构中的几个字段,如下所示
                    media_ptr -> fx_media_driver_free_sector_update
                    media_ptr -> fx_media_driver_write_protect
               fx_media_driver_free_sector_update标志用于指示FileX在没有使用扇区时通知驱动程序。
               这对于FLASH管理者来说特别有用,因为他们不需要为不再使用的扇区维护映射。

              驱动程序可以在任何时候设置fx_media_driver_write_protect标志,
               以指示媒体不可写。 当这个标志被设置时,写入尝试会被返回为错误。*/

            /*在这里执行基本的初始化......直到引导记录将在随后被读取,并再次请求卷名。*/

            /* 使用闪存磨损水平,FileX应该在扇区不再使用时告诉磨损水平。*/
            media_ptr -> fx_media_driver_free_sector_update =  FX_TRUE;

            /* Open the NOR flash simulation.  */
            status =  lx_nor_flash_open(&nor_flash, "sim nor flash", nor_driver_initialize);

            /* Determine if the flash open was successful.  */
            if (status != LX_SUCCESS)
            {
                /* Return an I/O error to FileX.  */
                media_ptr -> fx_media_driver_status =  FX_IO_ERROR;
                return;
            }
            /* Successful driver request.  */
            media_ptr -> fx_media_driver_status =  FX_SUCCESS;
            break;
        }

        case FX_DRIVER_UNINIT:
        {

            /* 在这种情况下,RAM驱动是没有什么可做的。 对于实际设备,可能需要进行一些关机处理。*/
            /* Close the NOR flash simulation.  */
            status =  lx_nor_flash_close(&nor_flash);

            /* Determine if the flash close was successful.  */
            if (status != LX_SUCCESS)
            {
                /* Return an I/O error to FileX.  */
                media_ptr -> fx_media_driver_status =  FX_IO_ERROR;
                return;
            }

            /* Successful driver request.  */
            media_ptr -> fx_media_driver_status =  FX_SUCCESS;
            break;
        }

        case FX_DRIVER_BOOT_READ:
        {
            /*读取boot记录并返回给调用者*/
            /*设置目标缓冲区。*/
            destination_buffer =  (UCHAR *) media_ptr -> fx_media_driver_buffer;

            /* Read boot sector from NOR flash.  */
            status =  lx_nor_flash_sector_read(&nor_flash, 0, destination_buffer);

            /*对于NOR驱动,确定启动记录是否有效。*/
            if ((destination_buffer[0] != (UCHAR) 0xEB) ||
                (destination_buffer[1] != (UCHAR) 0x34) ||
                (destination_buffer[2] != (UCHAR) 0x90))
            {
                /* Invalid boot record, return an error!  */
                media_ptr -> fx_media_driver_status =  FX_MEDIA_INVALID;
                return;
            }

            /* Determine if the boot read was successful.  */
            if (status != LX_SUCCESS)
            {
                /* Return an I/O error to FileX.  */
                media_ptr -> fx_media_driver_status =  FX_IO_ERROR;
                return;
            }
            /* Successful driver request.  */
            media_ptr -> fx_media_driver_status =  FX_SUCCESS;
            break;
        }

        case FX_DRIVER_BOOT_WRITE:
        {
            /* Write the boot record and return to the caller.  */
            /* Setup the source buffer.  */
            source_buffer =       (UCHAR *) media_ptr -> fx_media_driver_buffer;

            /* Write boot sector to NOR flash.  */
            status =  lx_nor_flash_sector_write(&nor_flash, 0, source_buffer);

            /* Determine if the boot write was successful.  */
            if (status != LX_SUCCESS)
            {
                /* Return an I/O error to FileX.  */
                media_ptr -> fx_media_driver_status =  FX_IO_ERROR;
                return;
            }
            /* Successful driver request.  */
            media_ptr -> fx_media_driver_status =  FX_SUCCESS;
            break ;
        }

        default:
        {
            /* Invalid driver request.  */
            media_ptr -> fx_media_driver_status =  FX_IO_ERROR;
            break;
        }
    }
}

本次工程文件:ThreadX + LevelX+ FileX在STM32+NorFlash的移植工程

更新:

在昨天刚写完此贴后,ST就上传了字节的关于ThreadX LevelX FileX的SDIO设备以及SPI NOR设备的代码工程。大概看了一下移植大概都是一样的,感兴趣的可以看看ST的官方github代码库中的代码。
x-cube-azrtos-h7

声明 我所有的资源下载都是免C币的,下载时需要C币是CSDN要的,我修改不了。

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: STM32 FileX是一款嵌入式文件系统,专为STM32微控制器系列而设计和优化。它提供了一个强大而灵活的文件管理系统,适用于存储和管理嵌入式系统中的各种文件类型。 STM32 FileX具有以下特点和优势: 1. 系统资源占用低:FileX对内存资源的要求非常低,可以在有限的嵌入式系统中运行,而不会造成系统资源的浪费,从而使得STM32微控制器可以更加高效地执行其他任务。 2. 多种文件类型支持:FileX可以处理各种类型的文件,包括文本文件、二进制文件、图像文件等。它支持常见的文件操作,如打开、读取、写入、重命名、删除等,使得嵌入式系统可以灵活地处理不同类型的文件。 3. 文件系统安全性:FileX提供了数据完整性和文件系统安全性的保护机制。通过使用校验和、CRC校验、写入保护等技术,可以保证文件在读写过程中不会被破坏或损坏,确保数据的可靠性和完整性。 4. 支持多线程:FileX支持多线程操作,可以同时处理多个文件的读写操作。这在复杂的嵌入式系统中非常有用,可以提高系统的整体性能和效率。 5. 高度可配置:FileX可以根据具体的应用需求进行灵活的配置。用户可以根据需要选择适合的文件系统大小、块大小、簇大小等参数,以满足自己的存储容量和性能要求。 总的来说,STM32 FileX是一款功能强大、高效可靠的嵌入式文件系统。它在不占用过多系统资源的同时,提供了丰富的文件操作功能,可以满足各种嵌入式系统对文件管理的需求。无论是嵌入式设备的开发者还是应用工程师,都能够通过使用STM32 FileX轻松实现文件的存储、管理和操作。 ### 回答2: STM32 FileXSTMicroelectronics开发的一款嵌入式文件系统。它是专门为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都能够提供可靠的支持。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值