ARM习题及答案.

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

ARM习题

1.1 什么是嵌入式系统?

答:嵌入式系统是以应用为中心,以计算机技术为基础,软/硬件可裁减,功能。可靠性,成本,体积,功耗要求严格的专用计算机系统。

1.2 与通用计算机相比,嵌入式系统有哪些特点?

答:(1).嵌入式系统通常是面向特定应用的;

(2).嵌入式系统是将计算机技术,半导体技术和电子技术与各行各业的具体应用相结合的后的产物,是一门综合技术学科;

(3).嵌入式系统和具体应用有机的结合在一起,它的升级换代也是和具体产品同步进行的,因此嵌入式产品一旦进入市场,就有较长的生命周期;

(4).为了提高执行速度和可靠性,嵌入式系统中的软件一般都固化在存储器芯片或单片机本身中,而不是存储于磁盘等载体中;

(5).嵌入式系统本身不具有自主开发能力,即使设计完成以后用户通常也不能对其中的程序功能进行修改,必须有一套开发工具和环境才能进行开发。

1.3 ARM处理器有几种寻址方式,说明各种寻址的方式。

答:

立即寻址:操作数直接放在指令中。例如:ADD R0,R0,#0x3f ;R0←R0+0x3f

寄存器寻址:操作数放在寄存器中。例如:ADD R0,R1,R2 ;R0←R1+R2

寄存器间接寻址:操作数在内存,以寄存器中的值作为操作数的地址。

例如:LDR R0,[R1] ;R0←[R1]

基址加偏移量寻址(基址变址寻址):基址寄存器的内容与指令中的偏移量相加形成操作数的有效地址例如:LDR R0,[R1,#4] ;R0←[R1+4]

LDR R0,[R1,R2] ;R0←[R1+R2]

多寄存器寻址:一条指令可以完成多个寄存器值的传送。例如:

LDMIA R0,{R1,R2,R3,R4} ;R1←[R0];R2←[R0+4];R3←[R0+8];R4←[R0+12]

堆栈寻址:堆栈是一种数据结构,按先进后出(First In Last Out,FILO)的方式工作,使用一个称作堆栈指针的专用寄存器指示当前的操作位置,堆栈指针总是指向栈顶。

例如:STMFD R13!,{R0,R4-R12,LR}

LDMFD R13!,{R0,R4-R12,PC}

1.4举例介绍嵌入式处理器有哪几类?

答:1.嵌入式微处理器(Embedded Microprocessor Unit,EMPU);

2.嵌入式微控制器;(Embedded Microcontroller Unit,EMCU)

3.嵌入式DSP处理器(Embedded Digital Signal Processor,EDSP);

4.嵌入式片上系统(Embedded System on Chip,EsoC);

1.5从硬件系统来看,嵌入式系统由哪几个部分组成?画出简图。

3.1编写1+2+3+***+100的汇编程序。

AREA EXAMPLE1, CODE,READONLY ;定义一个代码段,名称为EXAMPLE1 ENTRY ;入口

MOV R0,#0 ;给R0赋值为0

MOV R1,#0 ;用R1来存放1~100的总和,初始化为0

START ADD R0,R0,#1 ;用来判断终止的,每次加1

ADD R1,R1,R0 ;从1加到100

CMP R0,#100 ;执行R0-100的操作,但不保存,只影响CPSR的值

BLT START ;带符号数小于时跳转到START处执行

STOP B STOP ;死循环

END

3.2如何实现128位数的减法,请举例说明。

AREA EXAMPLE2,CODE,READONLY

ENTRY

START

SUBS R5,R5,R9

SBCS R4,R4,R8

SBCS R3,R3,R7

SBCS R2,R2,R6

STOP

B STOP

END

3.3将存储器中起始地址地址0X10处的4个字数据移动到地址0X20处。

AREA EXAMPLE2,CODE,READONLY

ENTRY

LDR R0,=0X10 ;把地址0X10赋给R0

LDR R5,=0X20 ;把地址0X20赋给R5

START

LDMIA R0,{R1-R4} ;把R0为首地址的内存单元中的值依次赋给,

; R1到R4,每次赋完一次值,R0自动加1

STMIA R5,{R1-R4} ;把R1到R4的值依次赋给以R5为首地址的内存单元

中,R5每次自动加1 STOP

B STOP ;死循环

END

3.4参考CPSR寄存器中各标志位的含义,使处理器处于系统模式。

AREA EXAMPLE2,CODE,READONLY

ENTRY

START

MOV R0,#0X1F ;给R0赋值,2进制为11111

MSR CPSR_c,R0 ;把CPSR的条件位置1

STOP

B STOP ;死循环

END

3.5用跳转指令实现两段程序间的来回切换。

AREA EXAMPLE5 ,CODE, READONLY

ENTRY

BL X ;跳到a对R0,R1,赋值

START

CMP R0,R1 ;比较R0,R1的值

BNE Y ;不等跳转到b

BEQ STOP ;相等时跳转到STOP

X

MOV R0,#3 ;对R0,R1赋值

MOV R1,#2

MOV R15,R14 ;返回

Y

ADD R1,R1,#1 ;R1自加1

B START ;跳转到START

STOP

B STOP ;死循环

END

3.5 ARM调用 Thumb子程序例子

AREA ThumbSub, CODE, READONLY ; Name this block of code ENTRY ; Mark first instruction to execute

CODE32 ; Subsequent instructions are ARM

header

ADR r0, start + 1 ; Processor starts in ARM state,

BX r0 ; so small ARM code header used

; to call Thumb main program.

CODE16 ; Subsequent instructions are Thumb.

start

MOV r0, #10 ; Set up parameters

MOV r1, #3

BL doadd ; Call subroutine

stop

相关文档
最新文档