《嵌入式系统原理与应用实验指导书.docx》由会员分享,可在线阅读,更多相关《嵌入式系统原理与应用实验指导书.docx(44页珍藏版)》请在课桌文档上搜索。
1、实验一:熟悉开发环境与汇编编程实验11实验目的熟悉ADSL2软件开发环境;掌握ARM920T汇编指令的用法,并能编写简单的汇编程序;掌握指令的条件执行和使用LDR/STR指令完成存储器的访问。2实验内容(1)使用LDR指令读取0x30003100上的数据,将数据加1,若结果小于10,则使用STR指令把结果写回原地址,若结果大于等于10,则把0写回原地址。(2)使用ADSL2软件仿真,单步,全速运行程序,设置断点,打开寄存器窗口(ProcessorRegisters)监视RO,RI的值,打开存储器观察窗口(Memory)监视0x30003100上的值。3预备知识(1) ARM指令系统内容;(2)
2、 ADS1.2工程编辑、编译器和AXD调试器的内容。4实验设备硬件:PC机一台。软件:WindOWS98/XP/2000系统,ADS1.2集成开发环境。5实验步骤(1)启动ADSl.2,使用ARMExecutableImage工程模板建立一个工程arml.mcp。输入工程名称,选择存放路径,确定。(2)新建工程源文件,输入文件名如arml.s,选择添加到工程中选项,在TargetS中选择DebUgRel选项,确定,进入代码编写窗口编写实验程序,最后保存。(3)进行DebugRelSettings设置。在LanguageSettings中,将ARM汇编编译器、C语言编译器、C+语言编译器、ThU
3、mb汇编编译器、ThUmbC语言编译器的Target选项Processor全部选择ARM920T处理器。(4)设置工程连接Linker地址ROBase为0x30000000,RWBase为0x30003000,设置调试口地址Imageentrypoint为0x30000000。(5)编译连接工程正确后,选择ProjeCtlDebug,启动AXD进入调试环境,在菜单OPtiOnS中选择ConfigureTarget,进入ChooseTarget,选择ARMulate.dll后,单击Configure按钮,选择ARM920微处理器,单击OK按钮退出。这时就为软件仿真做好了准备工作,进行调试。(6)
4、打开寄存器窗口(ProCeSSorRegisters),选择CUlTent项监视R0,Rl的值。打开存储器观察窗口(Memory),设置观察地址为0x30003100,显示方式SiZe为32Bit,监视0x30003100地址上的值。(7)可以FlO单步运行程序,可以设置/取消断点,或者全速运行程序,停止程序运行。这时观察寄存器和0x30003100地址上的值。6、实验报告内容(1)叙述ADSL2集成开发环境的组成。(2)叙述主要调试窗口和作用。7参考程序:COUNTEQU0x30003100AREAExamplelll,CODE,READONLYENTRYC0DE32STARTLDRRl,=
5、COUNTMOVRO,#0STRRO,RI1.OOPLDRRl,=COUNTLDRRO,RIADDRO,RO,#1CMPRO,#10MOVHSRO,#0STRRO,RIBLOOPEND实验二汇编指令实验21实验目的(1)掌握ARM乘法指令的使用方法;(2)了解子程序编写及调用。2实验内容(1)使用STMFD/LDMFD,MUL指令编写一个整数乘方的子程序,然后使用BL指令调用子程序计算Xn的值。(2)使用ADSL2软件仿真,单步,全速运行程序,设置断点,打开寄存器窗口(ProcessorRegisters)监视RO,Rl的值,打开存储器观察窗口(Memory)监视0x30003000上的值。3
6、预备知识(1) ARM指令系统内容;(2) ADS1.2工程编辑和AXD调试的内容。4实验设备硬件:PC机一台。软件:WindOWS98/XP/2000系统,ADS1.2集成开发环境。5实验步骤(1) .启动ADS1.2,使用ARMExecutableImage工程模板建立一个工程arm2.mcpo(2) .建立汇编源文件arm2.s,编写实验程序,然后添加(3) .设置工程连接地址ROBase为0x30000000,RWBase为0x30003000,设置调试口地址Imageentrypoint为0x30000000o(4) .编译连接工程,选择PrOjeCUDebug,启动AXD进行软件仿
7、真调试。(5) .打开寄存器窗口(ProcessorRegisters),选择CUITent项监视寄存器RO,RhR13(SP)和R14(LR)的值。(6) .打开存储器观察窗口(Memory),设置观察地址为0x30003EA0,显示方式SiZe为8Bit,监视从0x30003FoO起始的满递减堆栈区。(7) .单步运行程序,跟踪程序执行的流程,观察寄存器值的变化和堆栈区的数据变化,判断执行结果是否正确。(8) .调试程序时,更改参数X和n来测试程序,观察是否得到正确的结果。例如:先复位程序,接着单步执行到“BLPoW”指令,在寄存器窗口中将R0,Rl的值进行修改,然后继续运行程序。说明:用
8、鼠标双击寄存器窗口的寄存器,即可修改寄存器的值。输入数据可以是十进制数(如136,198),也可以是十六进制数(如0x123,OxFO),输入数据后回车确定。6实验报告内容(3)叙述ARM中的B指令与BL指令的区别7参考程序XEQU9nEQU2AREAExample2,CODE,READONLYENTRYC0DE32STARTLDRSP,=0x30003F001.DRRO,=X1.DRRl,=nBLPOWHALTBLHALTPOWSTMFDSP!,R1-R12,LRMOVSR2,RlMOVEQRO,#1;IF(Rl)=OTHEN(RO)=IBEQPOW_END;ANDJUMPTOPOW_END
9、,ELSEMOVRl,ROSUBR2,R2,#1POW_L1BLDOJftJLSUBSR2,R2,#1BNEPOW_L1POW_ENDLDMFDSP!,R1-R12,PC;POPSTATICRETURNTOMAINPROGRAMDO_MULMULRO,Rl,ROMOVPC,LR;RETURNTOMAINPROGRAMEND实验二汇编指令实验21实验目的(1)掌握ARM乘法指令的使用方法;(2)了解子程序编写及调用。2实验内容(1)使用STMFD/LDMFD,MUL指令编写一个整数乘方的子程序,然后使用BL指令调用子程序计算Xn的值。(2)使用ADSL2软件仿真,单步,全速运行程序,设置断点,打
10、开寄存器窗口(ProcessorRegisters)监视RO,Rl的值,打开存储器观察窗口(Memory)监视0x30003000上的值。3预备知识(1) ARM指令系统内容;(2) ADS1.2工程编辑、编译器和AXD调试器的内容。4实验设备硬件:PC机一台。软件:WindOWS98/XP/2000系统,ADS1.2集成开发环境。5实验步骤(1) .启动ADS1.2,使用ARMExecutableImage工程模板建立一个工程arm2.mcpo(2) .建立汇编源文件arm2.s,编写实验程序,然后添加(3) .设置工程连接地址ROBase为0x30000000,RWBase为0x30003
11、000o(4) .编译连接工程,选择PrOjeCtlDebug,启动AXD进行软件仿真调试。(5) .打开寄存器窗口(ProcessorRegisters),选择Current项监视寄存器RO,RbR13(SP)和R14(LR)的值。(6) .打开存储器观察窗口(Memory),设置观察地址为0x30003EA0,显示方式SiZe为8Bit,监视从0x30003FOo起始的满递减堆栈区。(7) .单步运行程序,跟踪程序执行的流程,观察寄存器值的变化和堆栈区的数据变化,判断执行结果是否正确。(8) .调试程序时,更改参数X和n来测试程序,观察是否得到正确的结果。例如:先复位程序,接着单步执行到“
12、BLPOW”指令,在寄存器窗口中将RO,Rl的值进行修改,然后继续运行程序。说明:用鼠标双击寄存器窗口的寄存器,即可修改寄存器的值。输入数据可以是十进制数(如136,198),也可以是十六进制数(如0x123,OxFO),输入数据后回车确定。6实验报告内容(2)分析汇编程序各行的功能或作用(2)叙述ARM中乘法指令的特点(3)叙述ARM中的B指令与BL指令的区别7参考程序XEQU9nEQU2AREAExample2,CODE,READONLYENTRYC0DE32ATARTLDRLDRLDRSP,=0x30003F00RO,=XRl,=nHALTPOWBL POWBL HALTSTMFD :
13、MOVS MOVEQPOW LlBEQ MOV SUBBLDOSP!, R1-R12, LRR2,R1RO,#1POW_ENDRl, ROR2, R2, #1NftJLSUBSR2,R2,#1BNEPOW_L11.DMFDSP!,R1-R12,PCMULRO,Rl,ROMOVPC,LREND实验三ARMC/C+语言实验11实验目的通过实验了解使用ADSl.2编写C语言程序,并进行调试。2实验内容(1)编写一个汇编程序文件和一个C程序文件,汇编程序的功能是初始化堆栈指针和初始化C程序的运行环境,然后跳转到C程序运行,这就是一个简单的启动程序。C程序使用加法运算来计算1+2+3+(N-I)+N的值
14、(N0)o(2)使用ADSL2软件仿真,单步,全速运行程序,设置断点,打开寄存器窗口(ProcessorRegisters)监视RO,Rl的值,打开存储器观察窗口(Memory)监视0x30003000上的值。3预备知识(I)ARM指令系统内容;(2) APCS(ARMProcedureCallStandard)过程调用内容;(3) ADSl.2工程编辑和AXD调试的内容。4实验设备硬件:PC机一台。软件:WindOWS98/XP/2000系统,ADS1.2集成开发环境。5实验步骤(1) .启动ADS1.2,使用ARMExecutableImage工程模板建立一个工程cLmcpo(2) .建立
15、汇编源文件StartUp.s和ClC编写实验程序,然后添加到工程中。(3) .设置工程连接地址ROBaSe为0x30000000,RWBase为0x30003000,设置调试口地址Imageentrypoint为0x30000000o(4) .设置位于开始位置的起始代码段。方法:在ARMLinker中的Object/Symbol的栏中填写Startup。,即Startup.s文件的目标代码;在Seetion栏中填写启动段名Star屋(5) .编译连接工程,选择ProjectIDebug,启动AXD进行软件仿真调试。(6) .在StartUp.S的BMain”处设置断点,然后全速运行程序。(7)
16、 .程序在断点处停止,单步运行程序,判断程序是否跳转到C程序中运行。(8) .选择ProcessorViewsVariables打开变量观察窗口,观察全局变量的值,单步/全速运行程序,判断程序的运算结果是否正确。6实验报告内容(3)在ADSL2中能直接编写C语言程序进行运行吗?为什么?(4)在汇编语言中调用C语言的格式怎样?(5)汇编语言如何向C程序语言函数传递参数?7参考程序(1)汇编语言StartUp.s程序代码IMPORTImage$R0$LimitIIMPORTImage$RW$Base|IMPORTImage$ZI$BaSelIMPORTImage$ZI$Limit|IMPORTMa
17、inAREAStart,CODE,READONLYENTRYCODE32Reset LDRSP,二0x40003FOO1.DRR0,=|lmage$R0$Limit|1.DRRl,=Image$RW$Base1.DRR3,=:Image$ZI$Base|CMPRO,Rl;比较只读区域结束地址和读写区域起始地址,目的是判断有几个执;行区域,影响标志位ZBEQLOOPl;如果只有一个可执行区域,直接在读写区域末尾进行Zl区域的0初始化,;即跳到LOOPl标号处;否则顺序执行标号LOOPO1.OOPOCMPRl,R3;比较不断增大的读写区域起始地址与0初始化区域的起始地址。;影响标志位C,如果RkR
18、3,00,条件CC为TrUe,执行以下3条语句。1.DRCCR2,R0,#4;将网处的内容搬移到R1处STRCCR2,BCCLOOPO;如果不相等,跳回LoOPo继续搬移数据(可能包含能改变自身的;程序),如果相等,则执行L(X)PI标号后的程序1.OOPlLDRRl,=|Image$ZI$Limit|;这里RI又重新赋值为Zl的末地址MOVR2,#01.00P2CMPR3,R1;比较Zl的开始地址R3与末地址Rl,如果R3R1,则CC为TrueSTRCCR2,R3,#4;初始化Zl区域BCCL00P2;如果0初始化区域的终止地址小于不断增大的0初始化区域起始地址,;则跳到标号L00P2处继续
19、循环执行BMainEND(2) C语言CLC程序代码(1) fineuint8unsignedchar(2) fineuint32unsignedint#defineN100uint32sum;voidMain(void)(uint32i;sum=0;for(i=0;iRO-Limit一代码区.RW.Base初值ZLBaSe初值读写数据区代码预留去读写数据区ZLBaSe初值ZLLimit值、初值0数据区RW.Limit初值0数据区C编译后ADS中RO.Basc初(4代码分布代码分布RSBase初值C代码分布与ADS代码分布映射图注意:Image$R0$LinIitl就是为判断Image$RW$
20、BaSe而设计的,当Ilmage$R0$Limitl大于IImage$RW$BaseI时,说明ADS设置的数据区RW区初值设置太小,没有给代码区留有足够的空间。此程序中没有考虑到这种情形。当IIlnage$R0$Linlitl等于IlinagC$RW$BaSel时,说明ADS设置的数据区RW区正好与代码的数据区重合,此时不需要对RW的数据区进行搬移,只需要将ZI区清iiOffo当IImage$R0$Limitl小于IIlnage$RW$BaSel时,说明ADS设置的数据区RW区初值大于C代码段的末值,需要对数据区RW进行搬移。实验四ARMC/C+语言实验21实验目的掌握在C语言程序中调用汇编程
21、序,了解ATPCS基本规则。2实验内容(1)在C程序调用汇编子程序,实现两个整数的加法运算。汇编子程序的原型为:unit32Add(unit32x,unit32y)其中,unit32已定义为unsignedint.(2)使用ADSl.2软件仿真,单步,全速运行程序,设置断点,打开寄存器窗口(ProcessorRegisters)监视RO,Rl的值,打开存储器观察窗口(Memory)监视0x30003000上的值。3预备知识(3) ARM指令系统内容;(4) ARM的ATPCS的相关内容;(3)ADS1.2工程编辑和AXD调试的内容。4实验设备硬件:PC机一台。软件:WindoWS98/XP/2
22、000系统,ADS1.2集成开发环境。5实验步骤(1)启动ADS1.2,使用ARMExecutableImage工程模板建立一个工程c2.mcpo(2)建立汇编源文件Startup.S,Add.S和c2.c,编写实验程序,然后添加到工程中。(3)设置工程连接地址ROBase为0x30000000,RWBase为0x30003000,设置调试口地址Imageentrypoint为0x300000000(4)设置工程连接选项,位于开始位置的起始代码段设置为Startup.o的Start段.(5)编译连接工程,选择PrOjeCtlDebug,启动AXD进行软件仿真调试。(6) .在cl.c文件中的调
23、用Add()的代码处设置断点,然后全速运行程序。(7)程序在断点处停止,使用StepIn单步运行程序,观察程序是否跳转到汇编程序中Add.s运行。(8)选择ProcessorViewsVariables打开变量观察窗口,观察全局变量的值,单步/全速运行程序,判断程序的运算结果是否正确。6实验报告内容(6)简述ATPCS含义和内容。(2)论述在C语言程序中如何调用汇编语言。7参考程序(1)汇编语言启动程序StartUp.s代码IMPORTIImage$R0$LimitIMPORT|lmage$RW$Base|IMPORT|lmage$ZI$Base|IMPORTIIDIage$ZI$LiInit
24、IMPORTMainAREAStart,CODE,READONLYENTRYResetLOOPOLOOPlL00P2C0DE321.DRSP,=0x30003F001.DRRO,=IImage$R0$Linlit1.DRRl,=IImage$RW$BaSe1.DRR3,=Ilinage$ZI$BaSelCMPRO,RlBEQLOOPlCMPRl,R31.DRCCR2,RO,#4STRCCR2,RI,#4BCCLOOPO1.DRRl,=IIlnage$ZI$LimitMOVR2,#0CMPR3,RlSTRCCR2,R3,#4BCCL00P2BMainEND(2)C语言调用汇编语言程序#defin
25、euint8unsignedcharftdefineuint32tmsignedintexternuint32Add(uint32x,uint32y);uint32sum;voidMain(void)(sum=Add(555,168);while(l);(3)汇编加法程序代码EXPORTAddAREAAddl,CODE,READONLYENTRYC0DE32AddADDRO,RO,R1MOVPC,LREND实验五寄存器装载及存储汇编指令实验1实验目的(1)熟悉ADSL2软件开发环境;(2)掌握寄存器装载指令的条件执行等和使用各种形式的寄存器装载指令完成存储器的访问。2实验内容(1)主要内容:单
26、一指令加载/存储指令(LDR/STR)的基本格式有:1.DR/STR条件码类型码Rd,Rn1.DR/STR条件码类型码Rd,Rn,Flexoffset!1.DR/STR条件码类型码Rd,label1.DR/STR条件码类型码Rd,Rn,Flexoffset说明:条件码:可选,默认是无条件执行。内容见表2.6.1ARM条件码表。类型码:可选,默认是字(32bit)。也可以是字节B、带符号字节SB、无符号半字H、有符号半字SH和双字D。Rd:为ARM9的内部寄存器,作为加载/存储操作的目的/源。Rn:为ARM9加载/存储的源/目的。Flexoffset:表示地址偏移量。与Rn寄存器的值相加后得到有
27、效的操作数地址。有以下2种形式: 一个立即数,范围一4095+4095,书写格式#常数或#常数表达式。 一个内含偏移量的寄存器Rm,m15o书写格式为:Rm,shift)。shift代表Rnl的可选移位方法,有:ASRn算术右移n;LSLn逻辑左移n;1.SRn逻辑右移n;RORn循环右移n;RRX带扩展循环右移1位;label:表示一个偏移表达式。该偏移量加上PC值后,得到操作数的有效地址。注意偏移量在当前指令的上下4K范围内。!:表示写回地址的符号,可选。若带有后缀!,表示加载/存储完成后,将包含偏移量的新地址写回Rn0多数据加载/存储指令(LDM/STM)的基本格式是:1.DM/STM条
28、件码类型码Rn!,寄存器列表条件码:同上。类型码:取其下列情况之一:IA:传送数据之后,修改指针加1;IB:传送数据之前,修改指针加1;DA:传送数据之后,修改指针减1;DB:传送数据之前,修改指针减1;FD:满递减堆栈;(ADS的堆栈方式)ED:空递减堆栈;FA:满递增堆栈;EA:空递增堆栈;Rn:是内部寄存器,但不允许是R15,用作存储器地址指针。寄存器列表:在格式中使用大括号括起来的内部寄存器,一般用逗号分开。当使用连续号的寄存器时,使用减号“一”恢复CPSR寄存器的值使用符号“八”:在把PC值存储到内存中时,同时也将CPSR的值存入到了内存中。在重新装载PC值时,若要同时恢复CPSR寄
29、存器的值,则使用符号,例如:STMFDR13!,R0-R12,R141.DMFDR13!,R0-R12,PC(2)主要实验项目使用ADSL2软件仿真,单步执行,观察通用寄存器、状态寄存器和存储器窗口内容的变化;编制在各种基本指令下指令实验程序,上机调试,使用各种窗口观察实验结果;编制无符号字节块、无符号半字块和字块的传送指令,使用汇编伪指令DCB定义字节数据、DCW定义半字数据、DCD定义字数据。使用ARM伪指令ADR、LDR设置块的首地址,完成各数据块的传送与拷贝工作。3预备知识(1) ARM指令系统的寄存器装载及存储指令;(2) ADS1.2工程编辑和AXD调试。4实验设备硬件:PC机一台
30、。软件:WindoWS98/XP/2000系统,ADS1.2集成开发环境。5实验步骤(1)启动ADSL2,使用ARMExecutableImage工程模板建立一个工程arml.mcpo(2)建立汇编源文件Exp5_arm.s,使用寄存器装载及存储指令编写实验程序,然后添加到工程中。(3)设置工程连接地址RoBaSe为0x30000000,RWBaSe为0x3(X)03000,设置调试口地址Imageentrypoint为0x30000000o(4)编译连接工程,选择PrOjeCtIDebug,启动AXD进行软件仿真调试。(5)打开寄存器窗口(ProcessorRegisters),选择CUIT
31、ent项监视其中寄存器的值。打开存储器观察窗口(MemOry),设置观察存储器操作的地址内容。(6)单步运行程序,或设置断点进行观察。6、实验报告内容(7)寄存器装载及存储指令可以完成哪些任务。(8)进行数据快传送编程时,块的首地址怎样设置,如何完成传送任务。(9)简要总结实验的内容和收获。1实验目的(1)熟悉ADSL2软件开发环境;(2)掌握算术逻辑指令对标志寄存器标志的影响、条件执行和功能等;(3)使用算术指令编写简单的汇编程序并进行调试。2实验内容(1)主要内容不带进位ADD、带进位ADC加法指令,其基本格式为:ADDADC条件码SDest,Opl,0p2说明:条件码:可选,默认是无条件
32、执行。内容见表2.6.1ARM条件码表。S:可选,默认是不影响状态寄存器CPSR的标志位。当选写S时,则影响CPSR的标志位。Dest:为目的寄存器Rd。OpK0p2:为两个操作数,0p2也可以是寄存器移位操作的结果。 不带进位ADD指令完成的功能是:Dest=Opl+0p2主要形式有:ADD Rd, Rm, RnADD Rd, Rm,#立即数ADD Rd, Rm, Rn, shiftRd - Rm + RnRd = Rm+立即数Rd = Rm + Rn shift 带进位ADe指令完成的功能是:DeSt=OPI+0p2+进位位。主要形式有:ADC Rd, Rm, RnADC Rd, Rm,#
33、立即数ADC Rd, Rm, Rn, shift shift代表Rm的可选移位方法,ASR n LSR n RRX算术右移n;逻辑右移n;带扩展循环右移1位;Rd=Rm + Rn +进位位Rd=Rm +立即数+进位位 Rd=Rm + Rn shift + 进位位 有:LSL n逻辑左移nROR n循环右移n不带借位SUB指令、带借位SBC指令的基本格式是:SUBSBC条件码SDest,0pl,0p2说明:条件码、S、DestOpK0p2:同上。不带借位SUB指令完成的功能是:Dost=0pl-0p2主要形式有:SUB Rd, Rm, RnSUB Rd, Rm,#立即数SUB Rd, Rm, R
34、n, shiftRd = Rm - RnRd = Rm-立即数Rd = Rm - Rn shift 带借位SBC指令完成的功能是:Dest=Opl-0p2-!Carry主要形式有:SBC Rd, Rm, RnSBC Rd, Rm,#立即数SBC Rd, Rm, Rn, shiftRd=Rm-Rn-!CarryRd=Rm-立即数-!CarryRd=Rm-Rnshift-!CarryShift同上反向减法指令RSB、带借位反向减法指令RSC的基本格式是:RSBRSC条件码SDest,Opl,0p2说明:条件码、S、DestOP1、0p2:同上。 反向减法指令RSB完成的功能是:Dest=0p2-0
35、pl主要形式有:RSB Rd, Rm, RnRSB Rd, Rm,#立即数RSB Rd, Rm, Rn, shiftRd = Rn - RmRd =立即数- RmRd = Rn shift - Rm 带借位反向减法指令RSC完成的功能是:DeSt=0p2-Opl-!Carry主要形式有:RSC Rd, Rm, RnRSC Rd, Rm,#立即数RSC Rd, Rm, Rn, shiftShift同上位逻辑指令“与“ AND、 其指令格式为:Rd=Rn -Rm- !CarryRd=立即数 - Rm - ! CarryRd= Rn shift - Rm -!Carry“或 ORR、“异或 EOR和
36、位清除指令BIC,功能如下:AND功能:ORR功能:EOR功能:;位与;位或;位异或操作码条件码SDest,0pl,0p2Dest=OplAND0p2Dest=OplORR0p2Dest=OplAND0p2AND功能:Dest=OplAND!0p2;将0P2中为1位的对应位清0(2)主要完成的工作编写一个汇编程序,通过寄存器窗口观察每一指令的运行结果和CPSR的状态标志位;编写代码实现无符号数(RI)(RO)+(R3)(R2)f(Rl)(RO),若有益处,则将R4的低8位通过BIC指令或AND、ORR指令设置为Oxaa,否则设置为0x55;编写代码实现无符号数(RI)(R0)-(R3)(R2)
37、f(Rl)(RO),若有借位,则将R4的低8位通过BlC指令或AND、ORR指令设置为Oxaa,否则设置为0x55;编写程序计算1+2+22+23+22。的值。3预备知识(1) ARM指令系统的算术加/减法指令;(2) ADS1.2工程编辑和AXD调试。4实验设备硬件:PC机一台。软件:WindoWS98/XP/2000系统,ADS1.2集成开发环境。5实验步骤(1)启动ADSl.2,使用ARMExecutableImage工程模板建立一个工程arm4.mcp0(2)建立汇编源文件Exp6_arm.s,使用算术类指令(主要是加减法)编写实验程序,然后添加到工程中。(3)设置工程连接地址ROBa
38、Se为0x3000(X)00,RWBaSe为0x30003000,设置调试口地址Imageentrypoint为0x30000000o(4)编译连接工程,选择PrOjeCtIDebug,启动AXD进行软件仿真调试。(5)打开寄存器窗口(ProcessorRegisters),选择CUlTent项监视其中寄存器的值。打开存储器观察窗口(Memory),设置观察存储器操作的地址内容。(6)单步运行程序,或设置断点进行观察。6、实验报告内容(10)简述ARM加/减法指令的种类,各指令完成的功能。(三)简述ARM逻辑指令与位清0指令完成的功能。(12)写出上述实现无符号数相加减的部分程序代码片段。实验
39、七ARM乘法及其它指令汇编指令实验1实验目的(1)掌握ARM乘法及其它指令对标志寄存器标志的影响、条件执行和功能等;(2)使用乘法指令编写简单的汇编程序并进行调试。2实验内容(1)主要内容32位乘法指令MUL、32位乘加指令MLA,其基本格式分别为:乘法指令:MUL条件SDest,Opl,0p2;Dest=Opl0p2乘加指令MLA条件SDest,0pl,0p2,0p3;Dest=Opl0p2+0p3说明:条件码、S与之前的意义相同;所有的操作数以及目的寄存器必须是简单的寄存器,不能是立即数或被移位的寄存器;目的寄存器与操作数1必须是不同的寄存器,但不能使用R15寄存器。64位有符号数乘法指令
40、SMULU乘加指令SMLAL和64位无符号数乘法指令UMULL、乘加指令UMLAL说明:具体格式参阅第2章的相关内容。 64位有符号数乘法指令SMIJLL条件S,;Rd-RmXRS 64位有符号数乘加指令SMLAL条件Szzz;RdLo-(RmXRs)Lo+RdLoRdHi-(RmxRs)Hi+RdHi注意:该指令高位计算时也包含低位的进位位,但是高位相加的进位不影响CPSR中的进位位C 64位无符号数乘法指令UMULL条件Szzz;Rd-RrnXRS 64位无符号数乘加指令UMLAL条件SzVRdHi,vRs;RdLo-(RmXRs)Lo+RdLoRdHi-(RmxRs)Hi+RdHi注意:
41、该指令高位计算时也包含低位的进位位,但是高位相加的进位不影响CPSR中的进位位C(实验已证明)传送指令MOV和传送取反值指令MVN指令,其基本格式分别是: 传送指令MOV:MOV条件码SDest,Opl;DeSt-Opl说明:条件码、S、Dest:同上。OPl可以是寄存器或寄存器移位;Dest与OPl可以是相同的寄存器,此时指令的功能等价于NOP指令;例movr,r可以对相同的寄存器进行移位操作;例:MOVRO,RO,LSL#3 传送取反值指令MVN:MVN条件SDest,Opl;Dest-OPL按位取反说明:MVN把OPI操作数,可以是立即数、寄存器或移位的寄存器的值按位取反后传送给DeSt
42、寄存器。例:movRo,#4;(ro)=oxfffffffo比较指令CMP.取反比较指令CMN,其基本指令格式是: CMP比较指令:CMP条件0pl,0p2功能:完成Opl0p2运算但不保存结果,只影响CPSR的标志,与减法指令SUBS相同。用于判断两个操作数的大小,以决定之后的条件汇编指令能否执行。 CMN比较指令:CMN条件0pl,0p2功能:完成0pl+0p2运算但不保存结果,只影响CPSR的标志,与加法指令ADDS相同。用以决定之后的条件汇编指令能否执行。位测试指令TST和相等测试指令TEQ,其指令格式为: 位测试指令TST:TST条件码0pl,0p2功能:完成OPIAND0p2位“与”运算,但不存储运算结果,只影响CPSR的相应的标志位Z,与ANDS相同。Opl一般是一个寄存器,0p2一般是一个用于测试位掩码的立即数,用于测试对应掩码位“1”是否全为“0。若Z=I,则全为0,否则不全为0。例:TSTR0,#%1;IFZ=I,THENROISALL0.WHERE“”ISBINARY 相等测试指令TEQ:TEQ条件码0pl,0p2功能:完成OPlEOROP2位“异或”运算,但不存储运算结果,只影响CPSR的相