TMS570LS3137笔记-内部Flash FEE使用

1、基本简介

TMS570LS3137内部Flash分为三个 Bank,主Flash 数据存储区3MB,是Bank1和Bank2.还有一个Bank7是作为内部Flash模拟EEPROM使用。内部存储器如下图所示:

 

 FEE功能只是用于Bank7,需要使用这块存储器就需要相应的函数实现数据的读取、写入和擦除。Ti为我们准备了F021FLASH-library实现了程序代码和系统存储器之间的桥梁。因此我们只需要调用F021FLASH-library的接口代码即可实现对存储器的读写操作。这可比翻手册写代码简单多了。

2、使用流程

2.1需要使用FEE功能,首先需要在HALCoGen软件配置相应功能,使能FEE驱动库等操作。然后配置内部存储器的Block操作等。

 FEE配置:

 

 FEE驱动配置就完成了,HALCoGen生成代码。然后进入Code Composer Studio 编译。

2.2添加F021FLASH-library代码;

在前面的HALCoGen生成代码完成后,进入CCS编译,会报错。提示:F021.h文件找不到。那是因为我们前面说过的F021FLASH-library驱动代码没有添加到工程中。在Ti网站下载:https://www.ti.com/tool/HERCULES-F021FLASHAPI#downloads F021FLASH-library包,下载下来后是一个压缩包spnc033.zip。将其解压后是一个exe文件,安装exe文件。会默认将F021FLASH-library代码解压到C:\ti\Hercules\F021 Flash API。

将F021 Flash API文件夹复制到工程所在路径下:

 接下来配置CCS,首先将新添加到头文件路径加入到CCS工程之中:

由于F021FLASH-library是以Lib 方式提供的,因此还需要将对应的lib添加到CCS工程中去。打开F021FLASH-library文件目录会发现文件夹中除了提供了代码文件和lib文件还有完善的API说明。有兴趣可以详细看看API代码的意思,和操作流程。Ti文档解释的还是比较清楚的。我们发现这里提供了很多lib,那是因为这个工程是服务于TI很多芯片的。因此需要添加正确的lib文件才可以使用该功能。

 就F021库而言,BE和LE分别指大端序和小端序,Hercules系列产品中,TMS570系列为大端序,RM系列为小端序;我们使用的是TMS570LS3137因此选择F021_API_CortexR4_BE.lib。

在CCS这个位置添加,如下图所示:

自此,我们所有的配置过程就完成了。

 3、代码编写和测试

在需要使用FEE的文件中调用头文件“#include "ti_fee.h"”;

3.1 FEE初始化函数

在进行FEE读写数据之前必须调用 “TI_Fee_Init();”初始化库。

3.2写数据

下面定义写入数据函数,参数是Block号和Buf,单次写入数据我们前面已经定义好 64字节。

void bank7_flash_write(uint16 BlockNumber,uint8 *buf)

{

    TI_FeeModuleStatusType Status;           //定义状态标志字

    do

    {

      TI_Fee_MainFunction();

      delay_ms(1);

      Status=TI_Fee_GetStatus(0 );

    }

    while(Status!=IDLE);                     //获取 FEE状态并等待为 IDLE

    TI_Fee_WriteAsync(BlockNumber, buf);     //写入数据

    do

    {

      TI_Fee_MainFunction();

      delay_ms(1);

      Status=TI_Fee_GetStatus(0);

    }

    while(Status!=IDLE);

}

3.3读取数据

BlockNumber读取数据 block号,BlockOffset读取数据偏移,buf读取数据Buf,Length读取数据长度。

void bank7_flash_read(uint16 BlockNumber,uint16 BlockOffset,uint8 *buf,uint16 Length)

{

    unsigned int index = 0;

    unsigned int set_w_num = 0;

    TI_FeeModuleStatusType Status;

    Std_ReturnType oResult;

    TI_Fee_AddressType cur_address = 0;

    index = TI_FeeInternal_GetBlockIndex(BlockNumber);

    set_w_num = TI_FeeInternal_GetBlockSize(index)-TI_FEE_BLOCK_OVERHEAD;

    cur_address = TI_FeeInternal_GetCurrentBlockAddress(BlockNumber,0,index);

    if(BlockOffset<=set_w_num)                                                //检查 Length 长度数据的 合法性

    {

      if(Length>(set_w_num-BlockOffset))Length=set_w_num-BlockOffset;

    }

    oResult=TI_Fee_Read(BlockNumber,BlockOffset,buf,Length);

    do

    {

        TI_Fee_MainFunction();

        delay_ms(1);

        Status=TI_Fee_GetStatus(0);

    }

    while(Status!=IDLE);

}

3.4 擦除数据

擦除函数可选择使用如下两种函数:

   TI_Fee_Format(0xA5A5A5A5U);                //格式化就是将整个bank7进行格式化。

   TI_Fee_EraseImmediateBlock(1);             //Block1 擦除

TI_Fee_EraseImmediateBlock(2);             //Block2 擦除

3.5测试函数

我编写了2个block数据写入和读取的测试函数。实现数据写入和读取并在串口中显示数据。

void bank7_flash_test(void)

{

   uint8 buf[64],read[64];

   uint16 i=0;

   for(i=0;i<64;i++)

       {

         buf[i]=65-i;

         read[i]=0;

       }

   TI_Fee_Init();                             //FEE 系统初始化

   bank7_flash_write(1,buf);                  //Block1 写入数据

   bank7_flash_read(1,0,read,64);             //Block1读取 写入的数据

   printf("Block1 读出数据:\r\n");

   for(i=0;i<64;i++){printf("%d ",read[i]);}  //打印读取的数据

                                              //Block2 数据读写测试开始

   for(i=0;i<64;i++)

       {

         buf[i]=i+2;

         read[i]=0;

       }

   bank7_flash_write(2,buf);                  //Block2 写入数据

   bank7_flash_read(2,0,read,64);             //Block2读取 写入的数据

   printf("\r\nBlock2 读出数据:\r\n");

   for(i=0;i<64;i++){printf("%d ",read[i]);}  //打印读取的数据

//   TI_Fee_Format(0xA5A5A5A5U);                //格式化就是将整个bank7进行格式化。

   TI_Fee_EraseImmediateBlock(1);             //Block1 擦除

   TI_Fee_EraseImmediateBlock(2);             //Block2 擦除

}

3.6测试结果

测试结果如下所示:

 

 

posted @ 2021-12-07 20:08  迷幻森林  阅读(1362)  评论(1编辑  收藏  举报