本篇博客整理汇编语言课上及课后练习题,如有错误欢迎指正。
第一周作业
某一次课上练习
第7周练习题
设计题
第8周练习题
第七章作业
编辑
存储器寻址练习题
例子1:编辑
例子2:
编辑
例子3:
例子4:
8253芯片题
例子1:
例子2
填空题:
CPU的字长为4,代表字长为4位,需要1ns;8个字节是64位,64/4=16ns。
频率是周期的倒数 1/100s
器 AH 和低8位寄存器 AL 。
由于没有电子版只有当时手拍图片
答案: D
解析:计算公式为(5*2+2)*10+3=123 DUP就是重复几次
答案:C
解析:16=2^4 1M=2^20 故16M=2^24B
答案:25000H 916H 0A3800H (如果16进制中遇到字母开头需要加上前导0)
计算方法通通为段基址左移一个然后加上偏移量
答案:CF=1 OF=0 ZF=0 SF=0
计算过程:1101 1000 1000 0100
0100 1001 1000 1000
———————————
10010 0010 0000 1100 (220CH)
CF是进位标志 0-无进位 1-有进位(仅对无符号整数)
OF是溢出标志 1-有溢出 0-无溢出(判断方法1:都看成带符号的数 eg;一个负数加一个正数不可能溢出 判断方法2:观察最高位和次高位的进位是否都有进位 如果是则有溢出)
SF符号标志 1-最高位为1 0-最高位为0(注意SF是最高位不是进位 ;两个位要区分开)
ZF零标志 1-结果为0 0-其他值
答案:存储器寻址 寄存器寻址 立即数寻址
判断方法很简单 这里不再赘述
A、20 B、22 C、24 D、28
解析:1M=2^20 256=2^8 =>256M=2^28 B
考察知识点:CPU地址总线根数与内存空间的关系
地址总线含有x根,那么CPU可以访问2^x个内存单元
A、存储器寻址 B、寄存器寻址 C、立即数寻址 D、接口寻址
考察数据三种寻址方式:区分 立即数寻址 eg:mov ax,332h、寄存器寻址 eg:mov ax,bx、存储器寻址 eg:mov ax,[5] (标志:带有方括号)
A、TEST AX,1000H B、OR AX,1100H
C、XOR AX,1000H D、AND AX,1000H
A、地址信号较先有效 B、二者同时有效
C、数据信号较先有效 D、同时高电平
先寻地址再传输数据
A、执行停机指令 B、重新发送地址码
C、执行空操作指令 D、插入等待周期
如果一个总线周期4T时间完成不了一个操作,就会将READY置0 增加一个Tw时间
零标志位ZF=1,说明运算结果为0,即CX与1A2CH相等
指令段的物理地址=CS+IP(即段基址+偏移量)CS先左移一个位再与IP相加
36A80+007A=36AFAH
2.取到该指令后,执行该指令时,需要从哪个内存单元开始取两个字节送到AX寄存器中?
内存数据段物理地址=DS+数据偏移量
31A40+5=31A45H
设计一个存储器接口电路,其中部分电路给出如下图所示,要求该存储系统的地址范围为0DC000H~0DCFFFH,可增加的器件可以是基本门电路(与门、或门、非门、与非门、或非门),完成74LS138同CS的连接,画出虚线框中门电路。
摆出地址范围对应位置的数字
DC000H
1101 1100 0000 0000 0000
DCFFFH
1101 1100 1111 1111 1111
故A14 A13 A12=100
由上到下CBA=001 故选中Y1 CS连接Y1
门电路 A19 A18 A17 A16=1101所以需要A17连接一个非门转换为1 最后四个输出为1再连接一个总的非门 因为是低电平有效
像这样画
A、2018H B、201DH C、2020H D、2022H
解析:PUSH操作 SP-2; POP操作 SP+2
2020H-2=201EH
A、ALE B、READY C、BHE D、M//
ALE——地址锁存允许,是一个三态、输出、高电平有效的信号。
A、AX B、CS C、IP D、Flag
段内转移改变IP 段间转移改变CS
A、CF B、SF C、IF D、DF
DF是一种控制标志,控制字符串复制的方向
(1)、在取指对应的总线周期的T1中,16-13号引脚(即A3-A0)的值分别是多少?
取指令对应指令段地址为CS+IP,36A80+0074=36AFAH 由于16-13号引脚正好对应最低四位A3-A0 地址最后一个数为A 改为二进制:1010即分别为所对应A3-A0值
(2)、在取指对应的总线周期中,M/引脚=?
引脚=?
引脚=?
M/IO* 为存储器或I/O操作信号 其中I/O信号低电平有效
取值操作是由内存读入CPU中 故M高电平有效,M/IO*=1
RD*为读信号 且低电平有效 故RD*=0
WR*为写信号 且低电平有效 故WR*=1
(3)、在执行指令对应的总线周期的T1中,16-13号引脚(即A3-A0)的值分别是多少?
执行指令对应数据段地址为DS+数据偏移量[5] ,31A40+5=31A45H ,16-13号引脚对应最低位5 改为二进制:0101 即为A3-A0对应的值
(4)、在执行指令对应的总线周期的T2-T4中,16-13号引脚(即D3-D0)的值分别是多少?
传送数据时,直接传数据值5A7BH,16-13号引脚传送最低位B,改为二进制为:1011,对应D3-D0
4x1024x8/512x8=8 8片存储芯片
512=2^9 9根寻址线
4K=2^12 12根寻址线 3个片选 9个片内寻址
答案:(一)存储器读 I/O接口写
(二)dx (因为dx存放有端口号可以送到地址总线上)
(三)al (al寄存器中存放有数据,故将al的内容送到数据总线上)
(四)I/O接口芯片
(五)数据缓冲 信号变换
(六)独立编址 统一编址
(七)2^20=1M (8086CPU含有20根地址线)
(八)2^16=64K(8086CPU采用独立编址方式,只使用最低16个地址信号)
(二)
MOV SI,OFFSET BUFFER1
MOV CX,0
L0:
MOV DX,621H
AGAIN:
IN AL,DX
AND AL,0000 0100B
JZ AGAIN
MOV DX,620H
in al,dx
CMP AL,'a'
JB L1
CMP AL,'z'
JA L1
SUB AL,32 ;是a~z之间的减32L1:
MOV [SI],al
ADD SI,1
ADD CX,1
CMP CX,1000
JE OVER
JMP L0OVER:
解答:(1)2KB=2x1024x8b 故2x1024x8)/(1024x8)=2片
(2)1024=2^10 故需要10根地址线
(3)2K=2^11 故需要11根地址线 其中1个片选 10个片内寻址
解答:(1)(2x1024x8)/(1024x4)=4片
(2)1024=2^10 故需要10根地址线
(3)2K=2^11 故需要11根地址线寻址 其中1根做片选(每2片并一块看成1组),10根片内寻址
解答:红箭头指示的地方 代表CS片选Y0低电平有效即A18 A17对应 0 0
A19 A18 A17 A 16 A15.....A0
0 0 0 0 0000 0000 0000 0000 最小范围
0 0 0 1 1111 1111 1111 1111 最大范围
故红箭头所指范围为:00000H——1FFFFH
绿箭头同理 只不过A18 A17片选Y3有效 对应1 1 剩下的位摆出来地址范围(最小是0 最大是1)即可
Y0对应的片选信号有效 A11 A10=0 0固定下来两位
摆出来地址范围:
A11 A10 A9 A8 A7 A6 A5 A4 A3 A2 A1 A0
0 0 0 0 0 0 0 0 0 0 0 0
0 0 1 1 1 1 1 1 1 1 1 1
即000H——3FFH
另外再分析一下这道题:1Kx4的芯片用了八片 组成了 4KB的存储系统
其中 12根用作地址线 (4K=2^12) 2个片选(用来选八组芯片) 10个片内寻址
计时器8253-5通道0按方式3(方波发生器)工作,时钟CLK0的频率为1MHz,要求输出方波的频率为2000Hz,此时写入的计数初值应为多少?输出方波的“1”和“0”各占多少时间。假设通道0采用二进制方式计数,写出初始化程序段。8253-5的端口为400H,401H,402H,403H。
解答:(1)初值计算方法:频率/频率 或者 周期/周期
1M=10^6 10^6/2000=500
(2)250x1/(10^6)=250x10^-6 s
(3)题目改成二进制 不考十进制
mov dx,403h ;控制端口
mov al,00111110B ;写入控制字
out dx,al
mov ax,500 ;写入初值
mov dx,400h ;计数器0
out dx,al
mov al,ah
out dx,al
级联方式示意图:
解答:计数器0的初值计算为 1000/1=1000
计数器1的初值为 (4+1)/(1)=5
Mov dx,803h
Mov al,00110100b
Out dx,al
Mov ax,1000
Mov dx,800h;0号计数器
Out dx,al
Mov al,ah
Out dx,al
Mov dx,803h
Mov al,01010100b
Out dx,al
Mov al,5
Mov dx,801h;1号计数器
Out dx,al