TMS320VC5402DSP的并行IO引导装载方法研究.docVIP

TMS320VC5402DSP的并行IO引导装载方法研究.doc

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
TMS320VC5402DSP的并行IO引导装载方法研究.doc

TMS320VC5402?DSP的并行I/O引导装载方法研究C5402主要特点如下[1]: *操作速率达100MIPS; *具有先进的多总线结构,三条16位数据存储器总线和一条程序存储器总线; *40位算术逻辑单元(ALU),包括一个40位桶形移位器和两个40位累加器; *一个17×17乘法器和一个40位专用加法器,允许16位带/不带符号的乘法; *整合维特比加速器,用于提高维特比编译码的速度; *单周期正规化及指数译码; *8个辅助寄存器及一个软件栈,允许使用业界最先进的定点DSP C语言编译器; *数据/程序寻址空间1M×16bit,内置4K×16bit ROM和16K×16bit RAM; *内置可编程等待状态发生器、锁相环(PLL)时钟产生器、两个多通道缓冲串行口、一个8位并行与外部处理器通信的HPI口、2个16位定时器以及6通道DMA控制器; *低功耗,工作电源有3V和1.8V(内核),特别适合电池供电设备。 由此可见,与TMS32054X系列的其它芯片相比,C5402以其独有的高性能、低功耗和低价格特性,使得一推出就受到业内用户的欢迎。但它的内部结构和片内掩模的引导装载(Bootloader)程序与C54X系列的其它DSP处理器[2]有较大的差异,而它的应用对象又大多是要求能脱机运行,如机顶盒(STB)、个人数字助理(PDA)和数字无线通信等内嵌式系统。为此,本文立足我们的实践经验,简单介绍C5402 Bootloader程序分析和实现方法,并较为详细地介绍并行I/O Bootloader方法。 1 几种引导装载方法 C5402 片内掩模的Bootloader用于在上电复位时把用户程序从外部引导到高速RAM中,以保证其全速运行。C5402提供了如下四种Bootloader 方法:8位或16位并行EPROM方法、8位或16位并行I/O方法、8位或16位串行口方法和处理器通信口(主端口)HPI方法。 上电复位后,C5402检测其MP/MC引脚,如果MP/MC=“0”则进入Bootloader程序。进入Bootloader后,如有INT2请求中断,则进入HPI引导方式,否则则读入端口地址为0FFFFH的I/O端的引导方式选择字(Boot Routine Selection,BRS)。当BRS=XXXX00时,进入I/O或串行口引导方式如BRS=XXXX1000时,进入8位I/O引导方式BRS =XXXX1100时,进入16位I/O引导方式,否则则进入串行口引导方式。当BRS=XXXX01时,进入8位EPROM引导方式,BRS=XXXX10时,进入16位EPROM引导方式。 2 C5402片内ROM结构及并行I/O引导装载程序分析 C5402 提供了4K×16bit 的掩模ROM,其具体内容见表1。C5402上电复位后,如果MP/MC=“0”则从F800h地址开始运行Bootloader程序。在进入8位并行 I/O引导程序以前,C5402与外部I/O要进行一系列的通信联络,其程序框图如图1所示。 ? 以下是8位并行I/O引导程序片段下: 行号 源程序 注 解 (标号) .. END?????????????;读入用户代码结束 ????????????????;并转执行用户程序 1 CALL (21)  ;调用读数据子程序 2 STL?????B,61h ;B的内容→61H单元 3 CALL  (21)??;调用读数据子程序 4 STL?????B,61h ;B的内容→62H单元 5 CALL (21)  ;调用读数据子程序 6 BC (END), BEQ ;B=0时结束 7 SUB #01h,0,B,B ;B-1→B 8 STLM??B,BRC;B→BRC 9??CALL (21)  ;调用读数据子程序 10 STL????B, 68h ;B的内容→68H单元 11 CALL (21)  ;调用读数据子程序 12 ADD 68h,16,B,B ;68H移位后加B→B 13 LD???B,0,A?????;B→A 14 RPTD (20)-1; 循环15-19?????????????? 15??CALL (21)  ;调用读数据子程序 16 SSBX?????XF????;XF=1 17 BC ??(17),BIO;BIO=0则等待 18 WRITA???B????;把B的内容写到*A 19 ADD #01h,0,A,A ;A+1→A 20 B  (5) ??????;跳转到标号为5 21 SSBX???XF???????;XF=1 22 BC (22),BIO???;BIO=0则等待 23 RXBX?????XF?????;XF=0 24 BC (24),NBIO??;BIO=1则等

文档评论(0)

天马行空 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档