接口与汇编程序设计作业答案_第1页
接口与汇编程序设计作业答案_第2页
接口与汇编程序设计作业答案_第3页
接口与汇编程序设计作业答案_第4页
接口与汇编程序设计作业答案_第5页
已阅读5页,还剩11页未读 继续免费阅读

下载本文档

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

文档简介

1、习题1(教材P56)18086/8088微处理器地址总线有多少位?寻址范围是多少?答:20位 A0-A19。寻址范围00000H-FFFFFH28086/8088微处理器分哪两部分?各部分主要由什么组成?答:执行单元EU和总线接口单元BIU。EU包括:ALU、寄存器组、暂存器、标志寄存器、EU控制单元。BIU包括:指令队列缓冲器、段寄存器及指令指针、总线地址加法器、总线控制逻辑。48086/8088微处理器中有几个通用寄存器?几个变址寄存器?有几个指针寄存器?几个段寄存器?答:8个通用寄存器AX、BX、CX、DX、SP、BP、SI、DI。2个变址寄存器SI、DI。2个指针寄存器SP、BP。DS

2、、ES、SS、CS段地址寄存器。58086/8088微处理器中有哪些标志位?它们的含义和作用如何?答:零标志位ZF、进位标志CF、溢出标志位OF、辅助进位标志位AF、奇偶标志位PF、符号标志位SF、方向标志位DF、中断允许标志位IF、跟踪标志TF。6试求出下列运算后的各个状态标志,说明进位标志和溢出标志的区别?1278H+3469H 答:0001 0010 0111 1000+0011 0100 0110 10010100 0110 1110 0001ZF=0;SF=0;CF=0;OF=0;AF=1;PF=1。54E3H-27A0H 答:0101 0100 1110 0011+1101 100

3、0 0110 0000(-27A0的补码)10010 1101 0100 0011ZF=0;SF=0;CF=1;OF=0;AF=0;PF=0。3881H+3597H 答:0011 1000 1000 0001+0011 0101 1001 01110110 1110 0001 1000ZF=0;SF=0;CF=0;OF=0;AF=0;PF=1。01E3H-01E3H 答:0000 0001 1110 0011+1111 1110 0001 1101(-01E3H的补码)10000 0000 0000 0000ZF=1;SF=0;CF=1;OF=0;AF=1;PF=1。进位表示最高位产生进位。溢

4、出表示超出数的表示范围。OF=CnCn-18什么是逻辑地址?什么是物理地址?它们之间有什么联系?各用在何处?答:逻辑地址:产生实际地址的两个地址分量:首地址和偏移地址。物理地址:内存单元地址。用户在编写程序时只使用逻辑地址。程序装到内存中使用物理地址。物理地址可以通过逻辑地址求得。9设现行数据段位于存储器的B0000H到BFFFFH存储单元,DS段寄存器内容为多少?答:DS=B000H118086/8088微处理器工作在最小模式和最大模式时的主要特点是什么?有何区别?答:最小模式只有一个CPU不需要总线控制器。最大模式有多个微处理器,必须要总线控制器来对总线控制权进行分配。引脚MN/MX=1工

5、作在最小模式。MN/MX=0工作在最大模式。13.80486地址总线宽度为多少?数据总线宽度为多少?答:80486地址总线宽度为32位(分成4个块,每个块为8位字长,块有A1,A0选择)有数据总线宽度为32位。14现有6个字节的数据分别为11H,22H,33H,44H,55H,66H,已知它们在存储器中的物理地址为400A5H400AAH,若当前的(DS)=4002H,请说明它们的偏移地址值。如果从存储器中读出这些数据,至少需要访问几次存储器,各读出哪些数据?解:物理地址=(DS)×16+偏移地址,偏移地址=物理地址-(DS)×16=400A5H400AAH-40020H=

6、85H8AH至少需要访问三次存储器,每次读出一个字,即2211H,4433H,6655H。11H22H33H44H55H66H4002:00854002:00864002:00874002:00884002:00894002:008A这六个数在存储器中的存放位置如图所示。习题2(教材P105)1已知DS=2000H,BX=0100H,SI=0002H,存储单元20100H20103H依次存放12 24 56 78H,21200H21203H依次存放2A 4C B7 65H,说明下列每条指令执行后AX寄存器的内容。(1) MOV AX, 1200H解:AX=1200H(3) MOV AX, 12

7、00H解:物理地址=DS×16+1200H=20000H+1200H=21200H,所以AX=4C2AH(5) MOV AX, BX+1100H解:物理地址=DS×16+BX+1100H=20000H+0100H+1100H=21200H ,所以AX=4C2AH(7) MOV AX, BXSI+1100H解:物理地址=DS×16+BX+SI+1100H=20000H+0100H+0002H+1100H=21202H ,所以AX=65B7H(2) MOV AX, BX解:AX=0100H(4) MOV AX, BX解:物理地址=DS×16+BX=20000

8、H+0100H=20100H,所以AX=2412H(6) MOV AX,BXSI解:物理地址=DS×16+BX+SI=20000H+0100H+0002H=20102H,所以AX=7856H2指出下列指令错误(1) MOV CX, DL答:数据类型不匹配,CX是16位,DL是8位。(2) MOV IP, AX答:指令指针不能直接修改。(3) MOV ES, 1234H答:段地址寄存器不能直接置数。(4) MOV ES, DS答:段地址DS不能做源操作数。(5) MOV AL, 300答:300大于255,AL是8位的,最多只能存255(6) MOV SP, AX答:SP不能做间接寻址

9、寄存器。(7) MOV AX , BX+DI答:基址变址寻址必须打。(8) MOV 20H, AH答:立即数不能做目的地址单元。3已知数字09对应的格雷码依次为:18H、34H、05H、06H、09H、0AH、0CH、11H、12H、14H,它存放在于以TABEL为首地址(设为200H)的连续区域中。对如下程序段的每条指令加上注释,说明每条指令的功能和执行结果。LEA BX,TABLE ;取表的首地址送BX,执行后(BX)=200HMOV AL,8 ;立即数8送AL,执行后,(AL)=8XLAT ;查表,将表首地址+8((BX)+(AL))所对应单元内容送AL, ;执行后,(AL)=12H(8

10、所对应的格雷码)4什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应哪两种指令?答:堆栈是在内存中开的一个特殊的数据区,堆顶有堆栈指针SP与SS共同决定。原则是:先进后出,两个操作:入栈、出栈,对应指令:PUSH(入栈)、POP(出栈)。5已知SS=FFA0H,SP=00B0H,画图说明执行下列指令序列时,堆栈区和SP的内容如何变化?MOV AX , 8075HPUSH AXMOV AX , 0F79HPUSH AXPOP BX POP BX解:57H80Hxx.FFA0:00AE SPFFA0:00AFFFA0:00B0 FFA0:0000执行完MOV AX , 8075HPUSH

11、AX 指令后SP=00AEH79H0FH57H80Hxx.FFA0:00AC SPFFA0:00ADFFA0:00AE FFA0:00AFFFA0:00B0 FFA0:0000再执行完MOV AX , OF79HPUSH AX 指令后SP=00ACH79H0FH57H80Hxx.FFA0:00AE SPFFA0:00AFFFA0:00B0 FFA0:0000再执行完POP BX指令后SP=00AFH79H0FH57H80Hxx.FFA0:00AE FFA0:00AFFFA0:00B0 SP FFA0:0000再执行完POP BX 指令后SP=00B0H8请分别用一条汇编语言指令完成如下功能:(

12、1)把BX寄存器和DX寄存器的内容相加,结果存入DX寄存器。解:ADD DX, BX(2)用寄存器BX和SI的基址变址寻址方式把存储器的一个字节与AL寄存器的内容相加,并把结果送AL中。解:ADD AL, BX+SI 或ADD AL, BXSI(3)用寄存器BX和02BH的寄存器相对寻址方式,把存储器的一个字和CX寄存器的内容相加,并把结果送回存储器中。解:ADD BX+02BH ,CX 或ADD 02BH BX ,CX(4)把数0A0H与AL寄存器内容相加,并把结果送AL中。解:ADD AL, 0A0H10指出下列指令错误(1) XCHG SI, 30H答:立即数不能作为单元地址来保存数据,

13、所以交换指令中的两个操作数必须是地址操作数。(2) POP CS答:CS不能作为寻址寄存器使用(3)SUB SI, DI答:算术运算指令中的两个操作数不能同时都在内存中(4)PUSH AH答:PUSH指令中的操作数必须是16位操作数,AH是8位(5)ADC AX, DS答:DS不能做源操作数,(6)OUT DX, AH答:只能使用AL(当端口数据位是8位)或AX(端口数据位是16位)与端口交换数据(7)IN AL 3FCH答:端口地址大于255时,必须有DX寄存器间接寻址。20假设DS=2000H,BX=1256H,SI=528FH,位移量TABLE=20A1H,232F7H=3280H,26

14、4E5H=2450H,试问执行下列段内间接转移指令后,转移的目的地址是什么?(1)JMP BX(2)JMP TABLEBX(3)JMP BXSI解:(1)JMP BX,目标地址的偏移量在BX中,所以转移的目的地址是CS:1256H(也可以直接写成有效地址IP=1256H)。(2) JMP TABLEBX,目标地址的偏移量在存储器单元中,该存储器单元有效地址为(BX)+ TABLE中,所对应的物理地址=DS×16+(BX)+TABLE=20000H+1256H+20A1H=232F7H,该单元存放的内容为3280H,所以JMP TABLEBX 转移的目的地址是CS:3280H(也可以直

15、接写成有效地址IP=3280H)(3)JMP BXSI 目标地址的偏移量在存储器单元中,该存储器单元有效地址为(BX)+ (SI)中,所对应的物理地址=DS×16+(BX)+(SI)=20000H+1256H+528FH=264E5H,该单元存放的内容为4500H,所以JMP TABLEBX 转移的目的地址是CS:4500H(可以直接写成有效地址IP=4500H)。23假设AX和SI存放的是有符号数,DX和DI存放的是无符号数,请用比较指令和条件转移指令实现以下判断:(1)若DXDI,转到ABOVE执行;(2)若AXSI,转到GREATER执行;(3)若CX=0,转到ZERO执行;(

16、4)若AX-SI产生溢出,转到OVERFLOW执行;(5)若SIAX,转到LESS_EQ执行;(6)若DIDX,转到BELOW_EQ执行。解:(1)CMPDX,DI JA ABOVE(2)CMP AX,SI JG GREATER(3)CMP CX,0 JE ZERO(4)CMP AX,SI JO OVERFLOW(5) CMP SI,AXJLE LESS_EQ(6) CMP DI,DXJBE BELOW_EQ选做题14题(P107).已知数据段500H600H中存放了一字符串,说明下列程序段执行后的结果。MOV SI, 600HMOV DI, 601HMOV AX, DSMOV ES, AXM

17、OV CX, 256STD REP MOVSB24题(P108).有一个首地址为ARRAY的20个字的数组,说明下列程序的功能。MOV CX, 20MOV AX, 0MOV SI, AXSUM_LOOP: ADD AX, ARRAYSIADD SI, 2LOOP SUM_LOOPMOVE TOTAL, AX25题(P109).按照下列要求,编写相应的程序段:起始地址为STRING的主存单元中存放有一个字符串(长度大于6),把该字符串的第一和第六字符(字节变量)传送给DX,解:MOV SI, 0MOV DL , STRINGSIMOV DH , STRINGSI+5从主存BUFFER开始的4个字

18、节中保存了4个非压缩的BCD码,现按低(高)地址对低(高)位的原则将它们合并到DX中解:MOV SI, 0MOV AL , BUFFERSIAND AL, 0FHMOV AH , BUFFERSI+1AND AH, 0FHMOV CL, 4SHL AH, CLADD AL,AHMOV DL,ALMOV AL , BUFFERSI+2AND AL, 0FHMOV AH , BUFFERSI+3AND AH, 0FHMOV CL, 4SHL AH, CLADD AL,AHMOV DH,AL编写一个程序段,在DX 高4位全为0时,使AX=0;否则使AX=-1解: AND DX, 0F000H JZ

19、ZERO MOV AX 0FFFFH;-1补码=FFFFH JMP JENDZERO: MOV AX,0JEND: HALT26题(P109).按下述要求,分别给出3种方法,每种方法只用一条指令。使CF=0解:方法一:CLC方法二:ADD AL, 0方法三:SUB AL, 0使AX=0解:方法一:MOV AX, 0000H方法二:AND AX, 0000H方法三:SUB AX, AX同时使AX=0和CF=0解:方法一:SUB AX, AX方法二:AND AX, 0000H方法三:XOR AX, AX习题3(教材P182)1伪指令语句与硬指令语句的本质区别是什么?伪指令语句有什么主要作用?答:区

20、别:伪指令语句是汇编程序可以识别和解释语句(CPU不能直接执行),硬指令语句是CPU可以执行的语句。伪指令语句主要作用是为汇编程序提供解释说明,它仅仅是在汇编过程中告诉汇编程序如果进行汇编。2什么是标识符?汇编程序中标识符怎样组成?答:是用户自己定义的符号名。在汇编程序中标识符有两种:标号标识符,用在指令语句中,后面跟冒号,表示程序入口的逻辑地址。符号(或名字)标识符,用在伪指令语句中,后面不跟冒号,通常是定义一个变量,或说明变量类型。标识符一般不超31个字符,数字及常规符号($、?等)不能打头,也不能使用保留字。标识不区分大小写。4汇编语句有哪两种,每个语句有哪4部分组成?答:指令语句(又称

21、执行语句)和伪指令语句(又称说明性语句)。指令语句4部分包括,标号:、硬指令助记符、操作数、;注释。伪指令语句4部分包括,符号名、伪指令助记符、参数、;注释。5汇编程序开发有哪4个步骤?分别利用什么程序完成,产生什么输出文件?答:编辑。使用文本编辑器。产生汇编源程序文件:文件名.ASM。源文件是文本文件。汇编。使用汇编程序,如MASM或ML,排除程序中的语法错误。产生目标文件:文件名.OBJ。目标文件是二进制文件,是不能执行的文件。连接。使用LINK。产生可执行文件:文件名.EXE.调试。使用DEBUG。本身不产生文件,是对连接产生的可执行进行调试,排除程序中的算法错误,保证可执行文件的正确性

22、。7假设MYWORD是一个字变量,MYBYTE1和MYBYTE2是两个字节变量,指出下列语句中的错误原因。(1)MOV BYTE PTRBX, 1000答:数据类型不匹配,目的地址单元是字节单元,1000大于255。无法存放。(2)MOV BX, OFFSETSI答:OFFSET后只能跟标识符。(3)CMP MYBYTE1, MYBYTE2答:CMP的两个操作数不能同时在存储器中。(4)MOV AL, MYBYTE1+MYBYTE2答:运算符只能对常数进行操作,不能对变量进行操作。(5)SUB AL, MYWORD答:数据类型不匹配,AL是8位的,MYWORD是16位变量。(6) JNZ MY

23、WORD答:MYWORD是变量,其指的单元中存放的是操作数,不能用做跳转入口。8OPRL是个常数,请问下列语句中两个AND操作有什么不同?AND AL, OPRL AND 0FEH答:第一个AND是指令语句,在程序运行时才执行,第二个AND是逻辑运算符,是在汇编时就对两个常量完成的关系运算。选做题22题(P184).编写程序完成两个已知双精度(4B)A和B相加,并将结果存入双精度变量单元SUM中(不考虑溢出)A DD ?B DD ?SUM DD?MOV AX, WORD PTR AADD AX, WORD PTR BMOV WORD PTR SUM AXMOV AX, WORD PTR A+2

24、ADDC AX, WORD PTR B+2MOV WORD PTR SUM+2 AX22题(P184).编写程序完成12H,45H,0F3H 6AF,20H,0FEH,90H,0C8H,57H和34H共10字节数据之和,并将结果存入字节变量SUM中(不考虑溢出)。DAT1 DB 12H,45H,0F3H6AF,20H,0FEH, 90H, 0C8H, 57H,34H MOV CX, 10MOV AL, 0 LEA SI ,DAT1SUM_LOOP: ADD AL, SIINC SILOOP SUM_LOOPMOVE SUM, AL25题(P185).编写一个程序段,将AX寄存器中的16位数连续

25、4位分成一组,共4组,然后把这4组数分别放在AL、BL、CL和DL中。MOV BX, AXAND AL, 0FHMOV CL, 4SHR BL, CLAND BL, 0FHMOV DL, AHSHR DL, CLAND DL, 0FHMOV CL, AHAND CL, 0FH27题(P185).已知用于LED数码显示的代码表位为:LEDTABLE DB 0C0H,0FCH,0A4H, 0B0H,99H,92H,82H,0F8H,80H,90H,88H, 83H,0CCH,0C1H,86H,8EH 它依次表示09,AF这16个数码的显示代码。现编写一个程序实现将LEDNUM中的一个数字(09,A

26、F)转换成对应的LED显示码。LEA BX LEDTABLEMOV AL, LEDNUMXLAT26题(P185).编写一个程序,把从键盘输入的一个小写字母转换成大写字母显示出来MOV AH, 08H; 不带显示的键盘输入(字符以ASCII码存AL中)INT 21HAND AL, 1101 1111MOV DL, AL;将要显示字符的ASCII码DLMOV AH, 02H ;调显示INT 21H32题(P185).不用串操作指令,求主存0040H:0开始的一个64KB物理段中共有多少空格?编写程序实现。MOV AX,0040HMOV DS, AXMOV SI, 0MOV CX,0MOV DX,

27、0L0:MOV AL,SIINC SI CMP AL,20H ; 20H空格的ASCII码JNZ L1INC DXL1:LOOP L0HLT习题4(教材P280) 158255A有哪几种工作方式,对这些工作方式有什么规定?答:8255A有三种工作方式。分别是方式0(基本的输入输出方式);方式1(选通的输入输出方式);方式2(双向传输方式)。方式0:不需要应答联络信号。A、B、C口都可以工作在方式0。方式1:选通的输入输出方式,只有A、B端口可以工作在方式1,C端口作为A、B端口的应答信号。而且是单向的,作为输入端口,就不能做输出端口,作为输出端口就不能做输入端口。方式2:双向传输方式,只有A端

28、口可以工作在方式2,C端口做为A端口输入输出时的应答信号,可以工作在输入,也可以工作在输出。16假设8255A端口地址为00C000C6H,要求:(1)对8255A设置工作方式,A端口工作在方式1,输入;B端口工作在方式0,输出;端口C的4为配合端口A工作,端口C的低4为方式0,输入。(2)用置0置1,直接对PC6置1,对PC4置0答:端口地址0000 0000 1100 0000 0000 0000 1100 0110。说明A口地址为00C0H,B口地址为00C2H,C口地址为00C4H,控制字地址为00C6H。(1)控制字为:1011X001B,即0B1H(X取0)MOV AL,0B1HM

29、OV DX,00C6HOUT DX,AL(2)直接对PC6置1时的控制字为:0XXX1101B,即0DHMOV AL,0DHMOV DX,00C6HOUT DX,AL直接对PC4置0时的控制字为:0XXX1000B,即08HMOV AL,08HMOV DX,00C6HOUT DX,AL17使用8255A作为开关和LED指示灯的接口。要求8255A的A口连接8个开关,B口连接8个LED(发光二极管),用作指示灯,将A口的开关状态读入,然后送至B口控制指示灯亮、灭。试画出接口电路设计图,并编写程序实现。解:根据要求,设计电路如图所示。用PA7引脚上的开关控制PB7上的LED,PA0引脚上的开关控制

30、PB0上的LED。开关闭合输入低电平,开关打开输入高电平。高电平指示灯亮。A端口地址为8000H,B端口地址为8001H ,C端口地址为8002H ,控制字寄存器地址为8003H(假设未使用的地址线都取0)。控制字:10010000B(C口工作在输出),即90H参考程序:MOV AL, 90HMOV DX, 8003HOUT DX, ALLOOP:MOV DX, 8000HIN AL, DXMOV DX, 8001HOUT DX, ALJMP LOOP+5V8255APA7D0D7PB7PB0A0A1A15A0A1WRRDCSA0驱动电路WRRD3若8253芯片的接口地址为D0D0HD0D3H

31、,时钟信号为2MHz,现利用计数器0、1、2分别产生周期为10us的方波,每隔1ms和10ms(1s)产生一个负脉冲,试画出系统的连线图。并写出初始化程序。解:定时器0的计数初值=10×10-6×2×106=20,工作在方式3。控制字:00010111(17H)定时器1的计数初值=1×10-3×2×106=2000,工作在方式2。控制字:01110101(75H)定时器2的计数初值=10×10-3×2×106=20000=4E20H,工作在方式2。控制字:10110100(B4H)。注意:1s定时器2的计

32、数初值=2×106=2000000(超过16位计数器计数范围65536,采样2级计数,有计数1的输出OUT1作为计数器2的CLK2的计数脉冲。所以计数器2的计数常数1000初始化程序:MOV AL,17HMOV DX, 0D0D3HOUT DX, ALMOV AL,20MOV DX, 0D0D0HOUT DX, ALMOV AL,75HMOV DX, 0D0D3HOUT DX, ALMOV AX,00HMOV DX, 0D0D1HOUT DX, AL;先送计数值低位MOV AL,20HOUT DX, AL;再送计数值高位MOV AL,0B4HMOV DX, 0D0D3HOUT DX,

33、 ALMOV AX,1000MOV DX, 0D0D2HOUT DX, AL;先送计数值低位MOV AL,AHOUT DX, AL;再送计数值高位A15A14A13A12A11A10A9A8A7A6A5A4A3A2G1G2AG2BCBAY4A1A0CSA0A1RDWRRDWRD7D0OUT0CLK0GATE0OUT1CLK1GATE1OUT2CLK2GATE2825374LS1384某计算机系统采用8253的计数0作为频率发生器,输出频率500Hz,利用计数器1产生1000Hz的方波,输入的时钟频率为1.19MHz。请问计数器0和计数器1工作在什么方式下?计数初值分别是多少?解:计数器0工作方式2,计数器1工作方式3下。计数0初值=1.19×106÷500=2380计数2初值=1.19×106÷1000=11905利用8254的通道1,产生500Hz的方波信号。设输入时钟的频率CLK1=2.5MHz,端口地址为FFA0HFFA3H,试编制初始化程序。解:计数器1工作方式3下。计数1初值=2.5×10

温馨提示

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

评论

0/150

提交评论