第二章 微处理器及其结构
2-7 什么是逻辑地址? 什么是物理地址? 在实地址方式下,如何求存储器的物理地址? 设一个16字的数据区,它的起始地址为70A0H:DDF6(段基址:偏移地址).写出这个数据区的首字单元和末字单元的物理地址.
解:
1). 实模式下,逻辑地址由段基址和偏移地址组成.物理地址是真正的存储单元的地址. 2). 物理地址=段基址*16 + 偏移地址 3). 首字单元地址:
70A0H*16 +DDF6H = 70A00H + DDF6H = 7E7F6H 末字单元地址:
7E7F6H + (16-1)*2 = 7E7F6H + 1EH = 7E814H 注意:
相邻两个存储单元可构成一个字长为16位的字,在对准字时,用偶地址表示字的地址.
123456789101112131415160H2H4H6H8HAHCHEH10H12H14H16H18H1AH1CH1EH20H
第三章 指令系统
3-6 分别指出下列指令中源操作数和目标操作数的寻址方式. 若是存储器寻址,用表达式表示EA=?
(1)AND AX, 00FFH (2)ADD BX, [00FFH] (3)MOV AX, [BX+10H] (4)ADD AX, [ESI*8] (5)SUB [BP][SI], AX
(6)MOV AX, [BX+DI+20H] (7)CMP [SI], AX (8)OR AX, DX
(9)MOV EAX, [ESI][EDI*2] (10)PUSH DS 解:
(1)立即数寻址
(2)直接寻址 EA=00FFH (3)基址寻址 EA=(BX)+10 (4)比例间址 EA=ESI*8
(5)基址加间址寻址 EA=(BP)+(SI)
(6)带位移的基址加间址寻址 EA=(BX)+(DI)+20H (7)间址寻址 EA=(SI) (8)寄存器寻址
(9)基址加比例间址寻址 EA=(ESI)+(EDI)*2 (10)寄存器寻址 注意: ◆ 16位寻址: BX和BP作为基址寄存器.BX以DS作为默认段寄存器,BP以SS为默认
段寄存器.
SI和DI作为间址寄存器. 默认DS为段寄存器 ◆ 32位寻址: 8个32位通用寄存器均可作为基址寄存器,其中ESP,EBP以SS为默认
段寄存器,其余均以DS为默认段寄存器.
除ESP外的其它7个寄存器均可作间址寄存器,EBP默认SS作段基址
寄存器,其它以DS作段基址寄存器
3-7 32位微机工作在实地址模式下, 已知(DS) = 1000和(SS) = 2000H, (SI) = 007FH, (BX) = 0040H, (BP) = 0016H, 变量TABLE的偏移地址为0100H. 指出下列指令中源操作数的寻址方式,求它的有效地址(EA)和物理地址(PA).
(1)MOV AX, [1234H] (2)MOV AX, TABLE (3)MOV AX, [BX+100H] (4)MOV AX, TABLE[BP][SI] 解:
(1)直接寻址
EA=1234H PA=(DS)*16 + EA = 11234H (2)直接寻址
EA=(TABLE)=0100H PA=(DS)*16+EA=10100H (3)基址寻址
EA=(BX)+100H=0140H PA=(DS)*16+EA=10140H (4)带位移的基址加间址寻址
EA=(BP)+(SI)+TABLE=0195H PA=(SS)*16+EA=20195H
注意: 当基址寄存器和间址寄存器默认的段寄存器不同时,一般规定,由基址寄存器来决定默认的段寄存器为段基址寄存器. 这里BP为基址寄存器,所以默认SS为段基址寄存器.
3-8 指出下列指令的错误,并加以改正. (1)MOV DS, 100 (2)MOV 1020H, DX (3)SUB [1000H], [SI] (4)PUSH AL (5)IN AL, [80H] (6)MOV DS, ES (7)JMP BX (8)SHR DX, 4 (9)OUT 380H, AX (10)ADD AL, BX (11)POP CS
(12)MOV CL, 3300H 解:
(1)立即数不能直接传送到段寄存器中去 应改为: MOV AX, 100 MOV DS, AX
(2)立即数只能出现在源操作数位置 应改为: MOV DX,1020H
(3)源操作数和目标操作数不能同时为寄存器寻址 应改为: MOV AX, [1000H]
SUB AX, [SI]
(4)PUSH指令不能操作8位数据 应改为: PUSH AX
(5)[80H ]不是端口 IN AL ,80H 应改为: IN AL, 80H
(6)两个段寄存器之间不能直接传送 应改为: MOV AX, ES MOV DS,AX (7)对
(8)移位次数超过1的时候,要把移位次数放入CL中 应改为: MOV CL, 4 SHR DX, CL
(9)端口地址大于255时,要把地址放入DX中 应改为: MOV DX, 380H OUT DX, AX
(10)源操作数和目标操作数不匹配 应改为: ADD AX, BX
(11)POP指令只能使用在存储器或通用寄存器 可改为: POP AX
(12)源操作数和目标操作数不匹配 应改为: MOV CX, 3300H
3-9 已知: (DS) = 091DH, (SS) = 1E4AH, (AX) = 1234H, (BX) = 0024H, (CX) = 5678H, (BP) = 0024H, (SI) = 0012H, (DI) = 0032H, [09226H] = 00F6H, [09228H] = 1E40H, [1E4F6H] = 091DH. 试求下列各指令单独执行后的结果.
(1)MOV CL, 20H[BX][SI] ; (CL) = ? (2)MOV [BP][DI], CX ; [IE4F6H] = ? (3)LEA BX, 20H[BX][SI] : (BX) = ? MOV AX, 2[BX] : (AX) = ? (4)LDS SI, [BX][DI]
MOV [SI], BX ; (SI]) = ? (5)XCHG CX, 32H[BX] ; (AX) = ? XCHG 20[BX][SI], AX ; [09226H] = ? 解:
(1)(CL) = 00F6H (2)[IE4F6H] = 5678H (3)(BX) = 0056H
(AX) = 1E40H (4)(SI)= 0024H (5)(AX) = 5678H
[09226H] = 1234H
3-10 已知 (AL) = 0C4H, DATA单元中内容为5AH, 写出下列每条指令单独执行后的结果 (ODITSZAPC:0---xxux0)