1、1、TEC-XP机简介TEC-XP由清华大学科教仪器厂和清华大学计算机系联合研制。该实验系统重点用于计算机组成原理和计算机系统结构等课程的硬件教学实验,还支持监控程序、汇编语言程序设计、BASIC高级语言程序设计等软件方面的教学实验。1教学机系统配置了两个不同 实现方案的CPU系统,一个CPU沿袭传统的设计思路,和当前主流的教材配套,由中小规模的器件 组成;另一个CPU参考国外著名大学的设计思路用大规模的FPGA器件 设计实现 。2教学机的机器字长16位,即运算器、主存、数据 总线、地址总线都是16位。3指令系统支持多种基本寻址方式。其中一部分指令已 实现 ,用于 设计监控程序和用户的常规汇编
2、程序,尚保留多条指令供 实验者自己实现。4主存最大寻址空间是18K字,由基本容量 为8K(字节或16位的字)的ROM和2K(字节或16位的字)的RAM存储区域组成。还 可以进一步完成存储器扩展的教学 实验。5.原理上讲,主时钟脉冲的频 率可在几百KHz 近2MHz 之 间选择。6运算器由4片位片结构器件 级联而成,片 间用串行进位方式 传递进位信号。ALU 实现8种算术与逻辑运算功能,内部包括16 个双端口读出、 单端口写入的通用寄存器,和一个能自行以为的乘商寄存器。设置C(进位)、Z(结果为0)、V(溢出)和S(符号位)四个状态标志位。7控制器采用微程序和硬布线 两种控制方案实现,可由 实验
3、 者自由选择。实验人员可方便地修改已有设计,或加进若干自己 设计与实现的新指令,新老指令同时运行。8主机上安装有两路INTEL8251串行接口,一路出厂时已经实现,可直接接计算机终端,或接入一台PC 机作为自己的仿真终端;另一路保留学生扩展实现 。选用了MAX202倍压线路,以避免使用+12V 和-12V电源。9在主板的右下方,配置了完成中断教学实验的全套线路,可以实现三级中断和中断嵌套。10系统实现多种运行方式,可以单步/连续运行主存储器的指令或程序,也可以执行一条或若干条通过数据开关手动置入的指令。11主板上设置数据开关和微型开关、按键和指示灯,支持最低层的手工操作方式的输入/输出,通过指
4、示灯来显示重要的数据或控制信号的状态,可以完成及其调试和故障诊断。板上 还有支持教学实验用的一定数量的跳线夹。12.实验机硬件系统,全部功能部件分区域划分在大一些的水平放置的一 块印制电路板的不同区域,所有器件都用插座插接在印制板上,便于更换器件。13.实验计算机使用单一的5V 、最大电流3A 的直流模块电源,所耗电流在 1.52.5A之间。电源模块安装在水平电路板右上角位置,交流220V 通过电源接线插到机箱后侧板,经保险丝、开关连接到电路板上,开关安放在机箱右侧靠后位置,方便操作且比较安全。14. 两路的串行接口的接插座安装在机箱后侧板以方便接线插拔和机箱盖的打开关闭。2、TEC-XP实验
5、机的硬件组成21总线在教学计算机总线部件设计中, 选用单总线结构,数据 总线 、地址总线和控制总线都比较简单,保证教学机的正常运行并体 现出总线设计的基本原理。211数据总线被划分成内部总线IB(在CPU一侧)和外部总线DB(在存储器和串行接口一侧)两部分,它们之间通过2片8位的双向三态门电路连接在一起。3组存储器芯片的数据输入输出引脚都直接连接在一起,连接到16位的数据 总线DB上,串行接口芯片的 8位数据输入输出引脚只与数据总线DB的低8 位(DB7-DB0这8位)相连接。212地址总线的构成比较特殊,仅地址寄存器 AR一个来源, AR又只接收 ALU一路输入。内存 储器和接口电路的地址都
6、来自于地址总线AB(地址寄存器AR的输出),地址总线的最高3位送到1片三-八译码器,地址总线的低位字 节中的高4位(规定最高一位必定为1)送到另外1片三-八译码器,分别产生存储器芯片的8个片选信号和接口电路的8个片选信号。213控制总线提供内存和串口的读写命令,是把控制器提供的 3位控制信号送 1片双二-四译码器得到的,以决定有无内存或接口读写,若有,是内存和还是接口工作,执行的是读还是写操作。内存和CPU选用同步方式运行,串行接口和 CPU选用状态查询方式工作。22运算器运算器中配置了两组独立的8位字长的运算器,各自由 2片位片 结构的运算器器件组成;还有四位的状态标志寄存器和教学实验所需的
7、相关逻辑部件。全部的算术与逻辑运算均在这里完成;还完成几种寻址方式的实际地址计算;它也是主要的数据、地址传送的通路。23控制器控制器分别用微程序方式与硬布线方式两种方案实现,实验 者可以方便地选择使用其中任何一种。这能方便地比较两种控制器各自的优缺点,和设计过 程的相同的、不同的步骤与方法。在选用器件时,微程序方案中 选用了美国AMD公司的微程序定序器Am2901芯片,保证微程序设计的规范与实用性;控存体选用只读存储器(ROM)芯片,通过对该ROM的编程写入方式支持动态微程序设计。硬布线方案中,节拍逻辑与时序控制信号形成部件( 组合逻辑线路)选用了GAL20V8现场可编程器件和Macro Ar
8、ray CMOS High density(简写为MACH)器件, 这对简化控制器的逻辑设计 与实现至关重要。24存储器在教学计算机存储器部件设计中,出于 简化和容易实现的目的,选用静态存储器芯片实现内存储器系统,包括了唯读存储 区(ROM,存放监控程序等)和随 读写存储区(RAM)两部分,ROM存储区选用4片长度8位、容量 8KB的芯片实现, RAM存储 区选用2片长度8位、容量2KB的芯片实现,每2个8位的芯片合成一组 用于组成16位长度的内存字, 6个芯片被分成3组,其地址空间分配关系是:0-1777h用于第一组ROM,固化 监控程序,2000-2777h用于RAM ,保存用户程序和用户
9、数据,其高端的一些 单元作为监控程序的数据区,第二组ROM的地址范 围可以由用户选择,主要用于完成扩展内存容量的教学实验。25 I/O设备教学计算机提供了2路串行接口(INTEL 8251),以支持接入PC机作为 教学计算机的仿真终端完成 输入输出操作;第一个串口的端口地址分配为80h/81h,第二个串口的端口地址可以由用户选择。作 为扩展实验内容,也可以通过在一个40芯的器件插座上插上其他标准接口线路(例如INTEL 的8255、8253等)并适当接线,完成常用接口线路的输入输出操作。3、实验机指令系统3.1指令分类教学机的指令按不同的分类标准可划分为:1. 从指令长度区分,有单字指令和双字
10、指令。2. 从操作数的个数区分,有三操作数指令、双操作数指令、单操作数指令和无操作数指令。3. 从使用的寻址方式区分,有寄存器寻址、寄存器间址、立即数寻址、直接地址、相对寻址等多种基本寻址方式。4. 从指令功能区分,给出了算术和逻辑运算类指令、读写内存类指令、输入/输出类指令、转移指令、子程序调用和返回类指令,还有传送、移位、置进位标志和清进位标志等指令。5.按照指令的功能和它们的执行步骤,可以把该机的指令划分为如下4组。在后面几节中给出的指令流程框图、指令流程表都是以此为标准进行指令划分的。A组: 基本指令ADD、SUB、AND、OR、XOR、CMP、 TEST、MVRR、DEC、 INC、
11、SHL、SHR、JR、JRC、JRNC、JRZ、JRNZ扩展指令ADC、SBB、RCL、RCR、ASR、NOT 、CLC 、STC、EI、DI、JRS、JRNS、JMPRB组:基本指令JMPA、LDRR、STRR、PUSH、POP、PUSHF、POPF 、MVRD、IN 、OUT、RETC组: 扩展指令CALR、LDRA、STRA、LDRX、STRXD组: 基本指令CALA扩展指令IRETA组指令完成的是通用寄存器之间的数据运算或传送,在取指之后可一步完成。B组指令完成的是一次内存或I/O读、写操作,在取指之后可两步完成,第一步把要使用的地址传送到地址寄存器ARH、ARL中,第二步执行内存或I
12、/O 读、写操作。C组指令在取指之后可三步完成,其中CALR 指令在用两步读写内存之后,第三步执行寄存器之间的数据传送;而其它指令在第一步置地址寄存器ARH、ARL,第二步读内存(即取地址操作数)、计算内存地址、置地址寄存器ARH、ARL,第三步读、写内存。D组指令完成的是两次读、写内存操作,在取指之后可四步完成。3.2指令格式TEC-XP教学机实现了 29条基本指令,用于编写教学机的监控程序和支持简单的汇编语言程序设计。同时保留了19条扩展指令,供学生在教学实验中完成对这些指令的设计与调试。教学机的指令格式支持单字和双字指令,第一个指令字的高8位是指令操作码字段,低8位和双字指令的第二个指令
13、字是操作数、地址字段,分别有3种用法,如下图所示。DR SR操作码IO端口地址 / 相对偏移量立即数 / 直接内存地址 / 变址偏移量这8位指令操作码(记作“IR15IR8”),含义如下:1. IR15、IR14用于区分指令组:0X 表示A 组,10表示B组,11表示C、D组;C、D组的区分还要用IR11,IR11=0为C 组,IR11=1为D组。2. IR13用于区分基本指令和扩展指令:基本指令该位为0,扩展指令该位为1;3. IR12用于简化控制器实现,其值恒为0;4. IR11IR8用于区分同一指令组中的不同指令。教学机的指令根据指令字长、操作数不同可划分为如下6种指令格式:1)单字、无
14、操作数指令:格式:操作码 0000 0000基本指令:PSHF; 状态标志(C、Z、V、S、P1、P0)入栈POPF; 弹出栈顶数据送状态标志寄存器RET 子程序返回扩展指令:CLC; 清进位标志位C=0STC; 置进位标志位C=1EI; 开中断,置中断允许位INTE=1DI; 关中断,置中断允许位INTE=0IRET; 中断返回2)单字、单操作数指令:格式:DR 00000000 SROFFSET操作码I/O PORT基本指令:DEC DR; DRDR-1INC DR; DRDR+1SHL DR; DR逻辑左移,最低位补0,最高位移入CSHR DR; DR逻辑右移,最高位补0,最低位移入CJ
15、R OFFSET; 无条件跳转到ADR,ADR=原PC值+OFFSETJRC OFFSET; 当C=1时,跳转到ADR ,ADR=原PC 值+OFFSETJRNC OFFSET; 当C=0时,跳转到ADR ,ADR=原PC 值+OFFSETJRZ OFFSET; 当Z=1 时,跳转到ADR ,ADR=原PC值+OFFSETJRNZ OFFSET; 当Z=0 时,跳转到ADR ,ADR=原PC值+OFFSETIN I/O PORT; R0I/O PORT ,从外设I/O PORT端口读入数据到R0OUT I/O PORT; I/O PORTR0,将R0中的数据写入外设 I/O PORT端口PUS
16、H SR; SR入栈POP DR; 弹出栈顶数据送DR扩展指令:RCL DR; DR与C循环左移,C 移入最低位,最高位移入 CRCR DR; DR与C循环右移,C 移入最高位,最低位移入 CASR DR; DR算术右移,最高位保持不变,最低位移入CNOT DR; DR求反,即DR/DRJMPR SR; 无条件跳转到SR指向的地址CALR SR; 调用SR指向的子程序JRS OFFSET; 当S=1时,跳转到ADR ,ADR=原PC 值+OFFSETJRNS OFFSET; 当S=0时,跳转到ADR ,ADR=原PC 值+OFFSET3)单字、双操作数指令:格式:操作码 DR SR基本指令:A
17、DD DR,SR; DRDR+SRSUB DR,SR; DRDR-SRAND DR,SR; DRDR and SRCMP DR,SR; DR-SRXOR DR,SR; DRDR xor SRTEST DR,SR; DR and SROR DR,SR; DRDR or SRMVRR DR,SR; DRSRLDRR DR,SR; DRSRSTRR DR, SR; DRSR扩展指令:ADC DR,SR; DRDR+SR+CSBB DR,SR; DRDR-SR-C4)双字、单操作数指令:格式:操作码 0000 0000ADR基本指令:JMPA ADR; 无条件跳转到地址ADRCALA ADR; 调用首
18、地址在ADR的子程序5)双字、双操作数指令:格式1:DR 0000操作码0000 SRDATA基本指令:MVRD DR,DATA; DRDATA扩展指令:LDRA DR,ADR; DRADRSTRA ADR,SR ; ADRSR格式2:操作码 DR SRADR扩展指令:LDRX DR,OFFSETSR; DROFFSET+SRSTRX DR,OFFSETSR; OFFSET+SRDR4、实验机软件系统从计算机组成原理课程教学需求的角度看, 该计算机软件系 统的组成也是完整的,支持 简单的高级语言(包括浮点运算指令和基本函数运算功能),汇编语言(支持基本伪指令功能)和二进制的机器语言,配有自己的
19、监 控程序,以及PC机仿真终端程序等。毫无疑问,全部软件的源程序代码是宝贵的教学参考资料。从上图可以看到,软件实现的 计算机系统级和指令级模拟 系统,可以脱离硬件教学 计算机系统,直接在PC机的Windows平台上运行教学机的程序,可以在 PC机上运行教学机的监控程序,其运行效果和在真正的教学计算机上运行监控程序是相同的。微程序和硬连线这一级别的模拟软件,可以通过PC机屏幕查看在教学计算机内部数据、指令的流 动过程,并显示每一步的运行结果,为设计、调试教学机新的软件或硬件功能提供重要的 辅助作用。5、实验机与PC关系在本次试验中,需要使用到一台 TEC-XP实验机和一台PC机;其中TEC-XP
20、教学机系统是试验中必不可少的东西,教学机系 统中配置了两个不同方案的系统,一二CPU演戏传统 的 设计思路,和当前主流的教材配套,由中小规模的器件组成;另一个CPU参考国外著名大学的设计思路用大规模的EPGA器件设计实现。上面集成了各类实验所需的硬件元器件,它是我们本次实验的主要 设备。其次,在实习的过程中还配置了 PC机,这主要是为了在做联机试验是要用到电脑;当用串口线将PC机遇教学机连接好设置好后,通 过软件PCEC 16.EXE进行以及一些基本的汇编命令,我们就可以设计一些小程序来操作各种不同的寄存器,从而验证或是自己扩展一些汇编指令, 实现通过程序来操作 试验机教学系统的目的。软件:解
21、释 BASIC 语言汇编语言支持监控程序(指令)级模拟教学机模拟:运算器、控制器模 拟(微程序级或硬连线控制器级 模拟)主存储器模拟,总线,接口模拟输入设备/ 输出设备模拟运行 环境 :PC机,Windows系统6、实验机工作原理在实验机上运行一下小程序,来 说明试验机的工作原理小程序如下:2000 MVRD R0, 00012002 MVRD R1, 00022004 ADD R0,R12005 RET2006MVRD R0 , 0001这条指令的微程序如下取指周期PC - MAR,1 - RAd(CMDR) -CMARM(MAR)-MDR,(PC) + 1-PCAd(CMDR) -CMAR
22、MDR -IR, OP(IR) -CU-形成微指令执行周期0001 R0 将0001直接送至通用寄存器R0;Ad(CMDR)-CMAR 取指令程序入口地址 -CMARMVRD R1 , 0002这条指令的微程序如下取指周期:PC - MAR,1 - RAd(CMDR) -CMARM(MAR)-MDR,(PC) + 1-PCAd(CMDR) -CMARMDR -IR, OP(IR) -CU-形成微指令执行周期0002 R1 将0002直接送至寄存器R1;Ad(CMDR)-CMAR 取指令程序入口地址 -CMARADD R0,R1这条指令的微程序如下取指周期:PC - MAR,1 - RAd(CM
23、DR) -CMARM(MAR)-MDR,(PC) + 1-PCAd(CMDR) -CMARMDR -IR, OP(IR) -CU执行周期:(R0)+(R1) -R0Ad(CMDR)-CMAR 取指令程序入口地址 -CMARRET这条指令的微程序取指周期PC - MAR,1 - RAd(CMDR) -CMARM(MAR)-MDR,(PC) + 1-PCAd(CMDR) -CMARMDR -IR, OP(IR) -CU执行周期:0 GAd(CMDR)-CMAR 取指令程序入口地址 -CMAR通过上述这段实现加法运算的小程序可以得出计算机运行程序的原理,计算机首先将每一条汇编程序转化成微程序,而每一
24、段微程序都有若干条微指令构成,微指令可以直接对硬件进行操作。7、实验 内容及 实验过 程71基础汇编语言程序设计7.1.1实验内容用R命令查看寄存器内容或修改寄存器的内容。在命令行提示符状态下输入R R0, 用来修改R0寄存器的内容。通过D 2000可以显示从2000H开始的连续128个字的内容。通过E 2000可以修改存储器的内容。.用A命令键入一段汇编程序,主要是向累加器送入数据和进行运算。用U命令反汇编刚输入的程序。用G命令运行刚输入的程序。用P或T命令单步执行刚键入的程序7.1.2实验过程1. 准备一台串口工作良好的PC机;2. 将TEC-XP实验箱与PC机通过串口COM1或者COM2
25、连接,并且将实验系统左下方的五个黑色的控制机器运行状态的开关置成00110(连续、内存读指令、组合逻辑、联机、16位),并打开电源;3. 在PC 机C 盘目录下tec-xp目录下找到PCEC16.EXE 文件并运行,根据连接的 PC机串口设置联机工作,直至主机显示如下:TEC-2000 CRT MONITORVersion 1.0 April 2001Computer Architectur Lab. , Tsinghua UniversityProgrammed by He Jia即为联机成功;4. 联机成功后进行试验内容。72脱机运算器实验7.2.1实验过程1. 将教学机左下方的5个拨动开
26、关置为1XX00(单步、16 位、脱机);先按一下“RESET”按键,再按一下“START ”按键,进行初始化;2. 按下表所列的操作在机器上进行运算器脱机实验,将结果填入表中:其中D1取为0101H,D2取为1010H;通过两个十二位的红色微型开关向运算器提供控制信号,通过16位数据开关向运算器提供数据,通过指示灯观察运算结果及状态标志。表1.脱机运算器实验结果压 START前 压 START后运算 I8I0 SST SSH SCi B AALU输出CZVS ALU输出CZVS*D1+0-R0 011000111 001 00 00 0000 不用 0101 0000 0101 0000*D
27、2+0-R1 011000111 001 00 00 0001 不用 1010 0000 1010 0000R0+R1-R0 011000001 001 00 00 0000 0001 1111 0000 2121 0000R0-R1-R0 011001001 001 00 01 0000 0001 0101 0000 F0F1 1000R1-R0-R1 011001001 001 00 01 0001 0000 0F0F 1000 0E0E 1000R0R1-R0 011011001 001 00 00 0001 0000 0F0F 1000 0F0F 1010R0R1-R0 0111000
28、01 001 00 00 0000 0001 0101 1010 0101 1010R0R1-R0 011110001 001 00 00 0000 0001 0E0E 1010 0101 1000(R0R1)-R0 011111001 001 00 00 0000 0001 FEFE 1000 0E0E 10012*R0-R0 111000011 001 00 00 0000 不用 FEFE 1001 FDFC 0001R0/2-R0 101000011 001 00 00 0000 不用 FDFC 0001 7EFE 000173组合逻辑控制器实验7.3.1实验内容1. 完成控制器部件的教
29、学实验,主要内容是有学生自己设计几条指令的功能、格式和执行流程,并在教学计算机上实现、调试正确。2. 首先是看懂TEC-XP教学计算机的功能部件组成和线路逻辑关系,然后分析教学计算机中已经设计好并正常运行的几条指令(例如,ADD、SHR、OUT 、MVRD 、JRC 、CALA 、RET 等指令)的功能、格式和执行流程。3. 设计几条指令的功能、格式和执行流程,并在教学计算机上实现、调试正确。例如ADC、JRS、JRNS 、LDRA、STOR、JMPR等指令,可以从TEC-XP教学计算机系统技术说明与实验知道第二章给出的19条扩展指令中任意选择,当然也可以设计与实现其它的指令,包括原来己程序的
30、基础上按照ABEL语言的要求添加 新指令的控制信号,编译产生JED 文件并下载到MACH芯片里。软件的使用和下载参见附录。4. 单条运行指令,查看指令的功能、格式和执行流程。现将教学计算机左下方的5个拨动开关置为11110,再按一下“RESET ”按键,然后通过16位的数据开关(SWH、SWL)置入指令,按 “START”按键单步送脉冲,通过指示灯观察控制信号的变化。5. 用控制程序的A、E(扩展指令必须用 E命令置入)命令编写一段小程序,观察运行结果。实验是将教学机左下方的5个拨动开关置为00110,运行编写的小程序。观察终端显示的结果,检验设计的指令是否正确。若与预定结果不符,可查看指令的
31、功能、格式、执行、流程设计的是否正确。7.3.2实验过程1. 接通教学机电源;2. 将教学机左下方的5个拨动开关置为11110(单步、手动指令、组合、16位、联机);3. 按一下“RESET”按键;4. 通过16位的数据开关SWH 、SWL置入16位的指令操作码;5. 在单步方式下,通过指示灯观察各类基本指令的节拍。选择基本指令的A组指令中的 ADD指令,观察其节拍流程;6. 单步方式下,通过指示灯观察各类基本指令的控制信号。1)选择基本指令的A组指令中的 SHR指令,观察期执行过程中控制信号的变化,分析其作用。2)选择基本指令的B组指令中的 JMPA指令,观察其执行过程中信号的变化,分析其作
32、用。74存储器实验7.4.1实验内容1 要完成存储器容量扩展的教学实验,需为扩展存储器选择一个地址,并注意读写和OE控制信号的正确状态;2 用监控程序的D、E命令对存储器进行读写,比较 RAM(6116)EEPROM(28系列芯片)EPROM(27系列芯片)在读写上的异同;3 用监控程序的命令编写一段程序,对RAM(6116)进行读写,用D命令查看结果是否正确;4 用监控程序的A命令编写一段程序,对扩展存储器 EEPROM(28系列芯片)进行读写,用D命令查看结果是否正确;如不正确,分析原因,改写程序,重新运行。7.4.2实验过程1.检查FPGA下方的插针要按下列要求短接:标有“/MWR”“R
33、D”的插针左边两个短接,标有“ /MRD”“GND”的插针右边两个短接,标有ROMLCS和RAMLCS 的插针短接。2RAM(6116)读写实验1简单指令测试:(1)用E命令改变内存单元的值并用D 命令观察结果。图1-1. E命令改变内存单元的值并用D 命令观察结果分析:可以看到相应内存单元已被修改为指定的值(2) 并用D命令观察结果。图1-2. E命令改变内存单元的值并用D 命令观察结果分析:可以显示子指定内存单元地址开始128个内存单元的值,这里只截取了一部分以求简练。(3) 断电后重启内存单元的值已经改变图1-3. 断电后的查询结 果分析结果:从输入输出结果可以看出, RAM芯片在断电重
34、启后原先写入的程序都会丢失,需要每次重新执行输入写入程序的过程。2用A命令输入一段程序,执行并观察结果。截屏如下:图2-1.A命令执行结果分析:第一次单步调试,R0的值变为 AAAAH,其余寄存器的值不变第二次但不调试,R1的值变为 5555H,其余寄存器的值不变第三次单步调试,R0的值变为 0000H,其余寄存器的值不变图2-2.A命令执行结果续3 EPROM芯片实验。将芯片0000001F 的内存单元的值置为 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F 10 11 12 13 14 15 16 17 18 19 1A 1B 1C 1D 1E 1
35、F。截屏如下:图3-1. 擦除芯片内容断电重启后的实验结果如下:图3-2. 断电重启后的实验结 果分析:由图可知断电后重启,内存数值没变。4 58C65芯片扩展EEPROM实验。(1)、用E命令改变内存单元的值并用D 命令观察结果。截屏如下:图4-1. 用E命令改变内存单元的值并用D 命令观察结果图4-2 修改内存单元程序代 码图4-3 内存单元值修改效果演示分析:有上述结果可以知道从5000H 开始的内存值被程序修改,同时运行时可以看到程序有延迟,这是由于地址为2200开始的子程序代码决定的,当将子程序中R3的内容修改为00FF后运行结果仍正确,但延迟时间有变化。75微程序控制器实验7.5.
36、1实验内容1. 实验之前,应认真准备,写出实验步骤和具体设计内容,否则实验效率会特别低,一次实验时间根本无法完成实验任务,即使基本做对了,也很难说学懂了什么重要教学内容;2. 应在实验前掌握所有控制信号的作用,在脱机运算器实验中,已给出了与运算器有关的控制信号的作用,16位机微程序控制器用到的控制信号的功能表可参见TEC-XP教学计算机系统技术说明与实验指导第三章的控制器部件和运算器部件的相关内容。需要注意的是中端用到了DC23,在T4T0=00010 一拍时DC23 为1,其余节拍均为0;3. 实验过程中,应认真进行实验操作,既不要因为粗心造成短路等事故而损坏设备,又要仔细思考实验有关内容,
37、提高学习的主动性和创造性,把自己想不太明白的问题通过实验理解清楚,争取最好的实验效果,力求达到教学实验的主要目的;4. 实验之后, 思考总结,写出实验报告,包括实验步骤和具体的实验结果,遇到的主要问题和分析与解决问题的思路。7.5.2实验过程1. 接通教学机电源;2. 将教学机左下方的5个拨动开关置为11010(单步、手 动 置指令、微程序、联机、16位);3. 按一下“RESET”按键;4. 通过16位的数据开关SWH 、SWL置入指令操作码;5. 在单步方式下,通过指示灯 观察各类基本指令的微码1)选择基本指令的A组中的 ADD指令, 观察其节拍流程2)选择基本指令的B组指令中的MVRD指
38、令, 观察其节拍流程6. 在连续方式下,用A命令键 入程序并运行图6-1分析:程序将R0赋值 0036H,结 果如图,寄存器 R0的值已被修改。7. MPROM芯片扩展:图7-1对CMH的操作图7-2对CML的操作8. 测试ADC指令:图8-1分析:程序将R0赋值0101,R1赋值 1010,然后用 E命令键入利用已 经编写好的ADC指令其中6D00和2001的得出是从扩展指令的指令格式表中查表得出的。 00100000 DRSR 即2001,功能是DRDR+SR+C.所以是将R0, R1中的值相加再加1最后放到R0中,而R1中的值不变。于是的到如上结果。9. 测试CALR指令:图9-1测试C
39、ALR指令程序代码图9-2测试CALR指令测试效果分析:就是一个调用子程序的过程,实现输出AZ,具体原理和上一题一样。图9-3测试CALR指令内存单元值查看10. 测试指令LDRA:图10-1测试指令LDRA效果演示分析:先将内存单元2100的内容赋给R0,输出R0,然后判断是否输出万,未完则循环测试,然后通过LDRA指令将内存单元2101的值赋给R0,然后在输出R0.这里同样,扩展指令无法通过A指令输入,必须用E指令键入,而且同样修改的值为其指令格式的编码。同样在扩展指令格式表中可以查表的到。8、实验总结通过本次实习使我对计算机的工作原理有了更加深入的了解,在学习本学期开设的计算机组成与原理这门课程时感觉很吃力,很多概念,电路图搞不清楚,更重要的是计算机有的模块到底是如何工作的感觉很模糊,对微指令那块学习起来感觉很吃力,因为不明白计算机到底是怎样通过微指令控制硬件电路的。还好,通过本次实习使我彻底搞清楚了微指令,明白了计算机是如何解释一条汇编指令的。本次试验还尝试扩展了一条微指令,扩展的是SBB那条指令,运行结果是正确的,说明微程序工作原理应该搞清楚了。本次实验时间很紧张,不过学到了很多有用的知识,清楚了计算机的工作原理,为下学期的汇编语言的学习打下了坚实的基础。