资料介绍
简要介绍TMS320C64x系列数字信号处理器(DSP)flash加载的基本原理,详细论述TMS320C64x DSP与16-bit Flash接口的设计方法及用该方案加载的可行性及优点,给出.out文件到可供软件片上烧写的数据文件的编写方法。
l 引言
在仿真环境下调试DSP板程序之后,还有一项重要的工作要做:怎样实现程序代码的脱机加载。TMS320C6000系列DSP提供了3种引导方式:不加载、HPI加载以及Flash (ROM)加载。实际应用中,多采用外接Flash来加载程序代码。此种方法简单、灵活、成本低,因而受到广大工程技术人员的青睐。由于开发的DSP系统应用板最终要脱离仿真器独立运行,而TMS320C64x系列DSP本身不带这样的存储体,掉电后程序及数据就会丢失。这就需要1个能在断电后保存程序及初始化数据的存储体。Flash(ROM)即可满足这一需要。加载其实就是DSP系统板加电初始时刻,把Flash中的程序代码读人DSP的过程。
工程中的许多数据(如滤波器系数、FPGA配置文件、常数表格)常常使用16-bit的存储形式。如果把Flash设计为16-bit而不是8-bit形式,将成倍减少存取这些数据的时间,提高系统的实时性。然而,TMS320C64x只支持8-bit Flash加载。如果既能满足前者又不影响bootloader,将会更加方便工程应用。根据这种想法,笔者做了有益的尝试。
2 接口设计
本系统选用的Flash是AMD公司的AM291LV320D,存储容量为4Mx8 bit或2M×16 bit,满足CFI协议,易于编程,接口如图l所示。DSP与Flash是主从关系,由DSP通过EMIFB接口控制Flash的擦除和读写。其中,A0-A20为地址线,D15-DO为数据线,CE为片选信号,WE是写选通信号,OE为输出使能信号,BYTE为8位或16位数据模式选择(图中接VCC,为16位模式)。READY接高电平,擦除和编程Flash时用软件来检测是否成功写入。Flash用于存放引导程序段、用户代码及一些数据表,由DSP软件编程来写入。EMIFB只有20根地址线,最大可寻址l M空间,所以可以用现场可编程门阵列(FP-GA)或复杂可编程逻辑器件(CPLD)控制Flash高位地址作页选信号。

3 二级搬移程序的编写方法
TMS320C64x开机只自动加载l KB程序代码到内部RAM,所以通常要编写二次搬移程序加载剩余程序代码。二级搬移程序的大小不能超过1 K字节,且必须用汇编语言编写。这一部分通常把中断向量表改一下就可以实现,主要包括如下步骤:
(1)系统中所用的中断向量表不要更改,只把复位中断跳到搬移程序处(通常紧接中断向量表后),而不直接跳到C程序的入口点c_int00处;
(2)在搬移程序中配置DSP的EMIFB全局控制寄存器(GBLCTL)和空间控制寄存器(CElCTL)。按TMS320C64x文档说明和所用Flash数据手册配置读写时序,由于选用16-bit宽的Flash,所以MY-TYPE要定义为16-bit异步接口,建好系统软件和硬件沟通的平台。
(3)参照map文件编写搬移程序;
(4)跳到C程序入口点c_int00处,完成搬移程序的编写。
4 程序代码文件的提取及重组
由于Flash的设置与TMS320C64x默认的8-bitFlash加载不相同,所以必须根据COFF文件的格式重新从.out文件中提取数据信息。程序流程如图2所示。要提取的数据代码是初始化段和可执行代码段,这些信息可从COFF文件的段头(section head-er)获得。非初始化段是在程序运行时才分配空间的,所以不提取其数据。当可执行代码段是搬移段(通常是第一个)时,要把代码重新组合后再存储,目的是便于Flash烧写程序的编写。
由于.out文件的代码是32-bit存储形式,所以读一次文件要读取4字节代码,代码重组是要把4字节变成4个16-bit的形式依次存储起来。例如,某次读得的代码是0x11223344,代码重组后16-bit形式是(递增顺序):0x0044,0x0033,0x0022,Ox001l。再把这些代码以16-bit形式依次写入新的xx.bin文件0~400h(16-bit宽)处,不足的写入0;对于其他代码依据.out文件中的地址变化依次写入xx.bin文件的400h之后。

l 引言
在仿真环境下调试DSP板程序之后,还有一项重要的工作要做:怎样实现程序代码的脱机加载。TMS320C6000系列DSP提供了3种引导方式:不加载、HPI加载以及Flash (ROM)加载。实际应用中,多采用外接Flash来加载程序代码。此种方法简单、灵活、成本低,因而受到广大工程技术人员的青睐。由于开发的DSP系统应用板最终要脱离仿真器独立运行,而TMS320C64x系列DSP本身不带这样的存储体,掉电后程序及数据就会丢失。这就需要1个能在断电后保存程序及初始化数据的存储体。Flash(ROM)即可满足这一需要。加载其实就是DSP系统板加电初始时刻,把Flash中的程序代码读人DSP的过程。
工程中的许多数据(如滤波器系数、FPGA配置文件、常数表格)常常使用16-bit的存储形式。如果把Flash设计为16-bit而不是8-bit形式,将成倍减少存取这些数据的时间,提高系统的实时性。然而,TMS320C64x只支持8-bit Flash加载。如果既能满足前者又不影响bootloader,将会更加方便工程应用。根据这种想法,笔者做了有益的尝试。
2 接口设计
本系统选用的Flash是AMD公司的AM291LV320D,存储容量为4Mx8 bit或2M×16 bit,满足CFI协议,易于编程,接口如图l所示。DSP与Flash是主从关系,由DSP通过EMIFB接口控制Flash的擦除和读写。其中,A0-A20为地址线,D15-DO为数据线,CE为片选信号,WE是写选通信号,OE为输出使能信号,BYTE为8位或16位数据模式选择(图中接VCC,为16位模式)。READY接高电平,擦除和编程Flash时用软件来检测是否成功写入。Flash用于存放引导程序段、用户代码及一些数据表,由DSP软件编程来写入。EMIFB只有20根地址线,最大可寻址l M空间,所以可以用现场可编程门阵列(FP-GA)或复杂可编程逻辑器件(CPLD)控制Flash高位地址作页选信号。

3 二级搬移程序的编写方法
TMS320C64x开机只自动加载l KB程序代码到内部RAM,所以通常要编写二次搬移程序加载剩余程序代码。二级搬移程序的大小不能超过1 K字节,且必须用汇编语言编写。这一部分通常把中断向量表改一下就可以实现,主要包括如下步骤:
(1)系统中所用的中断向量表不要更改,只把复位中断跳到搬移程序处(通常紧接中断向量表后),而不直接跳到C程序的入口点c_int00处;
(2)在搬移程序中配置DSP的EMIFB全局控制寄存器(GBLCTL)和空间控制寄存器(CElCTL)。按TMS320C64x文档说明和所用Flash数据手册配置读写时序,由于选用16-bit宽的Flash,所以MY-TYPE要定义为16-bit异步接口,建好系统软件和硬件沟通的平台。
(3)参照map文件编写搬移程序;
(4)跳到C程序入口点c_int00处,完成搬移程序的编写。
4 程序代码文件的提取及重组
由于Flash的设置与TMS320C64x默认的8-bitFlash加载不相同,所以必须根据COFF文件的格式重新从.out文件中提取数据信息。程序流程如图2所示。要提取的数据代码是初始化段和可执行代码段,这些信息可从COFF文件的段头(section head-er)获得。非初始化段是在程序运行时才分配空间的,所以不提取其数据。当可执行代码段是搬移段(通常是第一个)时,要把代码重新组合后再存储,目的是便于Flash烧写程序的编写。
由于.out文件的代码是32-bit存储形式,所以读一次文件要读取4字节代码,代码重组是要把4字节变成4个16-bit的形式依次存储起来。例如,某次读得的代码是0x11223344,代码重组后16-bit形式是(递增顺序):0x0044,0x0033,0x0022,Ox001l。再把这些代码以16-bit形式依次写入新的xx.bin文件0~400h(16-bit宽)处,不足的写入0;对于其他代码依据.out文件中的地址变化依次写入xx.bin文件的400h之后。

下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- 从TMS320C64x迁移到TMS320C64x+
- TMS320C64x超级模块
- TMS320C64x DSP参考设计
- 在基于TMS320C64x的DSP平台上运行TMS320C64x编解码器
- TMS320F280x、TMS320C280x、TMS320F2801x数字信号处理器数据表
- TMS320F280x、TMS320C280x、TMS320F2801x数字信号处理器数据表
- TMS320C54x,LC54x,VC54x 定点数字信号处理器的详细介绍和对比 7次下载
- TMS320VC5501和TMS32VC5502数字信号处理器引导加载程序详细概述 3次下载
- TMS320C64x和数字信号存储系统在DSP应用中的缓存应用详细资料概述 14次下载
- TMS320C64x to TMS320C64x+ CPU 迁移指南 2次下载
- TMS320C6474数字信号处理器硅修订2.1, 1.2, 1.1, 1.0 勘误表 4次下载
- TMS320C64x+ DSP 大字节DSP库 程序员参考 7次下载
- TMS320C54x数字信号处理器硬件结构 0次下载
- TMS320C64x的.Flash设计及B ootloade
- TMS320C64x的.Flash设计及B ootloade
- 数字信号处理器的特点、作用及种类 4.5k次阅读
- 简单认识数字信号处理器 2.2k次阅读
- 中科昊芯推新版HXS320F28034数字信号处理器DSP 5.2k次阅读
- 基于TLl6C550C实现数字信号处理器与PC机串行通信的应用设计 2.1k次阅读
- 基于TI TMS320C6748定点/浮点DSP C674x处理器 3.8k次阅读
- 浅谈数字信号处理器的分类及选择 6.8k次阅读
- 一文了解dsp数字信号处理器 6.5k次阅读
- TMS320C6748和TMS320C6747芯片对比 1.9w次阅读
- tms320c6748异步接口访问相关问题 5.1k次阅读
- tms320c6748主要参数和原理图 tms320c6748 IO图浅析 1.7w次阅读
- dsp tms320c6000基本作用的认识 1.1w次阅读
- 数字信号处理选型和介绍 8.2k次阅读
- TMS320C6678处理器的VLFFT演示探讨与研究 5.1k次阅读
- DSP是什么?详解DSP又称数字信号处理器 5.1w次阅读
- 基于TMS320DSC2x的数字网络摄像机设计 786次阅读
下载排行
本周
- 1冷柜-电气控制系统讲解
- 13.68 MB | 4次下载 | 10 积分
- 2安川A1000变频器中文版说明书
- 20.16 MB | 3次下载 | 3 积分
- 3直流电路的组成和基本定律
- 1.67 MB | 2次下载 | 免费
- 4丹佛斯2800系列变频器说明书
- 8.00 MB | 1次下载 | 5 积分
- 5PC8011同步开关型降压3.5A单节锂电池充电管理电路技术手册
- 0.74 MB | 1次下载 | 免费
- 6ES7243E+ES8311音频录制与播放电路资料
- 0.06 MB | 1次下载 | 5 积分
- 7SDM02 激光测距模块产品手册
- 0.43 MB | 1次下载 | 免费
- 8SDFM 激光测距模块模组手册
- 0.54 MB | 1次下载 | 免费
本月
- 1CH341编程器软件NeoProgrammer_2.2.0.10
- 20.47 MB | 170次下载 | 1 积分
- 22025智能家居传感器市场分析及创新应用
- 3.11 MB | 43次下载 | 免费
- 3RV1126B系列开发板产品资料
- 4.19 MB | 18次下载 | 免费
- 4CH341编程软件下载
- 2.50 MB | 16次下载 | 5 积分
- 5全志系列-米尔基于T153核心板开发板 四核异构、3路千兆网,赋能多元化工业场景
- 3.05 MB | 12次下载 | 免费
- 6【开源】60余套STM32单片机、嵌入式Linux、物联网、人工智能项目案例及入门学习资源包
- 10.55 MB | 8次下载 | 免费
- 7冷柜-电气控制系统讲解
- 13.68 MB | 4次下载 | 10 积分
- 8特斯拉MODEL S车载充电机主电路回路原理图
- 0.81 MB | 4次下载 | 3 积分
总榜
- 1matlab软件下载入口
- 未知 | 935137次下载 | 10 积分
- 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
- 1.48MB | 420064次下载 | 10 积分
- 3Altium DXP2002下载入口
- 未知 | 233094次下载 | 10 积分
- 4电路仿真软件multisim 10.0免费下载
- 340992 | 191448次下载 | 10 积分
- 5十天学会AVR单片机与C语言视频教程 下载
- 158M | 183356次下载 | 10 积分
- 6labview8.5下载
- 未知 | 81604次下载 | 10 积分
- 7Keil工具MDK-Arm免费下载
- 0.02 MB | 73824次下载 | 10 积分
- 8LabVIEW 8.6下载
- 未知 | 65991次下载 | 10 积分
电子发烧友App





创作
发文章
发帖
提问
发资料
发视频
上传资料赚积分
评论