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测试结果
测试结果如下所示:
手机扫一扫
移动阅读更方便
你可能感兴趣的文章