- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
最近下载
- 音响系统施工方案.docx
- 《C#程序设计》课程教学大纲.doc VIP
- 儿童呼吸科课程设计.docx VIP
- (高清版)B-T 9254.2-2021 信息技术设备、多媒体设备和接收机 电磁兼容 第2部分:抗扰度要求.pdf VIP
- 公园音响系统安装方案.docx VIP
- 跌倒、坠床与压疮的预防与护理.pptx
- 医院建筑工程施工方案(3篇).docx VIP
- 心肺复苏ppt讲课开场白.pptx VIP
- (高清版)B-T 9254.1-2021 信息技术设备、多媒体设备和接收机 电磁兼容 第1部分 发射要求.pdf VIP
- 基于模型的系统工程(MBSE)及MWORKS实践 课件全套 聂兰顺 第1--10章 引论、 MBSE语言、工具、方法论---MBSE未来发展趋势.pptx
文档评论(0)