老古开发网首页
导航:老古开发网首页文章索引文章分类DSP数字信号处理→[TI C54xx DSP 十天速成讲义 <九>]
| -文章搜索 - 最新文章 - |

TI C54xx DSP 十天速成讲义 <九>

发布时间:2006年6月18日 点击次数:1338
来源:   作者:
 
实验八 程序加载
C5000 DSP没有内部提供掉电保存程序的ROM/EPROM/Flash,上电时需要从外部加载应用程序。C5000
DSP提供了多种程序加载方式,满足不同应用的需要:串行加载、并行加载、HPI加载等,实际应用最多的是并行加载,本实验主要介绍8位并行存贮器加载。
加载过程:DSP上电时,如果MP/MC引脚为低电平,则跳转到内部ROM的FF80中断向量表的Reset中断,该处有一个跳转指令转到称为Bootloader的加载程序执行,该程序的功能是按照一定顺序查找可用的加载方式,如果找到,则开始加载应用程序,加载完毕转向应用程序执行。
实现并行存贮器加载的关键是建立一个加载表(boot
table),该表包括:一个或多个程序代码段、部分需要初始化的寄存器值、程序入口等信息。CCS附带有一个应用程序(C5000系列是hex500.exx)可以把.out程序转成.hex格式的加载表,然后可以烧录到非易失性存贮器中,如OTP/EPPOM/EEPROM/Flash中。
具体步骤:
1.修改项目的编译选顶,使其生成可以转化成加载表的.out文件格式
2.为hex500.exe建立一个配置文件
3.用hex500.exe把*.out转化成加载表*.hex
4.在.hex未尾加上加载表起始地址
5.烧录到非易失性存贮器中
6.安到目标板上进行加载实验

各步骤详述如下:
1.修改项目的编译选顶,使其生成可以转化成加载表的.out文件格式
在Project/Build Option…/Complier 里面加一个选项:-v548,或在Basic/Process
verson一栏中填写:548,然后点确定。
注意:如果不加这个选项,用hex500程序转化出来的hex文件无法加载。
2.为hex500.exe建立一个配置文件
这个配置文件包含了hex500程序执行所需要的选顶,下面是一个样板配置文件hex.cmd:
sample.out /* 待转化的程序文件*/
-map hex.map /* 生成一个map文件便于查看转化结果*/
-o hex.hex /* 输出文件名*/
-i /* 输出文件为Intel Hex 文件格式 */
-memwidth 8 /* 目标系统的存贮器为8位*/
-romwidth 8 /* 存贮器芯片的位宽为8位*/
-boot /* 生成加载表*/
-bootorg 0000h /* 加载表在存贮芯片中的起始位置*/
-e 80h /* 程序入口,即加载完毕后跳转执行程序位置 */

初学者容易弄错的是memwidth、romwidth和bootorg这三个选项。不同存贮器配置下设置不同,并且要注意的是上文注释的(包括TI资料中的解释)是程序脱机烧写的设置,而在系统烧录(EEPROM、Flash、NVSRAM可以支持)与脱机烧写又会有所不同。
脱机烧写指的是将存贮芯片放置在编程器里烧写,优点是直接可以利用hex500转化出来的hex文件,缺点是普通编程器无法烧写贴片封装的芯片。
在系统烧写相对灵活,但对不同系统,不同芯片需要编写专用的烧录程序,并且需要将hex文件进一步进行格式转换成烧录程序可以识别的程序。
不同情况设置方法如下表:
存贮器配置方案脱机烧写在系统烧写
8位存贮器-memwidth 8
-romwidth 8
16位存贮器-memwidth 16
-romwidth 16
两片8位贮器并行组成16位存贮器-memwidth 16
-romwidth 8-memwidth 16
-romwidth 16
bootorg芯片中的起始地址系统中的起始地址


3.用hex500.exe把*.out转化成加载表*.hex
在dos窗口下执行:hex500 hex.cmd
如果hex500.exe与hex.cmd以及待转化的程序文件不在同一目录下,需加上路径或设置path环境变量。

4.在FFFFH加上加载表起始地址
当开始并行加载时,Bootloader程序会在外部程序空间的FFFFH(如果是8位系统,同时也会查FFFEH)寻找加载表的地址,如果熟悉hex文件格式可以直接在hex文件末尾加一条纪录,也可以烧录器软件中加。

应用实例:
本实验箱是用于程序加载的是8位EPROM或EEPROM,可以用脱机方式,如用EEPROM也可以用在系统方式。Hex500程序的配置文件如前hex.cmd文件,只需要把第一行的sample.out换成实际的程序名称。EPROM/EEPROM在程序空间的地址为8000H,并且由于是8位系统,则要在FFFEH和FFFFH的值分别设为80H、00H。可以在生成的.hex文件倒数第二行加上:
:027FFE00800001
也可以在烧录器软件中修改FFFEH-FFFFH处的值,然后就可以烧写了。
烧写好后,将芯片安置在IC座中,确认MP/MC跳线置为低电平,INT3、INT2的跳线置于悬空后,打开电源,就可以看到程序运行的状况。

欢迎进入老古论坛进行讨论
[DSP数字信号处理] 相关文章:
TI C54xx DSP 十天速成讲义 <三>
简介:
实验三 中断 中断的概念应该不陌生,指的是当某个事件发生时,暂停当前的操作,转向中断服务程序,执行完后再返回继续原来的操作。这使得DSP能够处理多个任务。 DSP有许多中断源,可以设置中断控制寄存器来确定响应哪些中断而不理会哪些中断。本实验介绍最常用的定时器中断和外部中断的使用方法,并介绍中断向量表和中断向量指针。 实验3.1 定时器中断:方波发生器 实验目的:学习定时器中断的设计方法 回顾一下实验一控制LED的闪烁实际就是一个简单的方波发生器。但不足的是延时的方法定时不精确,另外还有一个缺点是在执行延时的过程中DSP就无法执行其它指令,这时就可以用定时器来改进。 使用定时器首先要对它初......

TI C54xx DSP 十天速成讲义 <一>
TI C54xx DSP 十天速成讲义 <四>
TI C54xx DSP 十天速成讲义 <二>
TI C54xx DSP 十天速成讲义 <五>
TI C54xx DSP 十天速成讲义 <八>
TI C54xx DSP 十天速成讲义 <七>
ISP1362 USB OTG控制芯片及其应用[转]
TMS320VC5402通用I/O资源及其应用
32位CPU架构具有DSP指令和JAVA引擎
 
下一个:[DSP数字信号处理]TI C54xx DSP 十天速成讲义 <六>
简介:
实验六 DMA实验 实验目的:学习DMA的原理的使用方法 实验内容:用DMA方法接收McBSP接口语音芯片的数据 DMA是直接存储器存取,是一种传送不占用CPU处理时间的大批量数据传送的有效方式。我们用以下实例来说明它的应用: 如果我们要做一个音频处理系统,需要连续用McBSP接口的语音芯片采集若干个样本进行处理,比如频谱分析、音频压缩等。本例假设要每采集256个样本进行一次处理。上例用的是查询方式,占用了所有CPU资源。可以用中断方式,结合前面的实验不难做到,请同学们自行完成。在这个实验中我们将介绍一个更有效的DMA传送方式。我们比较一下用中断方式和DMA方式的效率有何不同: 一、中断......
 

上一个:[EDA/IC设计]在QuartusII中使用上述niosII系统

老古开发网版权所有 2006年9月 asp.Net V2.0 设计:老古
页面缓存:10分钟 执行时间:16毫秒