第1页共8页题号一二三四五六七八九十总分累分人签名题分40122424100得分考生注意事项:1、本试卷共5页,请查看试卷中是否有缺页或破损。如有立即举手报告以便更换。2、考试结束后,考生不得将试卷、答题纸和草稿纸带出考场。一、填空题(每空2分,共40分)得分评阅人1、ARM微处理器有7种工作模式,它们分为两类非特权模式、特权模式。其中用户模式属于非特权模式2、ARM支持两个指令集,ARM核因运行的指令集不同,分别有两个状态ARM、Thumb,状态寄存器CPSR的T位反映了处理器运行不同指令的当前状态3、ARM核有多个寄存器,其中大部分用于通用寄存器,有小部分作为专用寄存器,R15寄存器用于存储PC,R13通常用来存储SP4、ARM处理器有两种总线架构,数据和指令使用同一接口的是冯诺依曼,数据和指令分开使用不同接口的是哈佛结构第2页共8页5、ARM微处理器复位后,PC的地址通常是0x0,初始的工作模式是Supervisor。6、ARM微处理器支持虚拟内存,它是通过系统控制协处理器CP15和MMU(存储管理部件)来进行虚拟内存的存储和管理。当系统发生数据异常和指令领取异常时,异常处理程序透过嵌入式操作系统的内存管理机制,通过MMU交换物理内存和虚拟内存的页面,以保证程序正常执行。7、编译链接代码时,有两种存储代码和数据的字节顺序,一种是小端对齐,另一种是打断对齐8、构建嵌入式系统开发环境的工具链有多种,其中开放源码的工具链是GNU工具链,ARM公司提供的工具链是ADS工具链9、计算机有CISC和RISC两种类型,以ARM微处理器为核心的计算机属于RISC、类型,其指令长度是定长的。二、指令测试题(共12分)1、写一条ARM指令,完成操作r1=r2*3(4分)ADDR1,R2,R2,LSL#12、初始值R1=23H,R2=0FH执行指令BICR0,R1,R2,LSL#1后,寄存器R0,R1的值分别是多少?(4分)R0=21H,R1=23H3、说明指令STMIAr12!,{r0-r11}的操作功能。(4分)将R0-R11十二个寄存器中的32位数据,存储到R12地址指针为起始地址的内存中,地址的操作方式是先操作、后增加,并更新地址。4、写一段ARM汇编程序:循环累加队列myarray中的所有元素,直到碰上零值元素,结果放在r4中。程序框架如下,补充代码完成上述功能。(8分)第3页共8页AREAtotal,CODEREADONLYENTRYstartMOVr4,#0ADRr0,myarray;在此补充代码loopLDRr1,[r0],#4ADDr4,r4,r1CMPr1,#0BNEloop5、这是一个由源程序strtest.c和scopy.s组成的混合程序项目,通过调用strcopy完成字符串复制,程序代码如下。要求阅读程序,在程序中的注释符“//”后,说明该句程序的作用,并说明extern和EXPORT伪指令的在程序中的作用。(8分)strtest.c#includestdio.hexternvoidstrcopy(char*d,constchar*s);intmain(){constchar*srcstr=Firststring-source;chardststr[]=Secondstring-destination;printf(Beforecopying:\n);printf('%s'\n'%s'\n,srcstr,dststr);//strcopy(dststr,srcstr);//printf(Aftercopying:\n);printf('%s'\n'%s'\n,srcstr,dststr);//return0;}scopy.sAREASCopy,CODE,READONLYEXPORTstrcopystrcopyLDRBr2,[r1],#1;STRBr2,[r0],#1;CMPr2,#0;BNEstrcopy;MOVpc,lr;END//输出源串和目标串(8分)//调用strcopy函数//输出复制后的源串和目标串;r1指向源串,从源串载入一个字节的字符到r2,并更新r1=r1+1第4页共8页;r0指向目标串,从r2保存一个字节的字符到目标串,并更新r0=r0+1;测试串尾标志\0;非零转标号strcopy;返回三、程序测试题(共24分)1、写一段ARM汇编程序:循环累加队列myarray中的所有元素,直到碰上零值元素,结果放在r4中。程序框架如下,补充代码完成上述功能。(8分)AREAtotal,CODEREADONLYENTRYstartMOVr4,#0ADRr0,myarray;在此补充代码答:loopLDRr1,[r0],#4ADDr4,r4,r1CMPr1,#0BNEloopstopBstopmyarrayDCD0x11DCD0x22……DCD0x0END2、有如下程序段,画出程序流程图,并回答执行程序以后R0的值是多少。(8分)numEQU2startMOVr0,#0MOVr1,#5MOVr2,#2BLfuncstopBstopfuncCMPr0,#numMOVHSpc,lrADRr3,JumpTableLDRpc,[r3,r0,LSL#2]第5页共8页JumpTableDCDDoADCDDoSDoAADDr0,r1,r2MOVpc,lrDoSSUBr0,r1,r2MOVpc,lrEND答:R0为0调用DoA,R0为1调用DoS,R0大于2直接返回,流程图略。R0=73、这是一个由源程序strtest.c和scopy.s组成的混合程序项目,通过调用strcopy完成字符串复制,程序代码如下。要求阅读程序,在程序中的注释符后,说明该句程序的作用,并说明extern和EXPORT伪指令的在程序中的作用。(8分)strtest.c#includestdio.hexternvoidstrcopy(char*d,constchar*s);intmain(){constchar*srcstr=Firststring-source;chardststr[]=Secondstring-destination;printf(Beforecopying:\n);printf('%s'\n'%s'\n,srcstr,dststr);//输出源串和目标串strcopy(dststr,srcstr);//调用strcopy函数printf(Aftercopying:\n);printf('%s'\n'%s'\n,srcstr,dststr);//输出复制后的源串和目标串return0;}scopy.sAREASCopy,CODE,READONLYEXPORTstrcopystrcopyLDRBr2,[r1],#1;r1指向源串,从源串载入一个字节的字符到r2,并更新r1=r1+1STRBr2,[r0],#1;r0指向目标串,从r2保存一个字节的字符到目标串,并更新r0=r0+1CMPr2,#0;测试串尾标志\0BNEstrcopy;非零转标号strcopyMOVpc,lr;返回END第6页共8页第7页共8页四、问答题(每题6分,共24分)得分评阅人1、目前使用的嵌入式操作系统主要有哪些?请举出六种较常用的。WindowsCE/WindowsMobile、VxWork、Linux、uCos、Symbian、QNX任选六2、ARM系统中的堆栈有四种,如下图。请按图标出四种堆栈的类型。ATPCS编程规范约定使用的堆栈是哪一种?答:FD、FA、ED、EA。ATPCS编程规范约定使用的堆栈是FD3、BootLoader在嵌入式系统中主要起什么作用?完成哪些主要的工作?答:BootLoader是在嵌入式系统复位启动时,操作系统内核运行前,执行的一段程序。通过BootLoader,初始化硬件设备,建立内存和I/O空间映射图,为最终加载操作系统内核调整好适当的系统软硬件环境。4、搭建嵌入式开发环境,连接目标板,一般使用什么通信接口连接?在Windows主机上使用什么软件建立连接?在Linux主机上使用什么软件建立连接?1、答:RS-232,以太网口、并口在Windows主机上使用超级终端软件在Linux主机上使用Minicom软件。。。SPSPSPSP栈空间的增长方向地址的增长方向栈空间的增长方向栈空间的增长方向栈空间的增长方向HiAddressLoAddressLoAddressHiAddress第8页共8页5嵌入式开发环境主要包括哪些组件?嵌入式系统开发需要交叉编译和在线调试的开发环境,主要包括宿主机目标机(评估电路板)基于JTAG的ICD仿真器、或调试监控软件、或在线仿真器ICE运行于宿主机的交叉编译器和链接器、以及开发工具链或软件开发环境嵌入式操作系统6在进行基于ARM核的嵌入式系统软件开发时,调用如下函数:intdo_something(intarg1,void*arg2,chararg3,int*arg4)这四个参数通过什么方式从调用程序传入被调函数?根据ATPCS编程规范,调用函数和子程序通过R0——R3四个寄存器传递参数,超过四个参数使用堆栈传递。因此arg1通过R0传入,arg2,通过R1传入,arg3通过R2传入,arg4通过R3传入7目前使用的嵌入式操作系统主要有哪些?请举出六种较常用的。WindowsCE/WindowsMobile、VxWork、Linux、uCos、Symbian、QNX任选六