深圳市瑞申电子有限公司

深圳市瑞申电子有限公司是一家10年专业大功率电感生产加工厂商,主要以大功率,大电流、扁平线圈电感、平面变压器设计、生产、销售工厂。设计、绕线、组装、检测、包装、出货等全制程的工艺流程!拥有完整、科学的质量管理体系。专业技术团队10人,我们的诚信、实力和产品质量获得业界的认可。欢迎各界朋友莅临参观、指导和业务洽谈。 ...

基于 DSP的嵌入式系统通过地址映射方式实现片外FLASH擦写

时间:2015-03-20 18:00:35 点击:

1 引言

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

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

DSP56F805芯片是Motoro电感厂家la公司在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的操作;对0x工字电感器0000~0x7FFF地址范围的读写仍是针对片内 XRAM的操作,从而将数据存储空间扩展了32k。

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

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

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

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


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); 大功率电感厂家 |大电流电感工厂
  • 大功率单片开关电源设计
    摘 要:本文介绍了基于TOP249Y的250W开关电源,结合PI公司的PI Expert 7.0软件设计出了该单片开关电源的关键元件变压器,并对该电源进行了分析和相关测试。关键词:单片开关电源;集成开
  • 同步降压转换器的布局注意事项
    降压 DC/DC 转换器(见图 1)是一种非常受欢迎的开关 DC / DC 稳压器拓扑,广泛应用于许多电气和电子,从云基础设施到个人电子产品,再到工厂和楼宇自动化。它们占据了当今所有非隔
  • 液晶面板的TN屏、VA屏和IPS屏有什么区别
    4月08日 第三届·无线通信技术研讨会 立即报名 12月04日 2015•第二届中国IoT大会 精彩回顾 10月30日ETF•智能硬件开发技术培训会 精彩回顾 10月23日ETF•第三届 消费
  • 大功率电感