0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于DSP的嵌入式系统实现擦写片外FLASH器件

电子设计 来源:半导体技术 作者:张伟,张太镒,陈 2020-09-18 16:49 次阅读

作者:张伟,张太镒,陈志刚,吕娜

1 引言

DSP系统的设计中,经常要使用片外存储器扩充系统存储空间。特别是当DSP的片内数据存储器和程序存储器容量比较小时, 必须把一部分数据,如常量、原始数据库等存储到片外的存储器中,从而节省DSP芯片内部的存储器资源。在实际应用中,片外存储器通常选择RAM或FLASH MEMORY。RAM数据掉电即丢失,不适合长期保存数据。对于一些无需频繁读写但需要长期保存的数据,如字模数据、端口地址等时,通常选择片外FLASH作伪扩展的数据存储器。使用片外 FLASH必须要解决对其擦写的问题。

在实际应用中,对片外FLASH的擦写有两种方式:一是使用通用编程器对FLASH芯片进行擦写;二是直接由DSP对FLASH进行擦写。对于需要修改或已安装在电路板上的FLASH芯片无法使用第一种方式,只能采用第二种方式,且便于调试。本文介绍一种利用存储器映射技术实现对DSP片外FLASH擦写的方法。

DSP56F805芯片是Motorola公司在DSP56800 的基础上开发的系列DSP芯片之一。该芯片采用先进的修正哈佛结构,三个内部地址总线和四个内部数据总线支持数据传输;采用MCU形式的指令集,寻址方式灵活;具有较强的片外存储空间扩展能力;功耗小,高度并行。但是该芯片的片内数据存储器空间最大为64k,程序存储空间寻址范围是64k,内部模式(Mode0A和Mode0B)下只有31.5k。对于一些需要复杂中文图形用户界面的 DSP系统来说芯片存储资源显得不够,必须对芯片存储空间进行扩展。考虑到具体要求,本文使用片外FLASH来扩展系统数据存储空间,将DSP系统的中文图形用户界面中用到的所有字模数据和页面内容数据存放到片外FLASH中,大大节省了片内的数据存储器空间。

CodeWarrior IDE是由Metrowerks公司专为Motorola的DSP56800系列设计的开发平台。该平台具有简单明了的图形用户界面和丰富的软件开发工具,适合于开发基于DSP56800系列的应用程序、插件程序等各种程序代码。在CodeWarrior环境中,用户可以通过修改.cmd文件来配置存储器分配方式,还可以通过修改startup文件夹中的初始化程序来控制系统的初始化操作。用户编译并链接后,将生成.elf文件,在文件中可以看到存储器的详细分配情况。当用户将程序下载到DSP芯片后,可以使用CodeWarrior的调试器对程序进行全面的调试,如设置断点、单步执行等;也可以使用 Watch Memory指令来检查存储器中的各地址段的值,还可以使用Save/Load Memory指令来保存或是载入某段存储器的值。

2 方法介绍

首先利用GPIOD0口生成合适的片外FLASH和片内XRAM片选信号,实现片内XRAM和片外FLASH的访问切换。例如当GPIOD0 =0时,0x8000~0xFFFF映射到片内XRAM,此时对于整个0x0000~0xFFFF地址范围的读写操作就是对于片内 XRAM的操作;当GPIOD0=1时,0x8000~0xFFFF地址范围映射到数据FLASH,则对0x8000~0xFFFF 地址范围的读写操作就是对于片外FLASH的操作;对0x0000~0x7FFF地址范围的读写仍是针对片内 XRAM的操作,从而将数据存储空间扩展了32k。

再将映射方式设置为片内,将需要写到FLASH中的数据文件载入片内XRAM。最后根据需要设置GPIO端口值,切换地址映射的存储器。这样通过地址映射的方法,便可实现将XRAM中数据写入片外FLASH的操作,而对于DSP芯片来说只是进行了其XRAM寻址空间内部的数据搬移操作。

假设要将一组二维数组character[180][32]形式的字模数据保存入片外数据FLASH的0x8000~0xA000地址段中,先做以下准备工作:

①用一个GPIO端口,扩展系统的可寻址数据存储器空间;②编写FLASH擦写程序,程序流程如图1所示。

#define N 100 /* 由于FLASH与RAM的读写速度不同,所以需要在每项操作后加入若干个延迟以保证正确性,延迟的具体长短可以根据具体情况作调整 */

基于DSP的嵌入式系统实现擦写片外FLASH器件

void main()

{

unsigned int i,code;

unsigned int *code_addr;

unsigned int *flash_addr;

*GPIO_D_DR=0x0002; /*映射方式设置为映射到片外数据FLASH*/

delay(N);

GPIOD_setup(); /*GPIOD设置*/

delay(N);

erase_flash(); /*如FLASH上原有数据无需保留,则全部擦除,如部分据需保留,也可部分擦除*/

*GPIO_D_DR=0x0000; /*映射方式设置为映射到片内XRAM*/ delay(N);

flash_addr=(unsigned int *) FLASH_ADDR;

code_addr=(unsigned int *)CODE_ADDR; /*设置XRAM的存储起始地址和数据FLASH擦写起始地址*/

/*循环擦写*/

for(i=0;i{

*GPIO_D_DR=0x0000;

delay(N);

code=*(code_addr++); /*保存XRAM中数据到变量code*/

delay(N);

*GPIO_D_DR=0x0002;

delay(N);

pre_write_flash(); /* 写FLASH前的预处理,向FLASH内写入相应命令字,根据所选用 FLASH的不同预处理操作也有所不同*/

delay(N);

*(flash_addr++)=code; /*写数据到FLASH中*/

delay(N);

}

}

擦写步骤如下:

① 将character[180][32]设置为全局变量。

② 将程序编译下载到DSP芯片中,打开工程目录中output文件夹中的.elf文件,找到character 数组在XRAM中存放的起始地址和长度。用户可以使用Watch Memory命令察看该段地址的数据值。

③ 使用Save Memory命令将XRAM中对应于character数组的地址段的数据以二进制形式保存在计算机上。通过UltraEdit将其打开,检看数据保存是否正确。

④ 打开FLASH擦写程序,修改数据在片内XRAM中存储的起始地址和FLASH的擦写起始地址与数据长度。编译下载后,单步执行,执行到擦除完FLASH,并将地址映射方式置为映射到片内XRAM处,使用Load Memory指令将char数据文件载入到片内XRAM的相应存储地址段中,再接着全速运行程序,几十秒之后程序执行完毕,数据便写到片外FLASH的相应地址中。

⑤ 再次打开FLASH擦写程序,单步执行到映射方式置为片外FLASH处停止,使用Save Memory命令保存FLASH中刚写入的地址段的数据值。接着使用UltraEdit的比较文件命令比较前两次保存的数据,如完全相同就表明character字模数组已经正确的写到片外FLASH中。

将数据擦写入片外数据FLASH后,就可以在用户程序中对该数据加以调用。在调用的时候要先将映射方式设置为映射到片外FLASH,然后再取数据。如下所示,取出FLASH中0x6000地址上存储的数据:

#define FLASH_ADD (unsigned int *)0x6000

*GPIO_D_DR=0x0002; /*映射方式设置为映射到片外FLASH*/

data = *(FLASH_ADD);

3 结论

本文介绍了一种通过地址映射方式,在基于 DSP的嵌入式系统中,通过DSP擦写片外FLASH的方法。该方法可适用于多种场合,针对多个 FLASH芯片可使用多个GPIO端口进行地址的扩展,并可通过DSP实现对其擦写操作;若将部分程序放置到片外FLASH中并作相应设置,即可实现系统的自举运行等。

责任编辑:gt

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • dsp
    dsp
    +关注

    关注

    544

    文章

    7681

    浏览量

    344332
  • 嵌入式
    +关注

    关注

    4981

    文章

    18274

    浏览量

    288361
  • FlaSh
    +关注

    关注

    10

    文章

    1549

    浏览量

    146643
收藏 人收藏

    评论

    相关推荐

    采用nios和μClinux实现嵌入式系统设计

    外设接口。 基于sopc的嵌入式系统主要由1核心芯片sopc和器件,以及一些相关的接口设备
    发表于 04-18 07:00

    嵌入式系统Flash存储器接口电路调试

    ROM/SRAM/FLASH组0和DRAM/SDRAM组0,暂未使用扩接口器件。3基于S3C4510B的嵌入式系统
    发表于 06-10 05:00

    如何设计嵌入式FIFO数据传输系统

    C6727B,由于其内集成dMAX模块,使得实现嵌入式FIFO成为可能。其实现嵌入式FIFO的本质就是将
    发表于 08-08 07:03

    什么是嵌入式系统

    、 低功耗技术 制造的 R. E. A. L DSP 处理器,其特点是具备双 Harvard 结构和双乘 / 累加单元,应用目标是大批量消费类产品。(4) 嵌入式系统 (Syst
    发表于 04-16 09:53

    嵌入式系统的硬件平台组成

    系统硬件配置非常精简,除了微处理器和基本的外围电路以外,其余的电路都可根据需要和成本进行裁剪、定制,非常经济、可靠。  嵌入式系统的硬件核心是嵌入式微处理器,有时为了提高
    发表于 06-20 15:25

    嵌入式手持移动终端中文件系统实现

    而广泛应用于便携电子产品中。在Flash存储器中使用文件系统,可将存储空间当作直观的名称空间,不用在每次应用开发中都从头使用存储器,还可方便地利用标准接口同主系统通信。本文中,我们将以嵌入式
    发表于 01-05 07:29

    如何用存储器映射的方法实现FLASH擦写

    请问如何用存储器映射的方法实现FLASH擦写
    发表于 04-20 06:13

    有什么方法可以实现FLASH擦写吗?

    请问大神有什么方法可以实现FLASH擦写吗?
    发表于 04-26 06:26

    嵌入式系统中的线性Flash文件系统设计,不看肯定后悔

    本文设计的线性文件系统为典型的嵌入式系统提供了所需的类文件系统能力。需要注意的是,本文件系统不支持复杂的
    发表于 04-28 06:21

    嵌入式系统概论

    嵌入式系统概论1.嵌入式系统:指操作系统和功能软件集成于计算机硬件之中。2.嵌入式
    发表于 10-27 08:09

    Linux/ARM嵌入式平台属于系统

    Linux/ARM 嵌入式平台是《ARM 嵌入式系统编程与优化》的第一章。好好学学硬件,然后深入一下 Linux,修炼好自己的内功。ARM 处理器不是独立芯片产品,而是具有多样性和异质性嵌入式
    发表于 12-14 09:25

    嵌入式系统的概念定义

    嵌入式系统的概念定义一 定义二嵌入式系统的分类嵌入式微处理器嵌入式微控制器即单片机
    发表于 12-17 08:33

    嵌入式系统分类有哪些?

    系统中,形成的嵌入式操作系统。另一类是实时操作系统。下面就来详细了解:嵌入式系统根据上面的分类,
    发表于 03-30 14:19

    基于Flash嵌入式交互系统的设计与实现

    电子发烧友网站提供《基于Flash嵌入式交互系统的设计与实现.pdf》资料免费下载
    发表于 10-08 10:48 0次下载
    基于<b class='flag-5'>Flash</b>的<b class='flag-5'>嵌入式</b>交互<b class='flag-5'>系统</b>的设计与<b class='flag-5'>实现</b>

    什么是可重复擦写Flash型)语音芯片?

    什么是可重复擦写Flash型)语音芯片?可重复擦写Flash型)语音芯片是一种嵌入式语音存储解决方案,采用了
    的头像 发表于 12-14 10:08 230次阅读
    什么是可重复<b class='flag-5'>擦写</b>(<b class='flag-5'>Flash</b>型)语音芯片?