第2章微处理器.ppt
《第2章微处理器.ppt》由会员分享,可在线阅读,更多相关《第2章微处理器.ppt(56页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、微微 机机 原原 理理 与与 接接 口口 技技 术术第第2章章 微处理器微处理器【任务驱动】本章主要介绍8086微处理器的相关知识,通过本章的学习,让学生掌握8086的内部结构及外部引脚定义,掌握8086存储器的组织形式,理解8086微处理器的工作模式和总线时序。【重点难点】18086CPU内部并行结构及外部引脚28086CPU的存储器组织及地址变换38086CPU的基本时序1微微 机机 原原 理理 与与 接接 口口 技技 术术2.1 微处理器概述微处理器概述2.2 Intel 8086/8088 CPU结构结构2.3 Intel 8086/8088 CPU的引脚的引脚2.4 Intel 80
2、86/8088 的典型时序分析的典型时序分析2微微 机机 原原 理理 与与 接接 口口 技技 术术微处理器(Microprocessor),又称中央处理器(Central Processing Unit,CPU)。是采用大规模或超大规模集成电路(LSI/VLSI)技术做成的半导体芯片,集成了计算机的主要部件:控制器、运算器和寄存器组等,是微机的核心部件。主要完成各种算术及逻辑运算,并控制计算机各部件协调地工作。CPU是微机的核心芯片,是整个系统的运算和指挥控制中心。不同型号的微机,其性能的差别首先在于其CPU性能的不同,而CPU的性能又与它的内部结构有关,每种CPU都有其特有的指令系统。但无论
3、哪种CPU,其内部基本结构总是相近的,都有控制器、运算器和寄存器组3大主要部件。2.1 微处理器概述微处理器概述3微微 机机 原原 理理 与与 接接 口口 技技 术术1运算器:又称为算术逻辑单元(Arithmetic and Logic Unit,ALU),它是以加法器为基础,辅之以移位寄存器及相应控制逻辑组合而成的电路,在控制信号的作用下,可完成加、减、乘、除四则运算和各种逻辑运算,以及浮点运算。2控制器:一般由指令寄存器、指令译码器、时序和控制逻辑电路组成。控制器是整个CPU的指挥控制中心,对协调整个微机有序工作极为重要。它从存储器中依次取出程序的各条指令,并根据指令的要求,向微机的各个部
4、件发出相应的控制信号,使各部件协调工作,从而实现对整个微机系统的控制。4微微 机机 原原 理理 与与 接接 口口 技技 术术3寄存器组:实质上是CPU内部的若干个的高速存储单元,在汇编语言中通常是按名字来访问它们。寄存器可分为专用寄存器和通用寄存器。专用寄存器的作用是固定的,如堆栈指针、程序计数器、标志寄存器、地址寄存器等。而通用寄存器则可由程序员规定其用途。通用寄存器的数目因CPU的不同而异,8088/8086 CPU中有8个16位的通用寄存器,缩短了指令的长度和指令的执行时间。微处理器中还有一些不能直接为程序员所用的寄存器,如累加锁存器、暂存器和指令寄存器等,它们仅受内部定时和控制逻辑的控
5、制。我们通常说的Z80、8086、80286、80386、80486指的是Z80处理器、8086微处理器、80286微处理器、80386微处理器和80486微处理器。在这一章中,我们将学习8086处理器及其系列芯片的内部结构、操作与时序等。5微微 机机 原原 理理 与与 接接 口口 技技 术术8086/8088 是Intel系列的16位微处理器,它是采用HMOS工艺制造的,内部包含约29000个晶体管,用单一的+5V电源,时钟频率为 5MHz10MHz。8086有16根数据线和20根地址线,其寻址空间达1M字节;8088是一种准16位微处理器,它的内部寄存器、内部运算部件以及内部操作都是按16
6、位设计的,但对外的数据总线只有8条。8086/8088 芯片内设有硬件乘除指令部件和串处理指令部件,可对位、字节、字串、BCD码等多种数据类型进行处理。8086/8088的指令系统完全相同,在软件上完全兼容。2.2 Intel 8086/8088 CPU结构结构6微微 机机 原原 理理 与与 接接 口口 技技 术术8086 CPU采用了一种较先进的指令流水线结构,取指令(或取操作数)与执行指令的功能分别由两个独立部件实现,即总线接口单元BIU(Bus Interface Unit)和执行单元EU(Execution Unit)。因此,当EU执行某条指令时,BIU同时完成从主存中预取后续指令,两
7、个部件并行地工作,使指令的读取与执行可以部分重叠,从而指令的执行速度。为此,将8086 CPU结构从功能上划分为两个逻辑单元,即总线接口单元BIU和执行单元EU,其内部组成结构如图2.1所示。7微微 机机 原原 理理 与与 接接 口口 技技 术术2.2.1 总线接口单元总线接口单元BIU和执行单元和执行单元EU 图图2.1 8086CPU内部结构图内部结构图8微微 机机 原原 理理 与与 接接 口口 技技 术术(一)总线接口单元(一)总线接口单元BIUBIU是8086 CPU与存储器或I/O设备之间的接口部件,负责全部引脚的操作。具体来说,BIU负责:(1)取指令。产生指令地址,根据指令地址从
8、存储器取出指令,送到指令队列中排队或直接送给EU去执行;(2)取操作数。从存储器的指定单元或外设端口中取出指令规定的操作数传送给EU;(3)传送结果。把EU的操作结果传送到指定的存储单元或外设端口中。BIU内部设有:1 4个16位的段寄存器:代码段寄存器CS(Code Segment)数据段寄存器DS(Data Segment)堆栈段寄存器SS(Stake Segment)附加段寄存器ES(Extra Segment)9微微 机机 原原 理理 与与 接接 口口 技技 术术2一个16位的指令指针寄存器IP(Instruction Pointer)。36字节指令队列缓冲器。8086的指令队列缓冲器
9、为六个字节,8088的指令队列缓冲器为四个字节。无论8086还是8088,都会在执行指令的同时,从内存中取下一条指令或几条指令,取来的指令就放在指令队列缓冲器中。这样,一般情况下,CPU执行完一条指令就可以立即执行下一条指令,称为流水线技术,减少了CPU为取指令而等待的时间,从而提高了CPU的效率。420位地址加法器和总线控制电路。地址加法器用来产生20位地址。上面已提到8086可用20位地址寻址1MB的内存空间,但8086内部所有的寄存器都是16位的,所以需要一个附加的机构来根据16位寄存器提供的信息计算出20位的物理地址,这个机构就是20位的地址加法器。10微微 机机 原原 理理 与与 接
10、接 口口 技技 术术(二)执行单元(二)执行单元EU执行单元(EU)的作用是:(1)从指令队列中取出指令;(2)对指令进行译码,发出相应的传送数据或算术运算的控制信号;(3)接收由总线接口部件传送来的数据,或把数据传送到总线接口部件;(4)进行算术运算。执行部件由下列部分组成:14个通用寄存器AX,BX,CX,DX四个通用寄存器既可作为16位寄存器用,也可以作为8位寄存器使用,分别为AH,AL,BH,BL,CH,CL,DH,DL。AX寄存器又称为累加器,8086指令系统中有许多指令都通过累加器的动作来执行。AX为16位累加器,AL为8位累加器。11微微 机机 原原 理理 与与 接接 口口 技技
11、 术术2专用寄存器4个专用寄存器,基址指针寄存器BP,堆栈指针寄存器SP,源变址寄存器SI,目的变址寄存器DI。4个专用寄存器的用法将在指令系统有专门的论述。3算术逻辑单元ALU它是16位的运算器,可用于8位或16位二进制算术和逻辑运算,也可按指令的寻址方式计算寻址存储器单元所需的16位偏移量。4数据暂存寄存器它协助ALU完成运算,暂存参加运算的数据。5EU控制电路从总线接口单元的指令队列取出指令操作码,通过译码电路分析,发出相应的控制命令,控制ALU数据的流向。如果是运算操作,操作数经过暂存寄存器送入ALU,运算结果经过ALU数据总线送到相应的寄存器,同时标志寄存器F根据运算结果改变状态。1
12、2微微 机机 原原 理理 与与 接接 口口 技技 术术6标志寄存器标志寄存器共有16位,其中7位未用,所用的各位含义如图2.2所示。6个状态标志,反映CPU指令运行后的运行状态信息,分别为SF、ZF、PF、CF、AF和OF。这些标志位根据指令执行后的操作结果进行变化,然后判断转移等。3个控制标志,分别为DF、IF和TF。控制标志与状态标志的区别是,控制标志可由编程员通过指令进行设置,有专门的指令对控制标志置0或置1;状态信息是由中央处理器执行运算指令,并根据运算结果而自动设置。6个状态标志位的职能是:CF进位标志位。做加法时出现进位或做减法时出现借位,该标志位置1;否则清0。PF奇偶标志位。当
13、结果的低8位中1的个数为偶数时,则该标志位置1;否则清0。AF半加标志位。在做加法时,当位3需向位4进位,或在做减法时位3需向位4借位,该标志位就置1;否则清0。该标志位通常用于对BCD算术逻辑结果的调整。13微微 机机 原原 理理 与与 接接 口口 技技 术术ZF零标志位。运算结果各位都为0时,该标志位置1;否则清0。SF符号标志位。当运算结果的最高位为1时,该标志位置1;否则清0。OF溢出标志位。在算术运算中,当带符号的数的运算结果超出了8位或16位带符号数所能表达的范围时,即字节运算大于+127或小于-128时,字运算大于+32 767或小于-32 768时,该标志位置位。14微微 机机
14、 原原 理理 与与 接接 口口 技技 术术图图2.2标志寄存器各位的含义标志寄存器各位的含义15微微 机机 原原 理理 与与 接接 口口 技技 术术3个控制标志位的控制职能如下:(1)DF(Direction Flag):方向控制标志位决定变址寄存器SI、DI的变化方向,即是增量变化还是减量变化。一般用于串处理指令,控制从前往后、还是从后往前对字符串进行操作处理。(2)IF(Interupt Flag):中断允许/禁止标志位IF=1,允许外部可屏蔽中断。CPU可以响应可屏蔽中断请求。IF=0,关闭中断。CPU禁止响应可屏蔽中断请求。(3)TF(Trap Flag):跟踪(陷阱)标志位TF=1,
15、每执行一条指令后,自动产生一次内部中断,使CPU处于单步执行指令工作方式,便于进行程序调试,用户能检查程序。TF=0,CPU正常工作,不产生中断。16微微 机机 原原 理理 与与 接接 口口 技技 术术2.2.2 8086/8088 的存储器组织的存储器组织(一)(一)存储器的标准结构存储器的标准结构8086 CPU有20根地址线,可寻址1MB存储空间。存储器按字节编址,从00000HFFFFFH,每个字节用惟一的地址表示。存放的数是字节形式,存储器单元按顺序排列存放。如图2.3所示,存放的数为一个字时,将字的高位字节放在高地址中,将低位字节放在低地址中,高低地址连续。对于存放的字,其低位字节
16、可以在奇数地址中(即从奇地址开始)存放,这种方式称为非规则存放,这样存放的字称为非规则字,CPU需要两次访问存储器才能存取该字。也可以在偶数地址中(即从偶地址开始)存放,这是规则存放,这样存放的字称为规则字,CPU一次便可对该字所在的两个存储单元进行存取。为加快程序的运行速度,编程时应注意用规则字。8088系统外部数据总线只有8位,CPU每次访问存储器只读写一个字节,如果要读写一个字,CPU需要访问两次存储器 17微微 机机 原原 理理 与与 接接 口口 技技 术术左图中,地址为00102H单元中存放的字数据是285BH,地址为00106H单元中存放的字数据是0AF6DH。图图2.3内存中数据
17、存储格式内存中数据存储格式18微微 机机 原原 理理 与与 接接 口口 技技 术术(二)存储器的分段(二)存储器的分段前面我们已经提到8086/8088可以具有1 MB的内存空间,可是其内部结构以及内部数据的直接处理能力和寄存器都只有16位,故只能直接提供16位地址,寻址64KB存储空间,很显然,不采取特殊措施,是不能寻址1 MB存储空间的。为此,我们引入了分段的概念,如图2.4所示,将1MB字节的存储器空间分成若干逻辑段,每个段最长为64KB,段内地址是连续的。逻辑段之间可以是连续的,也可以是分开的或重叠的。段的首地址必须能被16整除,即每段首地址的低4位必须为0,高16位就是段基础地址(简
18、称段基址)。段内任一存储单元与它所在段的段基值之间的距离称为偏移量或偏移地址。段基值存放在段寄存器CS、SS、DS、ES中,程序可以从4个段寄存器给出的逻辑段中存取代码和数据。19微微 机机 原原 理理 与与 接接 口口 技技 术术20微微 机机 原原 理理 与与 接接 口口 技技 术术(三三)物理地址和逻辑地址物理地址和逻辑地址物理地址(Physical Address)又叫实际地址,是CPU和存储器进行数据交换时使用的地址,在8086/8088系统的存储器中每个单元有惟一的一个20位的物理地址,CPU访问存储器必须按这个物理地址去进行。但总线接口单元得到的往往是其段基址和偏移地址,那么已知
19、一个存储单元的段基值和它的偏移量,如何计算其物理地址呢?物理地址(20位)=段基值10H+偏移地址段寄存器的内容16(10H,相当于左移4位)变为20位,再在低端16位上加上16位的偏移地址(也叫做有效地址),便可得到20位的物理地址,其产生过程如图2.5所示。16位的偏移地址有多种产生方法,在下一篇中再详细说明。21微微 机机 原原 理理 与与 接接 口口 技技 术术图图2.5.2.5.物理地址的形成过程物理地址的形成过程22微微 机机 原原 理理 与与 接接 口口 技技 术术逻辑地址由两部分组成:段基值和偏移量。它们都是用无符号的16位二进制数或4位十六进制数表示。逻辑地址的一般表示形式为
20、:段基值:偏移量这里仅以8086 CPU复位后如何形成启动地址为例,说明物理地址的计算方法。一条指令的物理地址是根据代码段寄存器CS和指令指针寄存器IP的内容得到的,复位时CS的内容为FFFFH,IP的内容为0000H。复位后的启动地址由CS段寄存器和IP的内容(作为偏移量)共同决定,即启动地址=CS16+IP=FFFF0H+0000H=FFFF0H23微微 机机 原原 理理 与与 接接 口口 技技 术术段寄存器的设立不仅使8086的存储空间扩大到1 MB,而且为信息按特征分段存储带来了方便。在存储器中,信息按特征可分为程序代码、数据、微处理器状态等。为了操作方便,存储器可以相应地划分为:程序
21、区,用来存放程序的指令代码;数据区,用来存放原始数据、中间结果和最后运算结果;堆栈区,用来存放压入堆栈的数据和状态信息。只要修改段寄存器的内容,就可将相应的存放区设置在存储器的任何位置上。这些区域可以通过段寄存器的设置使之相互独立,也可将它们部分或完全重叠。需要注意的是,改变这些区域的地址时,是以16个字节为单位进行的。表2.1表示了各段寄存器的使用情况。24微微 机机 原原 理理 与与 接接 口口 技技 术术表表2.1 8086/8088中段寄存器使用的基本约定中段寄存器使用的基本约定25微微 机机 原原 理理 与与 接接 口口 技技 术术(四)堆栈(四)堆栈所谓堆栈(Stack)是为保护数
22、据、调度数据而开辟的特殊数据区域。堆栈的一端是固定的(栈底),另一端是浮动的(栈顶),正常的堆栈操作,其信息的存取在浮动的一端进行。堆栈中的数据严格按照“先进后出(First In Last Out或FILO)”的原则进行存取操作,即数据是由栈顶压入和弹出的。由堆栈段寄存器SS提供段基值,堆栈指针寄存器SP提供偏移地址,每当压入或弹出数据时,SP的内容会自动修改,它始终指向堆栈的顶部。计算物理地址的公式是:物理地址(PA)=(SS)10H+(SP)当需要对堆栈段中的某个单元的数据进行操作时,还可使用BP寄存器通过各种寻址方式得到有效地址EA作为偏移地址,这样其物理地址是:物理地址(PA)=(S
23、S)10H+EA26微微 机机 原原 理理 与与 接接 口口 技技 术术(五)(五)8086系统存储区的分配系统存储区的分配1 00000H003FFH共1KB区域用来存放中断矢量,这一区域称为中断矢量表。中断矢量表的定义和作用参阅中断一章的有关内容。2 B0000HB0F9FH是单色显示器的显示缓冲区,存放单色显示器当前屏幕显示字符所对应的ASCII码和属性。3B8000HBBF3FH约16KB是彩色显示器的显示缓冲区,存放彩色显示器当前屏幕像点所对应的代码。4FFFF0HFFFFFH共16个单元,一般用来存放一条无条件转移指令,转到系统的初始化程序。这是因为系统加电或者复位时,会自动转到F
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 微处理器
限制150内