- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
如何通过网络接口实现DSP片外Flash在线系统编程_计算机论文.doc
如何通过网络接口实现DSP片外Flash在线系统编程_计算机论文
如何通过网络接口实现DSP片外Flash在线系统编程_计算机论文
摘要:文章针对传统设计采用RS232作为数据传输手段而造成的速度过慢的问题,设计了一种通过网络接口,使用一种特殊的UDP包对BF531片外Flash在线系统编程的方案,并给出了在系统编程的具体步骤和实现结果。实践证明该方法无须实现TCP/IP协议栈,速度快,体积很小,很好地解决了以DSP为核心的应用系统软件的维护和升级问题。
关键词:BF531;Flash;网络接口;ISP;UDP
在以DSP为核心的现代电子设备中,通常将可执行代码存放在Flash中,设备启动的时候,DSP通过引导加载机制将Flash中的代码转移到高速存储器中运行。Flash在系统编程(ISP)是指以在不改变硬件环境的条件下,在线将程序代码(固件)下载到Flash中,从而方便地实现系统软件的调试和升级。BF531是ADI公司生产的一款高性能DSP。ADI公司在其软件VDSP下提供了通用的在系统编程工具“FlashProgrammer”,但是该工具需要使用JTAG接口,并且需要专用仿真器。另外一种方法是采用RS232作为通信接口,通过一段引导程序来进行Flash的在系统编程,缺点是速度很慢。由于目前大多数电子仪器都已经具有网络接口,本文设计了一种通过网络接口进行Flash在系统编程的方案。采用的网络接口芯片为常见的DM9000a,由于网络通信中常见的TCP/IP协议栈过于庞大,本文中未使用协议栈,而是设计了一种简单的实现方法:直接构建含特殊标记头的UDP广播包来代替。
一、BF531的Flash启动加载过程
LDR文件是最终烧写到FLASH上面的程序文件,可以有多种格式。这里,我们生成的LDR文件是二进制格式,LDR文件分为多个块,每个块都分为一个“BLOCK”和一个10字节的“HEAD”。在“HEAD”中,头四个字节表示块应加载在BF531地址空间的地址,后四个字节表示“BLOCK”的大小,最后两个字节表示块的属性。
BF531芯片本身已经提供了4种启动代码加载方式,通过启动模式引脚BMODE来选择,本设计中将该引脚设置为最常见的“01”模式,即“从8/16位的FLASH/PROM启动”模式。
BF531内部有一个BOOTROM区,用以存放“引导核”,BF531启动的时候会先运行该引导核,自动将从Flash起始地址0x2000000开始的LDR文件分块按照用户的要求分别加载到片内RAM和SDRAM中。加载完毕后,引导核会修改程序指针PC,使之为片内RAM的启动地址0xFFA08000,启动用户自己的应用程序。
二、总体设计
需要设计一个Bootloader程序和一个与之配合的上位机程序,并将Bootloader烧在地址0。DSP启动后,“引导核”会自动启动该程序,Bootloader程序延时判断上位机是否发出了连接命令。如果有,进入更新固件模式,可以进行Flash的烧写;否则,则进入正常启动模式,用以加载并执行用户程序。
(一)Bootloader与用户程序
根据上面所述,启动的顺序是:“引导核”自动启动Bootloader,运行完成后再加载运行用户程序。所以Bootloader程序应该独立于用户程序,因为Bootloader一般不需要更新,而且,在系统编程出现意外的时候,不会导致Bootloader被破坏。由于Bootloader需要在启动的时候就运行,所以应该事先通过JTAG使用仿真器将其烧写到地址0。而对于常用的NorFlash,编程的时候会先把相应的整个扇区擦除,所以为了方便编程,应该使用户程序的LDR文件的起始烧写地址固定,并且为一个扇区的起始地址,本设计中固定为0
(二)网络通信协议设计
嵌入式仪器一般资源都比较少,所以Bootloader体积应该设计的尽量的小。最常用的网络通信协议为TCP/IP协议栈,虽然功能强大,但是体积过于庞大。考虑Bootloader只需要网络接口完成最简单的通讯功能,而且通信量很小,本文设计了一种简单的方法:直接构建含特殊标记头的UDP广播包。
详细的实现方法:上位机端发送数据的时候,在普通的UDP包的“payload”区加上一个自定义字符串的“标记头”,并定义为广播包,发送。Bootloader端接受时采用“杂散模式”接受,直接分析网络芯片DM9000A接受到的数据,如果发现是UDP包并且具有自定义字符串的“标记头”,则接受,否则,抛弃。相反,Bootloader端发送数据的时候,按照UDP包标准格式直接手动填充一个完整的UDP广播包,并加上“标记头”,
您可能关注的文档
- 大型水工构筑物结露问题与消除方法_工程建筑论文.doc
- 大型江边泵房沉井施工_工程建筑论文.doc
- 大型灌区续建配套及节水改造综合效益浅析_计算机论文.doc
- 大型火电厂125MW循环流化床锅炉机组控制系统设计与安装调试分析_电子机械论文.doc
- 大型设备安装工程中的电气接地保护技术分析探讨_工程建筑论文.doc
- 大型超市客流量的调查与分析_工程建筑论文.doc
- 大学校园外部空间的叙事性建构_工程建筑论文.doc
- 大学校园规划的整体设计 _工程建筑论文.doc
- 大学生网络社团存在的问题与对策_计算机网络论文.doc
- 大学生网络购物态度形成的影响因素研究_计算机网络论文.doc
- 庭审中心主义下直接言词原则的多维审视与实践进路.docx
- 湘教版八年级上册数学精品教学课件 第2章 阶段综合训练【范围:2.5~2.6】.ppt
- 创业板首批上市公司中PE、IPO与道德风险的深度剖析与启示.docx
- 脑萎缩的护理.pptx
- 湘教版八年级上册数学精品教学课件 第3章 专题强化训练(三) 训练 实数的运算.ppt
- 高血压对第四脑室外侧隐窝室管膜影响的深度剖析:基于形态学视角.docx
- 华师版七年级上册数学精品教学课件 第2章 整式及其加减 2.1 列代数式 3.列代数式 (3).ppt
- 北师版七年级上册数学精品教学课件 第六章 数据的收集与整理 2 数据的收集 第1课时 数据的收集 (2).ppt
- 脑血栓形成护理.pptx
- 大连旅桑一馆市场营销策略:基于市场环境与竞争态势的剖析与创新.docx
最近下载
- 管理学案例两面针公司.ppt VIP
- Roland罗兰GW-8说明书 中文.pdf VIP
- 亚吉铁路运营现状及问题分析.pdf VIP
- 2025年下半年新疆塔城地区急需紧缺人才引进243人笔试参考题库附答案解析.docx VIP
- 大理州旅游美宿基本要求与评价.pdf VIP
- 2025年国开电大机考网考题库04008_理工英语4.doc VIP
- 中建EPC项目总承包管理方法与实务2024.docx
- 2025年下半年新疆塔城地区急需紧缺人才引进243人笔试模拟试题及答案解析.docx VIP
- 2025年下半年新疆塔城地区急需紧缺人才引进243人笔试备考题库附答案解析.docx VIP
- 2025年铁路列车员(中级)职业技能鉴定参考试题库-下(判断题汇总).docx VIP
文档评论(0)