Flash做为DSP程序加载和引导
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Flash做为DSP程序加载和引导
1 引言
在现代数字信号处理系统中,采用Flash做为DSP程序加载和引导是一种常用的方法,它为用户对那些将来可能需要改变数据或代码的系统维护提供了有效手段。
利用Flash器件,能够实现在线程序编写,减少EPROM程序烧写带来的麻烦。
2 Flash AM29LV800B简介
Flash存储器又称闪存,它结合了ROM和RAM的特点,不仅具备电子可擦除可编程(EEPROM)功能,而且不会断电丢失数据同时能快速读取数据,它具有在线电擦写、低功耗、大容量、擦写速度快等特点,属于EEPROM的改进产品。
2.1主要性能
AM29LV800BB-90EC是AMD公司AM29LV800B系列的一种器件,其主要性能如下:访问时间:90 ns;存储容量:8Mbit;工作温度范围:-55~+125℃:在线编程电压:3.0~3.6 V;低功耗:读操作时电流为7 mA,编程/擦除时电流为15 mA。
2.2引脚功能说明
A0-A18:19根地址线;
DQ0-DQ14:15根数据线;
DQ15/A-1:当配置为16位字模式时,该引脚为数据I/O,组成16位字的最高位DQ15;当配置为8位字节模式时,该引脚为地址输入,为地址线的最低有效位A-1;
2.3工作模式
2.3.1读模式
为了读取数据,系统需将CE和OE设为低电平,同时将WE设为高电平。
在器件上电或硬件复位后,器件默认设置为读模式。
2.3.2写模式
为了向器件写入数据或指令,系统需将CE和WE置为低电平,同时将OE 置为高电平,写操作需要4个周期,前3个周期向两个特定地址写入3个特定字符,第4个周期将所需数据写入相应地址:
2.3.3复位
向器件的任意地址写入特定指令,该器件复位,复位后默认为读模式。
2.3.4自动选择模式
向器件两个特定地址写入3个特定的字符,该器件就进入自动选择模式。
在该模式下获取器件的厂商号和设备号,系统必须通过复位指令断开。
2.3.5擦除模式
片擦除是一个6周期操作,需向两个特定地址写入4个特定字符。
3 DSP与Flash接口设计
ADSP-TS201是ADI公司的TigerSHARC系列处理器的一种器件,其内核工作频率可高达600 MHz,指令周期为1.6 ns,片内存储器DRAM为24 Mbi
t,集成I/O接口,包括14通道的DMA控制器,4个链路口,可编程标志引脚,SDRAM控制器,外部端口,2个定时器等,具有IEEE 1149.1兼容的JTAG端口用于在线仿真,灵活的指令集和支持高级语言的DSP结构便于DSP编程。
ADSP片内无ROM,不能将应用程序和数据直接存储在DSP内部,通常需将应用程序存储在外部存储器。
系统工作时,通过加载操作将应用程序载人到DSP内部执行。
由于EPROM空间只提供8位数据线,因此如果Flash是16
位甚至更高位,那么Flash应当配置成8位工作。
由于EPROM接口是专门为处理器采用EPROM或者Flash进行程序引导而设计的,而EPROM和Flash 的数据传输并不是高速的,因此为了保证通用的EPROM和Flash能正确引导处理器运行程序,ADSP-TS201在进行每次EPROM读操作时需插入16个等待周期,并且在最后一个EPROM引导总线周期后有3个等待周期,用做EPRO M的断开时间。
ADSP-TS201提供BMS引脚用于引导存储器选择,作为Flash 的片选信号,实现系统加载。
此时TigerSHARC只能通过特定的DMA通道0
将程序从EPROM自动加载到TigerSHARC内存,并且外部总线自动将字节数据打包成32位指令。
另外TS201提供/MS0和/MS1引脚,用于存储器选择。
当DSP分别访问存储器bank0或bank1时,MS0或MS1有效。
该引脚也可用作Flash的片选信号,以实现Flash的在线编程。
按此方式实现硬件,可采用处理器内核或者非EPROM类型的DMA方式访问Flash,但是处理器不会自动完成32位字和8位字的打包和拆包,需要编写专门的打包程序,这点尤为重要。
其原理如图1所示。
4 对Flash加载的软件编程
本程序采用汇编语言,整个程序流程如图2所示。
当采用图1所示的连接时,ADSP-TS201向Flash写入一个字,由于DSP外部数据总线为[31:0],而Flash只连接了其中的低8位,因此DSP在向Flash写入数据时,需要先打包处理。
以下为本系统设计的关键程序代码。
擦除操作和擦除状态的查询对Flash非常重要,因为任何Flash器件的写入操作只能在空或已擦除的单元内进行,所以大多数情况下,在进行写入操作之前必须先执行擦除。
擦除操作可按6周期指令完成。
该操作将Flash的内容全部清零,然后从Flash的任意地址读取数据,与0相比较,判断擦除操作是否顺利进行。
相关指令代码如下:整个程序的流程如图2所示。
5结语
以Flash AM29LV800B为例,提出了Flash与DSP的硬件接口设计和Fl ash烧写程序的基本步骤。
这种系统设计使得软件设计相对简单,已多次应用于现代数字信号处理系统中应用,效果良好。