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测试结果

测试结果如下所示:

TMS570LS3137笔记-内部Flash FEE使用的更多相关文章

  1. STM32学习笔记:读写内部Flash(介绍+附代码)

    一.介绍 首先我们需要了解一个内存映射: stm32的flash地址起始于0x0800 0000,结束地址是0x0800 0000加上芯片实际的flash大小,不同的芯片flash大小不同. RAM起 ...

  2. [nRF51822] 11、基础实验代码解析大全 · 实验16 - 内部FLASH读写

     一.实验内容: 通过串口发送单个字符到NRF51822,NRF51822 接收到字符后将其写入到FLASH 的最后一页,之后将其读出并通过串口打印出数据. 二.nRF51822芯片内部flash知识 ...

  3. STM32F103使用内部Flash保存参数

    在我们应用开发时,经常会有一些程序运行参数需要保存,如一些修正系数.这些数据的特点是:数量少而且不需要经常修改,但又不能定义为常量,因为每台设备可能不一样而且在以后还有修改的可能.将这类数据存在指定的 ...

  4. STM32F4读写内部FLASH【使用库函数】

    STM32F4Discovery开发帮使用的STM32F407VGT6芯片,内部FLASH有1M之多.平时写的代码,烧写完之后还有大量的剩余.有效利用这剩余的FLASH能存储不少数据.因此研究了一下S ...

  5. STM32 对内部FLASH读写接口函数

    因为要用内部FLASH代替外部EEPROM,把参数放在STM32的0x08000000+320K处,其中20K是bootloader,300K是应用程序. 原理:先要把整页FLASH的内容搬到RAM中 ...

  6. STM32 对内部FLASH读写接口函数(转)

    源:STM32 对内部FLASH读写接口函数 因为要用内部FLASH代替外部EEPROM,把参数放在STM32的0x08000000+320K处,其中20K是bootloader,300K是应用程序. ...

  7. STM32f030f4p6 内部flash 打包读写

    最近做到的项目在运行需要把一组uint8_t(unsigned char)的数据进行掉电储存,想到单片机STM32f030f4p6内部flash可以直接由程序操作,写了以下代码用于uint8_t数据打 ...

  8. STM32 内部flash的读写程序

    ​ /* Base address of the Flash sectors */ #define ADDR_FLASH_SECTOR_0 ((uint32_t)0x08000000) /* Base ...

  9. 【转】STM32擦除内部FLASH时间过长导致IWDG复位分析

    @20119-01-29 [小记] STM32擦除内部FLASH时间过长导致IWDG复位分析

随机推荐

  1. [atARC075F]Mirrored

    假设$n=\sum_{i=0}^{k}a_{i}10^{i}$(其中$a_{k}>0$),则有$d=f(n)-n=\sum_{i=0}^{k}(10^{k-i}-10^{i})a_{i}$,考虑 ...

  2. [bzoj1863]皇帝的烦恼

    二分枚举答案,假设是ans,考虑判定答案从前往后计算,算出每一个将军与第一个将军最少和最多有多少个相同的奖牌,贪心转移即可 1 #include<bits/stdc++.h> 2 usin ...

  3. PHP绕过MD5比较的各种姿势

    1.用==进行弱类型比较时, 可以通过两个0e开头后面纯数字的md5绕过 php在进行弱类型比较时,如果为字符串为纯数字,包括浮点数.科学计数法.十六进制数等,都会转化为数字类型再进行比较,利用这点, ...

  4. C++构造函数写法

    笔记 class complex{ public: complex (double r = 0, double i = 0) : re(r), im(i) {} private: double re, ...

  5. redis序列化和反序列化的操作-(以前咋操作我都忘记了)

    //拿到数据,redis如果有则将现在有的传进去,如果没有则获取接口 ExWritPropertyVo ExWritPropertyVo = new ExWritPropertyVo(); ExWri ...

  6. JavaWeb 请求转发重定向

    请求转发和重定向 request除了可以作为请求对象之外,还可以作为域对象,但是该域对象的取值范围,是一次请求范围之内(浏览器地址栏没有发生跳转访问别的资源) 作用:将servlet中的数据通过req ...

  7. Atcoder Regular Contest 123 题解

    u1s1 我是真的不知道为什么现场这么多人切了 D,感觉 D 对思维要求显然要高于其他 300+ 人切掉的 D 吧(也有可能是 Atc 用户整体水平提升了?) A 开 幕 雷 击(这题似乎 wjz 交 ...

  8. python函数理解 json.dump()

    信息来自python说明文档(https://docs.python.org/3/library/json.html) 函数功能 输出一个python对象到文件 函数声明 json.dump(obj, ...

  9. 8.Maximum Depth of Binary Tree

    /** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode ...

  10. SpringBoot整合Shiro 一:搭建环境

    Java项目的安全框架一般使用 shiro 与 spring security 具体怎么选择可以参考文章:安全框架 Shiro 和 Spring Security 如何选择 我这里选择使用Shiro ...