57. 现有两片4110RAM组成存储器系统如下图所示。每片4110的存储容量为1K×8bit,地址译码器用74LS138。试回答:
(1) 第一片和和第二片4110的地址范围各是什么?
(2) 若要扩展1KB存储容量,4110须要几片?请将新增加的4110芯片画在图上并连接相应的信号线。新增RAM的地址范围是什么?
(3) 说明上述电路中(包括新增部分)存储器有无地址重迭现象?若有请指出重迭的范围并提出消除地址重迭的措施。
74LS138A19A17A16A15A18G1G2AG2BCBAY4Y24110CECECEA13A12A11........DBD0(1)D0(2)....WRRDD7D7D7D0....WR........ABA0RDWRA0RDMEMRMEMW....A9A9A9A0
解:G1=1 ==> A19 = 0
G2A=1 ==> A18 = 0
G2B=1 ==> A17 = A16 = A15 =0 A14和A10没有用到,可均设为0
(1)第一片 A13A12A11 =010 地址范围(Y2): 1000H---13FFH 第二片 A13A12A11 =100 地址范围(Y4): 2000H ----23FFH
(2)新一片4110的片选若接Y3,A13A12A11 =011 地址范围是:1800H---1BFFH 片选若接Y6, A13A12A11 =110 地址范围是:3000H---33FFH
片选若接Y0,A13A12A11 =000地址范围是:0000H---03FFH
片选若接Y1, A13A12A11 =001 地址范围是:0800H---0BFFH
片选若接Y5,A13A12A11 =101地址范围是:2800H---2BFFH
片选若接Y7, A13A12A11 =111 地址范围是:3800H---3BFFH
(3)由于地址信号A14和A10未参加地址译码,故每个译码输出端重叠4个地址范围。除(1)列出的基本地址(A14A10=00)外,还各有三个地址范围如下: A14A10=01 A14A10=10 A14A10=11 Y2 1400H--17FFH 5000H—53FFH 5400H—57FFH
Y3 1C00H—1FFFH 5800H—5BFFH 5C00H—5FFFH Y4 2400H—27FFH 6000H—63FFH 6400H—67FFH Y6 3400H—37FFH 7000H—73FFH 7400H—77FFH
消除地址重叠的方法是让地址信号A14和A10也参加地址译码,例如: A14、A10和A17、A16、A15一起纳入负与门(5输入端)译码; 或A14、A10和A18一起纳入负与门(3输入端)译码。
58. 试分析下图中存储器芯片6116的存储容量及在系统中的地址范围。
DBD7~D0A10~A0ABA17A13A12A15A14A16A18A19解:6116的地址容量是2K(11根地址线)B。
6116CSMEMWWERD
MEMR 其地址范围有相互重叠的两个区域:A0000H—A07FFH
63. PC/XT中接口地址译码电路如图所示:
或 A0800H—A0FFFH。
(1) 列表说明各译码输出端有效时对应地址信号A9~A0的取值,并用十六进制写出地址范围。 (2) 说明译码器输入信号AEN的名称及在此处的作用。 (3) 说明信号IOR和IOW在此处的作用。
A8A7A6A9AEN74LS138G1Y7A5A4A3IORIOWG2AG2BCBAA2A1A0Y0
解:1)译码电路中,A9A8A7A6A5A4A3A2A1A0=10,1111,0XXXB。因此Y0—Y7对应的地址范围分别是:
2F0H 2F1H . . 2F7H
2)AEN信号在此使译码电路在DMA时不工作,仅在CPU执行指令时工作。
3)IOR、IOW在此使译码电路在执行存储器读写时不工作,仅在执行I/O指令时工作。
64. 8086/8088响应中断后要获得中断类型号。举例说明不同的中断类型产生中断类型号的方法有哪几种?
解:不同的中断类型产生中断类型号的方法有三种: 1) CPU在执行指令过程中自动产生中断类型号,例如执行除法指令过程中,若发生除
以零中断,则自动产生类型号为0的中断,即INT 0。又如发生NMI时,自动产生类型号为2的中断,即INT 2。
2) CPU在执行指令过程中从指令机器码中获得中断类型号。写在源程序中的所有INT
n指令都属于这种情况。
3) 由外部可屏蔽中断源引发的硬中断由中断管理电路8259A在中断响应时提供中断类
型号,如系统时钟中断、键盘中断、硬软磁盘中断等。
36 .两个4位压缩的BCD数,存放在存储器中的地址为ALPHA和BETA,编写程序求两个数的和,结果存入ALPHA单元。 解:DATA SEGMENT
ALPHA DB 34H, 12H ;压缩的BCD数1字节表示2位,4位应占1个字。用DW的
可读性更好,但后面只能用字节加。 BETA DB 52H, 46H DATA ENDS
STACK SEGMENT STACK DB 100 DUP(?) STACK ENDS CODE SEGMENT
ASSUME CS:CODE, DS:DATA, SS:STACK START: MOV AX, DATA MOV DS, AX MOV SI, 0 MOV CX, 2
CLC
LOOPER: MOV AL, ALPHA [SI]
ADC AL, BETA [SI] DAA
MOV ALPHA [SI], AL INC SI
DEC CX ;也可以和下面可以合起来改成LOOP LOOPER JNZ LOOPER
CODE ENDS
END START
39. 比较AX,BX,CX中带符号补码数的大小,将其最大者放在AX中,试编写此程序。 解:DATA SEGMENT DATA1 DW 4142H DATA2 DW 8107H DATA3 DW 0A123H MAX DW ? DATA ENDS
STACK SEGMENT STACK DB 100 DUP(?) STACK ENDS CODE SEGMENT
ASSUME CS:CODE, DS:DATA, SS:STACK
START: MOV AX, DATA MOV DS, AX
MOV AX, DATA1 MOV BX, DATA2 MOV CX, DATA3
法 一:
MOV MAX, AX CMP BX, MAX JG GREAT1
NEXT: CMP CX, MAX JG GREAT2 JLE GOON GREAT1: MOV MAX, BX JMP NEXT GREAT2: MOV MAX, CX GOON: MOV AX, MAX 法 二:更好,不仅少占用资源,而且快 CMP AX,BX
JGE NEXT1 XCHG AX,BX
NEXT1: CMP AX, CX JGE NEXT2 XCHG AX,CX NEXT2: MOV MAX, AX
CODE ENDS
END START
40. 编写程序,将BLOCK中的100个字节数据的位置颠倒过来(即第1个字节和第100个字节的内容互换,第2个字节和第99个字节的内容互换,…)。 解: MOV CX, 50 ;循环次数 LEA SI, BLOCK
MOV AX, SI ADD AX, 99 MOV DI, AX
TOP: MOV AL, [SI] ;也可以取一个到AL后和内存XCHG MOV BL, [DI]
MOV [DI], AL MOV [SI], BL
INC SI DEC DI LOOP TOP
41. 编写程序,求AX寄存器中有多少个“1”,并将其个数存入CL寄存器中。 解: XOR BL, BL
MOV CX, 16
COUNT: SHL AX, 1 JNC GOON NEXT: INC BL
GOON: LOOP COUNT ;事实上,某次移位后AX=0就可以退出了 MOV CL,BL
48. 编写程序,把三个连续存放的单字节带符号整数,按递增次序重新存放在原来的三个存储单元中。 解:最直接的做法: DATA SEGMENT DATA1 DB 12H DATA2 DB 56H DATA3 DB ?