电子科技大学微处理器系统结构与嵌入式系统设计实验一.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

电子科技大学 实 验 报 告 课程名称 微处理器系统结构与嵌入式系统设计 实验名称 ARM汇编基础实验 任课教师 XXX 实验教师 XXX 姓名 黑XX 学号2012XXXXXXXXX 实验地点 XXXXXXX 分组号 X组 时间 XXXX年 X月X日XX:XX~XX:XX 实验目的 1.掌握ARM汇编指令。 2.学习掌握C与汇编混合编程基础。 3.熟练使用ARM调试工具RVDS进行调试操作。 实验内容 1.熟悉ARM汇编。 2.用ARM汇编实现1+2+...+N。 3.C调用汇编实验(实现字符串拷贝功能)。 4.汇编调用C实验。 5.ARM汇编实现冒泡算法(选做) 三、实验步骤 1)用ARM汇编实现1+2+….n的运算。在sum.s文件中,添加如下代码: SUN_L1 ADD R0,R1 BVS SUM_END CMP R1,R2 BHS SUM_END ADD R1,#1 B SUN_L1 理解C和汇编,并用汇编程序实现字符串拷贝,并在C程序中调用该汇编程序。在汇编文件testfile1.s中添加两行汇编代码,实现:拷贝源字符串的一个字节到R2中,将拷贝的字节复制到目标空间。关键代码如下: strcopy ;------------------------------------------ ;用汇编实现字符串拷贝 LDRB R2,[R1],#1 ;R1对应源字符串首地址,利用寄存器间接寻址读取字符到R2 STRB R2,[R0],#1 ;R0对应目的字符串首地址,利用寄存器间接寻址保存字符 CMP R2,#0 BNE strcopy MOV PC,LR ;------------------------------------------ END ;文件结束 3)在汇编中调用C函数。 在汇编文件testfile2.s中相应位置添加汇编代码,通过调用c函数g()实现1+2+3+glovb1,结果存在R8中。关键代码如下: STR LR,[SP,#-4]! MOVS R0,#1 MOVS R1,#2 MOVS R2,#3 LDR R4,=glovb1 LDR R3,[R4] ;传递参数 BL g MOV R8,R0 ADD sp,sp,#4 LDR pc,[sp],#4 实验结果 在实验1中,通过伪指令EQU,定义N的值。编译运行后,通过跟踪、调试,实现了对1+2+….n的累加运算。 在实验2中,编译运行后,经过跟踪调试,实现了在C语言中调用汇编函数strcopy。 在实验中,编译运行后,经过跟踪调试,实现了在汇编语言中调用C语言中的全局变量和全局函数。 五、实验总结 在本次实验中,通过汇编程序直接对ARM处理器中的寄存器进行操作,掌握了汇编程序设计的基础知识。更全面、更深入地理解了ASM处理器的工作原理,为基于ARM处理器的嵌入式软硬件开发奠定良好的基础。在嵌入式软件开发过程中,通常会使用ARM汇编语言和C/C++语言在内的多种语言,通过本次实验,初步认识了ARM汇编语言与高级程序设计语言混合编程的原理和基本方法。 六、实验思考题 1、add替换成adds ,sub替换成subs有什么影响。 使用ADDS、SUBS指令会影响标志寄存器中CPSR中的值 2、mov替换成movne有什么影响? MOVNE先判断条件NE (不相等)则转移,可以看作是两条指令 3、STMIA换成STMIB ,STMIA换成STMDA有什么区别。 STMIA指令完成操作后地址递增,而STMIB是指令完成操作前地址递增。STMIA指令是完成操作后地址递增,STMDA指令完成操作而后地址递减。 思考用ARM汇编实现1+3+5+….+(2n+1)或者2+4+6+…..+2n。 ;SUM_N ;功能:计算2+4+6+…..+2n; 入口参数:R0 N的值 ;出口参数:R0 运行结果 ;占用资源:R0 ;说明:当N=0时结果为0 ;若运算溢出,结果为0 SUM_N PUSH {R1-R7,LR} ;寄存器入栈保护 MOVS R2,R0 ;将n的值复制到R2,并影响相应条件标志 BEQ S

文档评论(0)

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

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

1亿VIP精品文档

相关文档