异构计算机软件移植可视化仿真技术研究的论文.docVIP

异构计算机软件移植可视化仿真技术研究的论文.doc

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

  异构计算机软件移植可视化仿真技术研究的论文 摘要:针对控制系统开发中程序调试难的问题,分析了计算机体系结构和指令系统,研究异构计算机软件移植可视化仿真技术,并设计了软件移植的可视化仿真系统。实验表明,该方法能解决异构机之间软件兼容和移植问题,提高了控制系统开发的效率。 关键词:异构计算机;软件移植;可视化仿真;指令系统 微机已经广泛应用于各种控制系统、智能仪器仪表、智能家电等领域。单片机性价比的提高,使单片机成为嵌入式系统的主流芯片。 目前,控制系统开发的常用方法是在pc机上编写和调试单片机系统程序。虽然,国内外有不少单片机开发系统,但由于单片机与pc机体系结构不同,用单片机指令编写的程序无法直接在pc机上运行,因此,系统开发时要有仿真器、编程器等专用设备,程序运行不能脱离单片机开发装置。因此,基于单片机的系统开发,源程序调试工作非常复杂,操作繁琐,调试结果的显示不够直观。针对上述情况,研究异构计算机软件移植可视化仿真技术,设计独立于单片机开发装置的可视化仿真系统,应用于控制系统和嵌入式系统的开发和实验具有重要的意义。本文在研究异构计算机软件移植可视化仿真技术的基础上,实现了在ibm-pc机上运行51系列单片机指令的可视化仿真系统,该仿真系统完全独立于单片机开发装置。 1软件移植概述 1.1软件移植方法 计算机系统层次模型[1]说明了各层次之间的关系及程序的执行情况。指令在计算机中执行的过程,实际上是指令由系统的高层逐级向低层转换的过程,从应用语言级直到微程序语言级,最后产生各种控制命令,驱动计算机的硬件完成指令功能。.高层语言转换为低层语言的实现方法有翻译法和解释法:翻译法是将高层程序变换成低一层等效程序,其处理流程可描述为 -pc机上执行由mcs51系列单片机指令系统所编写的汇编源程序,在分析mcs51单片机内部结构[2]的基础上,根据c语言的特点,同时兼顾程序运行的效率,合理地描述了系统设计所需的数据结构。 2.1程序存储器结构 mcs51内部虽然只有4kb的程序存储器,但在实际应用中可以在外部扩展至64kb,其内部有一个16位的程序计数器pc可寻址64kb以访问程序存储器。根据单片机指令结构[2]及c语言的数据类型关系,并考虑到程序仿真时并不会用到所有的存储单元,因此采用链式存储结构。程序存储器的数据结构描述如下: typedefstructprogmem {charopcode; unsignedlabel; //该条指令如果有标号,则存放其地址 charopnum1; charopnum2; charopnum3; pmemrecaddr; //存放当前指令的地址 pmemnextis; //指向下一条指令的地址 }memdata,*pmem; pmempc; 在结构体中,几个字符型变量分别用于存放指令的操作码和操作数,并用结构体指针变量存放当前指令及下一条指令的地址。仿真系统将单片机源程序翻译成目标代码放在程序存储器(结构体)中,通过结构体类型的指针变量可以访问程序存储器中的指令。 2.2数据存储器结构 mcs51将工作寄存器、端口和数据存储器统一编址,存储空间为256b。堆栈区设在30h~7fh,由堆栈指针sp指向栈顶。内部ram,除了工作寄存器、位标志、堆栈以外的单元,其余都可以当一般数据寄存器使用。如果内部数据存储器不够用,可以外接数据存储器,扩展至64kb。内部数据存储器在程序调试时需经常查看单元内容,且数量不大,因此将内部数据存储器定义为数组,堆栈指针定义为整型,并初始化为30h。 chardataram[256]; intramsp=0x30; 数据存储器单元的地址和数组的下标对应,这样在程序调试时,如果要查看内部数据存储器的内容,只要查看数据相应元素的值即可。另外定义一个结构体类型,模拟外部扩展的数据存储器,结构体定义如下: typedefexdataram {chardata; unsignedaddrram; //存放存储单元的地址,用于查询 exramptexdatap; }ramdata,*exrampt; 如果用到外部数据存储器,则将数据存在动态链式存储结构中,由于仿真程序运行时使用本机的存储器,因此其地址与仿真的单片机的地址不同,用一个变量addrram存放数据存储器的地址,以便于地址单元内的数据查询。 3软件移植的可视化仿真 软件移植可视化仿真系统,不仅要完成汇编指令的功能,而且应该根据要求查询程序执行后各寄存器的内容、端口的状态和运行结果。在系统开发过程中,我们详细分析了单片机指令格式[2]和计算机执行指令的过程[3],并根据仿真的速度要求,通过比较各语言的特点,选用visualc++语言和80x86汇编

文档评论(0)

ggkkppp + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档