文档库 最新最全的文档下载
当前位置:文档库 › MOVX指令执行过程

MOVX指令执行过程

MOVX指令执行过程
MOVX指令执行过程

外部数据存储器读周期

访问外部存储器指令MOVX

执行访问外部存储器指令MOVX时,首先从程序存储器中取出指令,然后从外部数据存储器中取出数据,因此该指令执行时序图与前三类指令不同。由于MOVX是单字节双周期指令,所以在取指令阶段(即第一个机器周期的S1P1到S4P2)是读1丢1,而在执行指令读数据阶段(即第一个机器周期的S5到第二个机器周期的S3)所完成的操作如下:

(1)先将外部数据存储单元的地址ADDR由DPTR从P0与P2口输出,即时序图中的S5P1到S6P2阶段。并在S4P2到S5P2阶段,发ALE信号将地址锁存。

(2)在第二个机器周期S1P2到S2P2内取消ALE与程序选通信号PSEN (即取消取指操作),使P0口专门用于传送数据。同时发读信号,通过P0口将外部数据存储单元中的数据传送到累加器A中。即:时序图的S6P2到S4P1阶段。

(3)由于锁存的地址为外部数据存储单元的地址,所以在第二个机器周期S4取消取指令的操作,即:不再发程序选通信号PSEN 。

PLC编程语言操作指令使用步骤详解

PLC编程语言/操作指令/使用步骤详解 [导读]控制系统流程图是一种较新的编程方法。它是用像控制系统流程图一样的功能图表达一个控制过程,目前国际电工协会(IEC)正在实施发展这种新式的编程标准。 一、PLC编程语言 1.梯形图编程语言 梯形图沿袭了继电器控制电路的形式,它是在电器控制系统中常用的继电器、接触器逻辑控制基础上简化了符号演变来的,形象、直观、实用。 梯形图的设计应注意以下三点: (一)梯形图按从左到右、从上到下的顺序排列。每一逻辑行起始于左母线,然后是触点的串、并联接,最后是线圈与右母线相联。 (二)梯形图中每个梯级流过的不是物理电流,而是“概念电流”,从左流向右,其两端没有电源。这个“概念电流”只是形象地描述用户程序执行中应满足线圈接通的条件。 (三)输入继电器用于接收外部输入信号,而不能由PLC内部其它继电器的触点来驱动。因此,梯形图中只出现输入继电器的触点,而不出现其线圈。输出继电器输出程序执行结果给外部输出设备,当梯形图中的输出继电器线圈得电时,就有信号输出,但不是直接驱动输出设备,而要通过输出接口的继电器、晶体管或晶闸管才能实现。输出继电器的触点可供内部编程使用。 2.语句表编程语言

指令语句表示一种与计算机汇编语言相类似的助记符编程方式,但比汇编语言易懂易学。一条指令语句是由步序、指令语和作用器件编号三部分组成。 3.控制系统流程图编程图 控制系统流程图是一种较新的编程方法。它是用像控制系统流程图一样的功能图表达一个控制过程,目前国际电工协会(IEC)正在实施发展这种新式的编程标准。 二、基本指令简介 基本指令如表所示 取指令 LD I、Q、M、SM、T、C、V、S、L 常开接点逻辑运算起始 取反指令 LDN I、Q、M、SM、T、C、V、S、L 常闭接点逻辑运算起始 线圈驱动指令

计算机程序的执行过程

一。计算机程序的执行过程 程序就是指令的集合 为使计算机按预定要求工作,首先要编制程序。程序是一个特定的指令序列,它告诉计算机要做哪些事,按什么步骤去做。指令是一组二进制信息的代码,用来表示计算机所能完成的基本操作。 1.程序 程序是为求解某个特定问题而设计的指令序列。程序中的每条指令规定机器完成一组基本操作。如果把计算机完成一次任务的过程比作乐队的一次演奏,那么控制器就好比是一位指挥,计算机的其它功能部件就好比是各种乐器与演员,而程序就好像是乐谱。计算机的工作过程就是执行程序的过程,或者说,控制器是根据程序的规定对计算机实施控制的。例如,对于算式 计算机的解题步骤可作如下安排: 步骤1:取a ; 步骤2:取b ; 步骤3:判断; . 若b≥0,执行步骤4 .若b<0,执行步骤6 步骤4:执行a+b; 步骤5:转步骤7; 步骤6:执行a-b; 步骤7:结束。 计算机的工作过程可归结为:取指令→分析指令→执行指令→再取下一条指令,直到程序结束的反复循环过程。通常把其中的一次循环称为计算机的一个指令周期。总之,我们可把程序对计算机的控制归结为每个指令周期中指令对计算机的控制。 2.指令 程序是由指令组成的。指令是机器所能识别的一组编制成特定格式的代码串,它要求机器在一个规定的时间段(指令周期)内,完成一组特定的操作。指令的基本格式可归结为操作码OP和操作数地址AD两部分,具体内容是: ⑴指出计算机应完成的一组操作内容,如传送(MOV)、加法(ADD)、减法(SUB)、输出、停机(HLT)、条件转移(JZ)等。这部分称为指令的操作码部分。 ⑵两个操作数的地址和存放结果的地址及寻址方式。 ⑶为保证程序执行的连续性,在执行当前指令时,还需指出下一条指令的地址。由于指令在存储器中一般是顺序存放的,所以只要设置一个指令指针(IP),每执行一条指令,IP自动加1,便自动指出下一条指令的地址,而不必在指令中专门指出下一条指令的地址。只有在转移指令中才指出下一条指令的地址。此时,IP的内容将随转移指令所指示的内容改变。 3.指令的执行 指令规定的内容是通过控制器执行的,或者说控制器是按照一条指令的内容指挥操作的。 ⑴控制器的功能

计算机系统结构作业答案第三章(张晨曦)

3.1 -3.3为术语解释等解答题。 3.4 设一条指令的执行过程分为取指令,分析指令和执行指令3个阶段,每个阶段所需时间分别为ΔT, ΔT, 2ΔT,分别求出下列各种情况下,连续执行N条指令所需的时间。 (1) 顺序执行方式 (2) 只有“取指令”与“执行指令”重叠 (3) “取指令”,“分析指令”与“执行指令”重叠 解: (1) 4NΔT (2) (3N+1) ΔT (3) 2(N+1) ΔT 3.6 解决流水线瓶颈问题有哪两种常用方法? 解: (1) 细分瓶颈段 将瓶颈段细分为若干个子瓶颈段 (2) 重复设置瓶颈段 重复设置瓶颈段,使之并行工作,以此错开处理任务 3.9 列举下面循环中的所有相关,包括输出相关,反相关,真数据相关。 for(i = 2; i < 100; i=i+1) { a[i] = b[i] + a[i]; -----(1) c[i+1] = a[i] + d[i]; -----(2) a[i-1] = 2*b[i]; -----(3) b[i+1] = 2*b[i]; -----(4) } 解: 输出相关:第k次循环时(1)与第k+1轮时(3) 反相关:第k次循环时(1)和(2)与第k-1轮时(3) 真数据相关:每次循环(1)与(2),第k次循环(4)与k+1次循环(1),(3),(4) 3.12 有一指令流水线如下所示 50ns 50ns 100ns 200ns (1)求连续如入10条指令的情况下,该流水线的实际吞吐率和效率 (2)该流水线的“瓶颈”在哪一段?请采用两种不同的措施消除此“瓶颈”。对于你所给出 的两种新的流水线连续输入10条指令时,其实际吞吐率和效率各是多少? 解:(1)(m表示流水线级数,n 表示任务数)

单片机的组成结构及指令执行过程

单片机的组成结构及指令执行过程单片机结构 单片机结构 常用的单片机以MCS-51系列单片机为例,它的组成框图如图1-2所示。 微处理器由运算器和控制器两个部分组成,还有包括相关的寄存器。 1.运算器 运算器由运算部件——算术逻辑单元(Arithmetic & Logical Unit,简称ALU)、累加器和寄存器等几部分组成。ALU的作用是把传来的数据进行算术或逻辑运算,输入来源为两个8位数据,分别来自累加器和数据寄存器。ALU能完成对这两个数据进行加、减、与、或、比较大小等操作,最后将结果存入累加器。例如,两个数6和7相加,在相加之前,操作数6放在累加器中,7放在数据寄存器中,当执行加法指令时,ALU即把两个数相加并把结果13存入累加器,取代累加器原来的内容6。 运算器有两个功能: (1) 执行各种算术运算。 (2) 执行各种逻辑运算,并进行逻辑测试,如零值测试或两个值的比较。 运算器所执行全部操作都是由控制器发出的控制信号来指挥的,并且,一个算术操作产生一个运算结果,一个逻辑操作产生一个判决。 2.控制器 控制器由程序计数器、指令寄存器、指令译码器、时序发生器和操作控制器等组成,是发布命令的“决策机构”,即协调和指挥整个微机系统的操作。其主要功能有: (1) 从内存中取出一条指令,并指出下一条指令在内存中的位置。 (2) 对指令进行译码和测试,并产生相应的操作控制信号,以便于执行规定的动作。 (3) 指挥并控制CPU、内存和输入输出设备之间数据流动的方向。 微处理器内通过内部总线把ALU、计数器、寄存器和控制部分互联,并通过外部总线与外部的存储器、输入输出接口电路联接。外部总线又称为系统总线,分为数据总线DB、地址

cpu指令运行说明

cpu指令运行说明 cpu指令运行说明一计算机每执行一条指令都可分为三个阶段进行。即取指令-----分析指令-----执行指令。 取指令的任务是:根据程序计数器pc中的值从程序存储器读出现行指令,送到指令寄存器。 分析指令阶段的任务是:将指令寄存器中的指令操作码取出后进行译码,分析其指令性质。如指令要求操作数,则寻找操作数地址。 计算机执行程序的过程实际上就是逐条指令地重复上述操作过程,直至遇到停机指令可循环等待指令。 一般计算机进行工作时,首先要通过外部设备把程序和数据通过输入接口电路和数据总线送入到存储器,然后逐条取出执行。但单片机中的程序一般事先我们都已通过写入器固化在片内或片外程序存储器中。因而一开机即可执行指令。 下面我们将举个实例来说明指令的执行过程: 开机时,程序计算器pc变为0000h。然后单片机在时序电路作用下自动进入执行程序过程。执行过程实际上就是取出指令(取出存储器中事先存放的指令阶段)和执行指令(分析和执行指令)的循环过程。 例如执行指令:mov a,#0e0h,其机器码为“74h e0h”,该指令的功能是把操作数e0h送入累加器,

0000h单元中已存放74h,0001h单元中已存放e0h。当单片机开始运行时,首先是进入取指阶段,其次序是: 1 程序计数器的内容(这时是0000h)送到地址寄存器; 2 程序计数器的内容自动加1(变为0001h); 3 地址寄存器的内容(0000h)通过内部地址总线送到存储器,以存储器中地址译码电跟,使地址为0000h的单元被选中; 4 cpu使读控制线有效; 5 在读命令控制下被选中存储器单元的内容(此时应为74h)送到内部数据总线上,因为是取指阶段,所以该内容通过数据总线被送到指令寄存器。至此,取指阶段完成,进入译码分析和执行指令阶段。 由于本次进入指令寄存器中的内容是74h(操作码),以译码器译码后单片机就会知道该指令是要将一个数送到a累加器,而该数是在这个代码的下一个存储单元。所以,执行该指令还必须把数据(e0h)从存储器中取出送到cpu,即还要在存储器中取第二个字节。其过程与取指阶段很相似,只是此时pc已为0001h。指令译码器结合时序部件,产生74h操作码的微操作系列,使数字e0h 从0001h单元取出。因为指令是要求把取得的数送到a累加器,所以取出的数字经内部数据总线进入a累加器,而不是进入指令寄存器。至此,一条指令的执行完毕。单片机中pc="0002h",pc 在cpu每次向存储器取指或取数时自动加1,单片机又进入下一取指阶段。这一过程一直重复下去,直至收到暂停指令或循环等待指令暂停。cpu就是这样一条一条地执行指令,完成所有规定cpu指令运行说明二首先,cpu的内部结构可以分为控制

实验一(B) 利用DEBUG熟悉常用指令的使用

实验一利用DEBUG熟悉常用指令的使用 一、实验目的 熟悉指令系统,掌握常用指令的用法;通过实验加深对各种寻址方式的理解;能熟练使用DEBUG中的命令对指令进行反汇编,观察并了解机器代码。 二、示例 请分别用一条汇编语言指令完成如下功能:(过程略) (1)用寄存器BX和SI的基址变址寻址方式把存储器的一个字节与AL寄存器的内容相加, 并把结果送到AL中。 (2) 用位移量为0520H的直接寻址方式把存储器中的一个字与3412H相加,并把结果送回 该存储单元。 三、实验题 1、调试、验证下列指令的结果,已知(DS)=2000H,(BX)=0100H,(SI)=0002H, (BP)=0200H,(SS)=2300H,(20100)=12H,(20101)=34H, (20102)=56H, (20103)=78H, (21200)=2AH, (21201)=4CH,(21202)=B7H,(21203)=65H, (23204)=88H, 说明各指令执行完后AX寄存器的内容。要求输入指令,相应存储单元的内容要事先设置,单步T执行,观察执行结果。 (1)MOV AX,1200H (2) MOV AX,BX (3)MOV AX,[1200H] (4)MOV AX,[BX] (5)MOV AX,1100[BX] (6)MOV AX,[BX][SI] (7)MOV AX,1100[BX][SI] (8)MOV AX,[BP+SI+04] 2、上机调试、验证教材习题3.15和习题3.16。单步执行、观察运行结果并与自己的判断

进行比较。 四、实验报告 总结操作步骤及各种寻址方式,正确理解算术指令对标志位的影响,记录调试结果。

实验三 Debug的使用(2)

实验三Debug的使用(二) 一、实验要求和目的 1.熟悉Debug环境。 2.掌握常用Debug命令的基本操作。 二、软硬件环境 1.硬件环境:微机CPU 486以上,500MB以上硬盘,32M以上内存; 2.软件环境:装有MASM 5.0、DEBUG、LINK和EDIT 等应用程序。 三、实验涉及的主要知识单元 前面实验中,讲了Debug一些主要命令的用法,这里,我们再补充一些关于Debug的知识。 (1)关于D命令 从上次实验中,我们知道,D命令是查看内存单元的命令,可以用: d 段地址:偏移地址的格式查看指定的内存单元的内容,上次实验中,D命令后面的段地址和偏移地址都是直接给出的。 现在,我们知道段地址是放在段寄存器中的,在D 命令后面直接给出段地址,是Debug提供的一种直观的操作方式。D命令是由Debug执行的,Debug在执行“d 1000:0”这样的命令时,也会先将段地址1000

送入段寄存器中。 Debug是靠什么来执行D命令的?当然是一段程序。 谁来执行这段程序?当然是CPU。 CPU在访问内存单元的时候从哪里得到内存单元的段地址?从段寄存器中得到。 所以,Debug在其处理D命令的程序段中,必须有将段地址送入段寄存器的代码。 段寄存器有4个:CS、DS、SS、ES,将段地址送入哪个段寄存器呢? 首先不能是CS,因为CS:IP必须指向Debug处理D 命令的代码,也不能是SS,因为SS:SP要指向栈顶。这样只剩下了DS和ES可以选择,放在哪里呢?我们知道,访问内存的指令如“mov ax,[0]”等一般都默认段地址在ds中,所以Debug在执行如:“d 段地址:偏移地址”这种D命令时,将段地址送入ds中比较方便。 D命令也提供了一种符合CPU机理的格式:“d 段寄存器:偏移地址”,以段寄存器中的数据为段地址SA,列出从SA:偏移地址开始的内存区间中的数据。以下是4个例子: ①-r ds :1000

指令的执行过程

举个实例来说明指令的执行过程: 开机时,程序计算器PC变为0000H。然后单片机在时序电路作用下自动进入执行程序过程。执行过程实际上就是取出指令(取出存储器中事先存放的指令阶段)和执行指令(分析和执行指令)的循环过程。 例如执行指令:MOV A,#0E0H,其机器码为“74H E0H”,该指令的功能是把操作数E0H送入累加器,0000H单元中已存放74H,0001H单元中已存放E0 H。当单片机开始运行时,首先是进入取指阶段,其次序是: 1 程序计数器的内容(这时是0000H)送到地址寄存器; 2 程序计数器的内容自动加1(变为0001H); 3地址寄存器的内容(0000H)通过内部地址总线送到存储器,以存储器中地址译码电跟,使地址为0000H的单元被选中; 4 CPU使读控制线有效; 5 在读命令控制下被选中存储器单元的内容(此时应为74H)送到内部数据总线上,因为是取指阶段,所以该内容通过数据总线被送到指令寄存器。 至此,取指阶段完成,进入译码分析和执行指令阶段。 由于本次进入指令寄存器中的内容是74H(操作码),以译码器译码后单片机就会知道该指令是要将一个数送到A累加器,而该数是在这个代码的下一个存储单元。所以,执行该指令还必须把数据(E0H)从存储器中取出送到CPU,即还要在存储器中取第二个字节。其过程与取指阶段很相似,只是此时PC已为0001H。指令译码器结合时序部件,产生74H操作码的微操作系列,使数字E0H从0001H 单元取出。因为指令是要求把取得的数送到A累加器,所以取出的数字经内部数据总线进入A累加器,而不是进入指令寄存器。至此,一条指令的执行完毕。单片机中PC=0002H,PC在CPU每次向存储器取指或取数时自动加1,单片机又进入下一取指阶段。这一过程一直重复下去,直至收到暂停指令或循环等待指令暂停。CPU就是这样一条一条地执行指令,完成所有规定的功能

1、设一条流水线的执行过程分成取指令、分析指令和执行指令三个阶段

1、设一条流水线的执行过程分成取指令、分析指令和执行指令三个阶段,每个阶段所需的时间分别为t、t和2t,分别求出下列各种情况下,连续执行N条指令所需的时间。 (1)顺序执行方式; (2)只有取指令和执行指令重叠执行; (3)取指令、分析指令和执行指令重叠执行; 2、有一条流水线如下所示 (1)求连续输入10 条指令,该流水线的实际吞吐率和效率; (2)该流水线的瓶颈在哪一段?请采取2种不同的措施消除此“瓶颈”。对于你所给出的新流水线,计算连续输入10 条指令时,其实际吞吐率和效率; 3、在改进的DLX 流水线上运行如下代码序列: LOOP: LW R1, 0(R2) ADDI R1, R1, # 1 SW 0(R2), R1 ADDI R2, R2, # 4 SUB R4, R3, R2 BNEZ R4, LOOP 其中,R3 的初始值是R2+396。假设:在整个代码序列的运行过程中,所有的存储器访问都是命中的,并且在一个时钟周期中对同一个寄存器的读操作和写操作可以通过寄存器“定向”。问: (1)在没有任何其它定向(或旁路)硬件的支持下,请画出该指令序列执行的流水线时空图。假设采用排空流水线的策略处理分支指令,且所有的存储器访问都可以命中Cache,那么执行上述循环需要多少个时钟周期? (2)假设该DLX 流水线有正常的定向路径,请画出该指令序列执行的流水线时空图。假设采用预测分支失败的策略处理分支指令,且所有的存储器访问都可

以命中Cache,那么执行上述循环需要多少个时钟周期? (3)假设该DLX 流水线有正常的定向路径,请对该循环中的指令进行调度。注意可以重新组织指令的顺序,也可以修改指令的操作数,但是不能增加指令的条数。请画出该指令序列执行的流水线时空图,并计算执行上述循环需要的时钟周期数? 4.根据需要展开下面的循环并且进行指令调度,直到没有任何延迟。指令的延迟如表: Code: Loop: LD F0,0(R1) MULTD F0,F0,F2 LD F4,0(R2) ADDD F0,F0,F4 SD 0(R2),F0 SUBI R1,R1,8 SUBI R2,R2,8 BNEQZ R1,LOOP 5.列举下面循环中的所有相关,包括输出相关,反相关,真相关和循环相关。

汇编语言源程序的运行过程

汇编语言源程序的运行过程 一、概述 二、具体操作过程 1.编辑过程 在计算机“附件”的“记事本”中,用word 编辑汇编语言源程序,比用编辑程序EDLIN 要方便得多。因为使用后者,必须熟记它的各种命令及其功能。使用前者的操作步骤如下: 第一步:编辑并建立扩展名为ams 的文件 开始→程序→附件→记事本→键入汇编语言源程序(也可用Ctrl+C 及Ctrl+V 拷贝已有程序)→文件→另存为→出现“另存为”窗口→在‘文件名:’处为该文件命名,并切记:将扩展名由.txt 改为.asm →在“另存为”窗口里的“我的电脑”中找到含有MASM.EXE 、LINK.EXE 以及DEBUG.EXE 这三个工具的文件夹(如,8086experi ),并双击之→该文件夹名便出现在“保存在:”处→保存(至此,该文件夹中将出现你所编辑的扩展名为asm 的汇编语言源程序。此时的源程序以ASCII 码形式存盘,而非机器码)→关闭记事本。 注意:上述三个工具及用户程序必须在同一文件夹中。 此后,为显示,打印或修改该程序,双击该程序的图标即可。 第二步:在DOS 下运行EDLIN ,以便查找并排除源程序中可能存在的语法错误。 window 状态→开始→运行→打开:cmd ↙→确定→出现DOS 提示符:C:\……>→指定存有你的程序的文件夹所在盘(如D 盘)为当前盘 D: ↙→D:\>cd 文件夹名↙→ 在DOS 管理下键入 源程序 编辑程序 无语法错误的汇编语言调试过程

D:\文件夹名>edlin 文件名.asm ↙ End of input file * E ↙ 按结束编辑命令E 之前,生成了一个扩展名为$$$的文件;结束编辑状态之后,该文件的扩展名由$$$变为BAK 。 特别指出:即使不用EDLIN 进行编辑,也必须进行此步。否则,若源程序中存在语法错误,下一步进行汇编后,不予提示,也不生成机器码文件,无法进行再下一步的连接,致使程序无法运行。除非源程序中无任何语法错误。 2.汇编过程 D:\文件夹名>masm 文件名;↙ 汇编程序负责将源程序文件(扩展名为.ASM )翻译为二进制的机器码文件(扩展名为.OBJ )。 在汇编过程中,计算机对源程序文件要进行语法检查,若有错误,在汇编结束后,屏幕上将出现错误信息提示,这时需要返回到编辑过程,对有语法错误的语句进行修改,修改后的源程序需要重新汇编,直到汇编结束时无语法错误为止。注意:汇编过程不能发现程序中的逻辑错误。 汇编结束时,生成扩展名为OBJ 的文件(即CPU 可识别的目标(object )文件,又称机器码文件)。若在编辑阶段中留有任何语法错误未改,则不能生成OBJ 文件,从而无法往下进行。 3.连结过程 D:\文件夹名>Link 文件名;↙ 我们学习汇编的主要目的,就是通过用汇编语言进行编程而深入地理解计算机底层的基本工作机理,达到可以随心所欲地控制计算机的目的。基于这种考虑,我们的编程活动,大都是直接对硬件进行的。我们希望直接对硬件编程,却并不希望用机器码编程。我们用汇编语言编程,就要用到:编辑器(Edit )、编译器(Masm )、连接器(Link )、调试工具(Debug )等工具,而这些工具都是在操作系统控制下运行的程序,所以我们的学习过程必须在操作系统的环境中进行。而操作系统,使用了许多工具,这势必要牵扯到操作系统、编译原理等方面的知识和原理。我们只是利用这些环境、工具来方便我们的学习,而不希望这些东西分散了我们的注意力。所以,对于涉及到而又不在本课程学习内容之中的东西,只做简单的解释。 * L ↙ 显示24条指令 * 25L ↙ 显示从第25条指令开始的另24条指令 此处为选择性操作

计算机组成原理实验五~六

计算机学院学院计算机科学与技术专业班___组、学号 姓名协作者______________ 教师评定_______________ 实验题目实验五微程序控制器部件教学实验 一、实验目的: 1.全面掌握计算机各部件组成及相互联接关系 2.深入理解计算机微程序控制器的功能组成知识 3.深入的学习计算机各类典型的指令的执行流程 4.对指令格式,寻址方式,指令系统,指令分类等建立具体总概念 5.学习微程序控制器的设计过程和相关过程 二、实验设备与器材: TEC-XP+教学实验系统和仿真终端软件PCEC。 三、实验说明和原理: 制器设计是学习计算机总体组成和设计的最重要部分。要在TEC-XP16教学计算机完成这项实验,必须清楚地懂得: 1、TEC-XP+教学机的微程序控制器主要由微程序定序器AM2910、产生当前微地址和下地址的微控存和MACH器件组成。 2、TEC-XP+教学机上已实现了的全部基本指令和留给用户实现的19条扩展指令的控制信号都是由微控存和MACH给出的。 3、应了解监控程序的A命令只支持基本指令,扩展指令应用E命令将指令代码写入到相应的存储单元中;不能用T、P命令单步调试扩展指令,只能用G命令执行有扩展指令的程序。 4、要明白TEC-XP+教学机支持的指令格式及指令执行流程分组情况;理解TEC-XP+教学机中已经设计好并正常运行的各类指令的功能、格式和执行流程、也包括控制器设计的实

现中的具体路线的控制信号的组成。 5、要明确自己要实现的指令功能、格式、执行流程设计中必须遵从的约束条件。 为了完成自己设计几条指令的功能、格式和执行流程,并在教学计算机上实现、调试正确的内容,具体过程包括。 (1)确定指令格式和功能,包括确定要用的操作码,指令中的其它字段的内容分配与使用,要受到教学机已有硬件的约束,应尽量与已实现指令的格式和分类办法保持一致。 (2)按新指令的功能和格式、设计指令的执行流程。划分指令执行步骤并设计每一步的执行功能,设计微地址和下地址的取值,应参照已实现指令的处理办法来完成。 (3)在指令流程表中真写每一个控制信号的状态值,基本上是个查表填数的过程,应特别仔细,并有意识地体会这些信号的控制作用。 (4)将设计好的微码,装入控制存储器的相应单元。 (5)写一个包含你设计的指令的程序,通过运行该程序检查执行结果的正确性,来初步判断你的设计是否正确;如果有问题,通过几种办法查出错误并改正,继续调试,直到完全正确。 四、实验内容: 1)完成控制器部件的教学实验,主要内容是自己设计几条指令的功能、格式和执行流程, 并在教学计算机上实现、调试正确。 2)首先是看懂TEC-XP+教学计算机的功能部件组成和线路逻辑关系,然后分析教学计算 机中已经设计好并正常运行的几条典型指令的功能、格式和执行流程,注意各操作功能所对应的控制信号的作用。 3)设计几条指令的功能、格式和执行流程,并在教学机上实现、调试正确。 4)单条运行指令。查看指令的功能、格式和执行流程。 5)用监控程序的A、E命令编写一段小程序,观察运行结果。 五、实验步骤: 1)接通教学机电源。 2)将教学机左下方的六个拨动开关置为110100. 3)按一下“RESET”按键。 4)通过16位的数据开关SWH、SWL置入指令操作码。

实验二 MASM、LINK指令的使用实验

实验二MASM、LINK指令的使用 一、实验目的 1.熟练掌握文本编辑器的基本用法。 2.熟悉汇编语言的编辑、汇编、连接、运行的全过程。 3.熟悉Debug调试程序的常用命令和用法。 二、实验要求 1.编辑一个扩展文件名为ASM的汇编语言源程序。 2. 用汇编程序MASM汇编上述的汇编语言源程序,形成目标代码文件。(扩展名为OBJ) 3.用连接程序LINK连接目标代码文件,形成可执行文件。(扩展名为EXE) 4.运行可执行文件。观察执行结果,以验证其正确性。 三、实验任务 1. 在文本编辑器(如:记事本程序)中先输入下列汇编语言源程序(注意:文件类型是.ASM文件),使用MASM程序和LINK程序对汇编语言源程序进行汇编和链接,用“debug 可执行文件名”命令,将生成的可执行文件装入内存,然后逐条执行指令,观察执行过程和结果。 练习程序段(实现ZZZ=XXX*16+YYY)如下: DSEG SEGMENT XXX DW 1234H YYY DW 5678H ZZZ DD ? DSEG ENDS CSEG SEGMENT ASSUME CS:CSEG,DS:DSEG START:MOV AX,DSEG MOV DS,AX MOV AX,XXX XOR DX,DX ADD AX,AX ADC DX,DX

ADD AX,AX ADC DX,DX ADD AX,AX ADC DX,DX ADD AX,AX ADC DX,DX ADD AX,YYY ADC DX,0 MOV WORD PTR ZZZ,AX MOV WORD PTR ZZZ+2,DX MOV AH,4CH INT 21H CSEG ENDS END START 四、实验步骤 1.任选熟悉的编辑环境,输入示例程序,存盘取名为EX1.ASM 操作步骤如下: 在Windows环境下可以使用“EDIT”和“记事本”来对汇编语言源程序进行编辑。 ①用EDIT编辑汇编语言源程序 用鼠标单击“开始”菜单,指向“运行”,在对话框中输入“COMMAND”或“CMD”,单击“确定”。将当前目录切换到D盘MASM目录下,在DOS提示符 后输入“EDIT 文件名”,回车,启动编辑程序。即: D:\MASM>EDIT 文件名↙ 在EDIT编辑状态下输入源程序,使用FILE菜单下的SA VE命令保存当前程序。 ②用记事本编辑汇编语言源程序 用鼠标单击“开始”菜单,指向“程序”→“附件”→“记事本”,打开记事本窗口。在记事本窗口中输入源程序,并在D盘的MASM目录下将文件存入磁盘。 注意:在对汇编语言源程序文件进行保存时必须给它取一个名字,且该文件的扩展名必须为“.ASM”,否则MASM不对其进行宏汇编操作。 2.利用MASM进行汇编,过程如下: ③在DOS提示符下面输入命令: D:\MASM>MASM EXAM1; ↙ 屏幕显示:

相关文档
相关文档 最新文档