101129-ARM程序测试.doc_第1页
101129-ARM程序测试.doc_第2页
101129-ARM程序测试.doc_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

测验要求:l 请独立完成l 可以翻阅课本l 请直接在文档中作答一、 请根据程序设计要求,分别编写一段C语言程序和汇编语言程序1.分支程序设计判断大小(只需写出具体语句)1)判读X、Y两个变量的大小,从而给变量Z赋予不同的值 main(void) int X,Y,; If (XY) Z=100;ElseZ=50;2)判断56和68的大小,若前者大,给R0赋值50,反之赋值100 AREA COMPARE,CODE,READONLYCODE32ENTRYLDRB R0, R2 ;加载第一个数给寄存器R0MOV R3,#7 ;R3用来控制循环次数Min ADD R2, R2,#1 ;R2指向数组中下一个数LDRB R1, R2 ;加载下咯数给寄存器R1CMP R0, R1 ;R0与R1进行比较MOVHI R0, R1 ;如果R0大于R1,则将R1的值赋给R0END 2循环程序设计累加(要求可以正常运行)1)实现从1+3+5+21,并打印输出结果#include extern int SUM(int a,int b);int main()int num;num = SUM(1,21);printf(%d,num);return 0;2)实现从1+3+5+21,相加后的结果放在起始地址为0x40000020的存储空间里。AREA Example1,CODE,READONLY ; 声明代码段Example1 ENTRY ; 标识程序入口CODE32 ; 声明32位ARM指令START LDR R2,=0x40000020MOV R1,#1MOV R0,#1 ;R0保存求和的结果Loop ADD R1,R1,#1 ; ADD R0,R0,R1 ; R0=R0+R1CMP R1,#21 ;加到21?BNE LoopSTR R0,R2 ;保存相加后的结果到地址为0x40000020处END二、请指出下面汇编程序每一行中存在的问题,并进行修改STARTLDR R0,Count XYZ:Mov R1,#8 ADDR0,R0,R1B startEND 答:START要顶格写 XYZ不是指令 重复用了2个寄存器R0 B应该写成LOOP三、现有一份程序代码如下,问:程序的输出结果是什么?主程序入口是汇编程序还是C程序?请为每行代码添加注释。答:主程序入口是汇编程序EXPORT asmfileAREA My_pro, CODE, READONLYasmfile ;头文件STMFD SP!, R4-R6,R8,R7 ;保存必要的寄存器和返回地址到数据栈 add r0, r0, r1 ;加法指令add r0, r0, r2 ;加法指令mov r4, #600 ;数据传送mul r3, r0, r4 ;乘法指令mov r0, r3 ;R3的数据传送到R0LDMFD SP!, R4-R6,R8,R7 ;恢复寄存器值mov pc, lr ;数据传送END ;结束#include ;头文件extern int asmfile(int arg1, int arg2, int arg3); 定义数据int main(void) ;主程序int a1=1,a2=2,a3=4; ;定义a1=1,a2=2,a3=4;printf(Example of C Program calling Assembly program!n); 打印printf(%d + %d + %d) * 600 = %dn,a1,a2,a3,asmfile( a1, a2, a3); 打印四、已知一个函数库能实现对数组中数据查找最大值和最小值,现需要在函数库中添加一个函数,实现数组的累加,并最终在主程序中调用并打印累加结果。(程序清单见附件,含array.h文件、array.c文件和主程序uselib.c各一个。)问:那

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论