微机原理第1章微型计算机系统基本组成原理.ppt
1-1,课程介绍,课程在计算机课程体系中的位置课程教学目的课程要求课程学习方法课程内容组织课程考核要求,1-2,课程在计算机课程体系中的位置,硬件类,软件类,CPU及整机设计(计算机组成原理),BIOS与接口驱动程序设计,模拟电路、数字逻辑电路设计,嵌入式/单片机系统,SOC芯片设计,计算机系统结构,外围接口电路设计,操作系统,编译系统,数据库,数据结构,C+,JAVA,离散数学,计算机系统综合设计,电子商务,多媒体技术,算法设计、数值分析、信号与系统、计算机理论课程、数学基础课程,汇编语言,软件工程,VB,1-3,课程教学目的,掌握先进微处理器芯片结构、微型计算机实现技术、计算机主板构成、各种接口技术原理及其应用编程方法;掌握汇编语言程序的编写方法,尤其掌握接口访问的方法。了解微机技术新的发展趋势,系统科学地获得分析问题和解决问题的训练;提高分析和设计接口的能力。,1-4,课程要求,不仅要学习微机各种接口电路的原理与作用,熟悉PC系列机接口电路,而且还要掌握常用接口的设计与分析方法,学会使用汇编语言(C语言)对接口进行编程,并具有一定的动手实验能力和接口应用程序的编写能力,为微机的深入应用和嵌入式系统SOC设计等的学习与实践打下良好基础。下载电子讲义,课堂上注意听讲并及时记录教师课堂上补充的内容,认真独立完成作业,做好课程实验、做好课前预习和课后复习。,1-5,课程学习方法,特点:本课程涉及的知识范围广,内容多,1.抓住x86系列微机基本结构这条主线,分析其基本结构,掌握各接口电路及可编程接口芯片的应用。2.进一步扩展和延伸CPU从PentiumCore 2 Duo,实模式保护模式;汇编语言CPU及接口直接控制,16位32位汇编;总线PCI,USB,PCI-Express等;中断从实模式下的中断向量保护模式下的中断描述符;从传统中断PCI中断串行中断 芯片组从中大规模集成电路(8237、8254、8255、8259等)超大规模集成电路(MCH、ICH)。存储管理从实地址模式到保护模式存储管理,1-6,课程学习方法,3.理论与实践相结合,锻炼实验动手能力。掌握汇编语言编程方法掌握x86系列寻址方式掌握x86常用指令学会x86汇编程序编写方法掌握PC机接口程序的编写方法充分利用课程实验锻炼自己的编程能力和接口设计与分析能力。,1-7,4.从系统的角度弄清楚“软件发出I/O写指令CPU及译码电路产生数据/控制信号接口电路产生对外设的数据信号和控制信号”的过程,以及“外设的数据和运行状态接口电路 CPU I/O读指令将数据或状态送到软件”的过程;5.学会分析与设计接口电路的基本方法分析接口两侧的情况合理选择接口芯片正确分析相关芯片的时序搭配进行正确的信号转换6.网络学习辅助:http:/物理与电子工程系-微机原理与接口技术(2011级)登录密钥:201112,课程学习方法,1-8,课程内容组织,第1章微型计算机系统基本组成原理第2章微处理器和指令系统第3章汇编语言及编程第4章总线和总线技术第5章存储器第6章I/O接口第7章典型可编程接口芯片及应用第8章常用交互设备及接口第9章模拟I/O 器件及接口第10章多媒体设备及接口,1-9,第一章重点,微机系统的三个层次和主要性能指标;三总线结构和各大组成部分的功能;MPU的主要硬件组成及各部分功能;指令和指令执行过程;计算机工作过程的实质;现代主流微机系统的主板结构。,1-10,第二章重点,Intel系列微处理器的演变历史;Pentium的内部基本寄存器功能及应用;操作数寻址方式;通用整数指令。,1-11,第三章重点,汇编语言程序结构;基本结构程序和子程序设计方法;,1-12,第五章重点,各类存储器芯片的接口特性和选用原则;由存储芯片构成存储系统时,位数、字数的扩展和片选控制方法。,1-13,第六章重点,接口的基本功能和基本结构;两种I/O编址方式的特点和优缺点;几种I/O同步控制方式的特点和优缺点。,1-14,第七章重点,中断的响应条件和中断处理过程;两种多中断源服务判决方法的原理、特点及其带来的优缺点;8259内部寄存器的读/写控制方法,命令字格式和编程;用户中断入口地址的设置;计数器用作计数和定时的原理;8254的工作方式及初始化编程;并行接口和串行接口的异同;8255的三种工作方式及编程使用。,1-15,课程考核要求,考试成绩(课堂教学内容)50实验成绩(实验出勤、实验报告完成及操作情况)30平时成绩(作业等学习情况)20,总成绩考试成绩实验成绩平时成绩,1-16,重点:1.微机系统的三个层次和主要性能指标;2.三总线结构和各大组成部分的功能;3.MPU的主要硬件组成及各部分功能;4.指令和指令执行过程;5.计算机工作过程的实质;6.现代主流微机系统的主板结构。,第一章 微型计算机系统基本组成原理,1-17,1.1 微型计算机系统组成结构1.2 微型计算机的运算基础1.3 微型计算机基本工作原理1.4 目前主流微机系统的硬件配置与主板结构1.5 微机系统的主要性能指标,第一章 微型计算机系统基本组成原理,1-18,1.1.1 总的系统结构1.1.2 各大组成部分概述,1.1 微型计算机系统组成结构,1-19,硬件上由运算器、控制器、存储器、输入设备和输出设备五大部分组成;数据和程序以二进制代码的形式不加区别地存放在存储器中,存放位置由地址指定,地址码也为二进制形式;控制器按指令流驱动的原理工作。,目前各种微机系统采用的基本上是计算机的经典结构冯诺依曼结构。结构特点是:,1.1.1 总的系统结构,1-20,1.三总线结构,1.1.1 总的系统结构,微型计算机系统,1-21,模块间的双向依赖关系变为各模块面向总线的单向依赖关系,简化了微机的结构。使微机系统易于扩充和维护。,微型计算机三总线结构示意图:,1.1.1 总的系统结构,1-22,单总线结构 双总线结构 多层总线结构,2.总线结构分类,根据总线组织方法的不同,总线结构可分为以下三类:,1.1.1 总的系统结构,1-23,单总线结构示意图:,特点:MPU对M和I/O的读写只能分时进行。优点:逻辑结构简单,成本低,实现容易。,单总线 结 构 双总线 结 构 多层总 线结构,1.1.1 总的系统结构,1-24,特点:MPU可分别在两套总线上同时与M和I/O口交换信息。优点:展宽了总线带宽,提高了数据传输速率。,单总线 结 构 双总线 结 构 多层总 线结构,双总线结构示意图:,1.1.1 总的系统结构,1-25,单总线 结 构 双总线 结 构 多层总 线结构(以双层 为例),多层总线结构示意图(以双层为例):,真正实现了多层总线上的并行工作。这对等效总线带宽的增加,系统数据处理和数据传输效率的提高,效果更明显。,1.1.1 总的系统结构,1-26,微处理器(MPU)存储器I/O设备及接口,微机系统由硬件和软件两大部分组成的,在硬件上主要由以下几部分组成:,1.1.2 各大组成部分概述,1-27,-微型计算机的运算和指挥控制中心,不同型号微机性能的差别首先在于其微处理器性能的不同,而微处理器的性能又与它的内部结构、硬件配置有关。每种微处理器有其特有的指令系统,但无论哪种微处理器,其内部基本结构总是相同的,都有控制器、运算器和内部总线及缓冲器三大部分,每部分又各由一些基本部件组成。,1.微处理器,1.1.2 各大组成部分概述,1-28,微处理器典型结构示意图,1.1.2 各大组成部分概述,1-29,2.存储器(内存或主存),内存由一个个内存单元组成,每个单元中一般存放一个字节(8位)的二进制信息。内存单元的总数目叫内存容量。内存中存放的数据和程序形式上都是二进制数。微机通过给每个内存单元规定不同的地址来管理内存。,微机的存储记忆部件,用以存放数据和程序。,内存单元的地址和内容,1.1.2 各大组成部分概述,1-30,CPU对内存的操作有读、写两种。,内存操作,将内存单元的内容取入CPU内部,不改变被读单元的内容。,CPU将其内部信息传送到内存单元保存下来,从而改变被写单元的内容。,1.1.2 各大组成部分概述,1-31,随机存取存储器(RAM)只读存储器(ROM),内存分类,按工作方式的不同,内存分为两大类:,特点,可被CPU随机的读和写,断电后所有信息会消失。,特点,只能被CPU随机读取,不能任意写入。断电后信息不会丢失。,1.1.2 各大组成部分概述,1-32,3.I/O设备及接口,微机通过I/O设备与外部交换信息,但两者处理的信息从数据格式到逻辑时序一般不能直接兼容,必须在两者之间引入连接电路,即I/O接口电路。,1.1.2 各大组成部分概述,1-33,1.2.1 计算机中数的表示方法1.2.2 计算机中有符号数的运算1.2.3 计算机中无符号数的运算1.2.4 计算机中的乘除法运算,1.2 微机的运算基础,1-34,1.机器数和真值,2.有符号数的机器数表示方法,3.数的定点和浮点表示,4.无符号数的机器数表示方法,1.2.1 计算机中数的表示方法,1-35,在计算机中使用的、连同符号位一起数字化了的 数,称为机器数。通常用一个数的最高位作为符 号位:0表示正数,1表示负数。,10110101,00101010,-53,+42,机器数所表示的真实值则叫真值。,1.机器数和真值,1.2.1 计算机中数的表示方法,1-36,常用的表示方法有三种:,(1)原 码,(2)反 码,(3)补 码,2.有符号数的机器数表示方法,1.2.1 计算机中数的表示方法,1-37,原码的最高位表示符号,数值位用二进制绝对值表示。,设机器数位长为n,则数X的原码定义为:,n位原码表示数值的范围:,-(2n-1-1)+(2n-1-1),+0原=0000,-0原=1000,数0的原码有两种不同的形式:,(1)原码(2)反码(3)补码,原码的定义:,原码表示简单、直观,与真值间转换方便,但用它作加减运算不方便,且0有两种表示方法。,1.2.1 计算机中数的表示方法,1-38,正数的反码表示与原码相同;负数的反码是将其原码除符位外各位取反得到。即:,n位反码表示数值的范围:,-(2n-1-1)+(2n-1-1),数0的反码也有两种形式:,+0反=0000(全0),-0反=1111(全1),反码还原为真值的方法:,反码原码真值,而X原=X反反,(1)原码(2)反码(3)补码,反码的定义,1.2.1 计算机中数的表示方法,1-39,-正数的补码表示与原码相同;负数的补码是将其原码除符号位外各位取反加1而得到。即:,n位补码表示数值的范围:,-2n-1+(2n-1-1),数0的补码只有一个:,+0补=-0补=0000(全0),补码还原为真值的方法:,补码原码真值,而X原=X补补,(1)原码(2)反码(3)补码,补码的定义:,1.2.1 计算机中数的表示方法,1-40,(1)原码(2)反码(3)补码,结论:,原码、反码、补码的最高位都是表示符号位。符号位为0时,表示真值为正数,其余位都为真值。符号位为1时,表示真值为负数,其余位除原码外不再是真值。对于正数,三种编码都一样;对于负数,三种编码互不相同。所以原码、反码、补码本质上是用来解决负数在机器中表示的三种不同的编码方法。二进制位数相同的原码、反码、补码所能表示的数值范围不完全相同。,1.2.1 计算机中数的表示方法,1-41,计算机中不用某个二进制位来表示小数点,而是隐含规定小数点的位置。,根据小数点的位置是否固定,数的表示方法可分为定点表示和浮点表示,相应的机器数就叫定点数或浮点数。,对于任一个二进制数X,通常可表示成:,X=2J S,其中,S为数X的尾数,J为数X的阶码,2为阶码的底。,尾数S表示数X的全部有效数字,阶码J则指出了小数点的位置。S值和J值均可正可负。当J固定时,表示是定点数;当J值可变时,表示是浮点数。,3.数的定点和浮点表示,1.2.1 计算机中数的表示方法,1-42,根据小数点固定的位置不同。定点数有定点(纯)整数和定点(纯)小数两种。,定点整数和定点小数在计算机中表示形式没什么区别,其小数点完全靠事先的约定而隐含在不同位置。,(1)定点数,1.2.1 计算机中数的表示方法,1-43,其中:阶码一般用补码定点整数表示,尾数一般用补码或原码定点小数表示。,为保证不损失有效数字,一般对尾数进行规格化处理,即保证尾数的最高位是1,实际大小通过阶码来进行调整。,(2)浮点数,浮点数一般由4个字段组成,一般格式如下:,1.2.1 计算机中数的表示方法,1-44,已知某数X的机器码为:“00001001101111110101000000000000”求其真值。,解:X=(1.01111110101000000000000)补2(00001001)补=(1.10000001011000000000000)原29=-0.1000000101129=(-100000010.11)2=(-258.75)10,例1.2 某计算机用32位表示一个浮点数,格式如下:,1.2.1 计算机中数的表示方法,1-45,1)位数不等的二进制码,2)BCD码,3)ASCII码:,与非压缩BCD码相似,低4位完全相同,高4位为0011,ASCII码一般在计算机的输入、输出设备中使用,而二进制码和BCD码则在运算处理过程中使用。,三种表示方法,每位BCD码用4位二进制表示,一个字节表示2位BCD码。,每位BCD码用一个字节表示,高4位总是0000,低4位表示09。,4.无符号数的机器数表示方法,1.2.1 计算机中数的表示方法,1-46,1.补码的加减法运算规则 2.溢出与溢出判断,1.2.2 计算机中有符号数的运算,1-47,加减法运算:XY补=X补+Y补,求补运算:-Y补=0-Y补=Y补连同符号位取反加1,1.补码的运算规则,1.2.2 计算机中有符号数的运算,1-48,例1.3 X=33,Y=45,求X+Y、X-Y。,解:X补=00100001 Y补=00101101,-Y补=11010011 X+Y补=X补+Y补=01001110 X-Y补=X补+-Y补=11110100,所以,X+Y=X+Y补补=01001110=(+78)10 X-Y=X-Y补补=10001100=(-12)10,1.2.2 计算机中有符号数的运算,1-49,负数的补码与对应正数的补码之间的转换可用同一方法-求补运算实现,因而可简化硬件;可将减法变为加法运算,从而省去减法器;有符号数和无符号数的加法运算可用同一加法器电路完成,结果都正确。,用补码表示计算机中有符号数的优点:,1.2.2 计算机中有符号数的运算,1-50,2.溢出与溢出判断,当结果超出补码表示的数值范围时,补码运算将会出错。这种现象称为“溢出”。计算机运算时要避免产生溢出,万一出现了溢出,要能判断,并做出相应处理。,溢出的概念,1.2.2 计算机中有符号数的运算,1-51,微机中多采用“双进位位”法进行溢出判断。,溢出的判别,1.2.2 计算机中有符号数的运算,1-52,因为C2=1,C1=0,OF=C1C2=1,所以有溢出,结果不对。,因为C2=0,C1=0,OF=C1C2=0,所以无溢出,结果正确。,例1.4 求:55+66,55补=00110111+66补=01000010,01111001=121补,例1.5 求:(-93)+(-59),-93补=10100011+-59补=11000101,0,1,根据C1、C2值亦可判断有溢出时是正溢出还是负溢出:C2C1=00=11时,无溢出;C2C1=01时,为正溢出;C2C1=10时,为负溢出。,1.2.2 计算机中有符号数的运算,1-53,1.2.3 计算机中无符号数的运算,1.2.2 计算机中有符号数的运算,微机中无论有符号数还是无符号数的加减法运算,都是在加法器电路中完成的。无符号数运算时,只有数据用二进制表示时,运算结果才是正确的;若数据用BCD码表示,则需要对运算结果进行调整,使之符合十进制运算的进位/借位规则;若数据用ASCII码表示,则必须把它们变换成二进制码或BCD码后才便于运算。,1-54,1)十进制加法调整规则 若两个一位BCD数相加结果大于9(1001),则应作6(0110)修正;若两个BCD数相加结果在本位并不大于9,但产生了进位,这相当于十进制数运算大于等于16,所以也应在本位作 加6修正。,十进制调整的规则如下:,2)十进制减法调整规则 两个BCD数相减,若出现本位差超过9,或虽不超过9但向高位有借位,则说明必然是借了16,多借了6,应在本位作减6修正。,实际中,现代计算机中均有专门的十进制调整指令,利用它们,机器可按规则自动进行调整。,1.2.3 计算机中无符号数的运算,1-55,1.2.4 计算机中的乘除法运算,1.基于加减法电路和移位寄存器实现 这种方法,运算器中不设乘除法运算电路,只设加减法电路。需要进行乘除法运算时,主要利用加减法运算指令和移位指令,按照某种算法通过编程来实现。,2基于乘除法电路实现 这种方法,运算器中除设置有加减法电路外,还设有乘除法电路。需要进行乘除法运算时,直接用乘除法指令编程实现。,1-56,1.3.1 计算机工作过程的实质1.3.2 指令与程序的概念1.3.3 指令与程序的执行过程,1.3 微型计算机基本工作原理,1-57,1.3.1 计算机工作过程的实质,计算机工作的过程实质上就是以计算机硬件为基础执行程序的过程。而程序是由若干条指令组成的,微机逐条执行程序中的每条指令,即可完成一个程序的执行,从而完成一项特定的工作。,因此了解微机工作原理的关键,就是要了解指令和指令执行的基本过程。,1-58,1.指令-规定计算机执行特定操作的命令。,2.指令系统-计算机全部指令的集合。,指令系统准确定义了计算机的处理能力。不同型号的计算机有不同的指令系统,从而形成各自的特点和相互差异。,1.3.2 指令与程序的概念,1-59,3.指令结构,1.3.2 指令与程序的概念,任何一条指令均由两部分组成:,指明要完成操作的性质,如:加、减、乘、除等。,指明参加规定操作的数据存放地址或数据。,1-60,4.程序,机器语言程序汇编语言程序高级语言程序,目前微机系统中使用着三个层次、三种形式的程序:,-为解决某一问题而编写在一起的指令序列。,1.3.2 指令与程序的概念,1-61,计算机中的指令以二进制代码形式存在,叫机器码指令。机器码指令构成的指令系统叫机器语言,用机器语言编写的程序叫机器语言程序。机器语言程序优点是能被计算机直接理解和执行;缺点是编程繁琐、不直观、难记忆、易出错。,机器语言 程 序汇编语言 程 序高级语言 程 序,1.3.2 指令与程序的概念,1-62,为克服机器语言程序的缺点,常用助记符来代替机器语言指令。助记符与机器语言指令之间有一一对应关系。这种用助记符构成的指令系统叫汇编语言。用汇编语言编写的程序叫汇编语言程序。汇编语言程序的优点是直观、易懂、便于记忆。但又存在着计算机无法识别的缺点。,机器语言 程 序汇编语言 程 序高级语言 程 序,1.3.2 指令与程序的概念,1-63,机器语言和汇编语言是依赖于机器的编程语言,统称为低级语言。与此相对应,高级语言则是一种比较接近于习惯的自然语言和数学语言的程序设计语言。它以语句和数据的定义为基础,且通常一个语句都是由一组机器语言指令或汇编语言指令构成的。用高级语言编写的程序即为高级语言程序。高级语言程序比汇编语言程序更直观易懂,更易于面向问题和对象。,机器语言 程 序汇编语言 程 序高级语言 程 序,1.3.2 指令与程序的概念,1-64,高级语言程序和汇编语言程序必须先翻译成机器语言程序才能执行。这个翻译过程,对汇编语言程序叫汇编(Assemble);对高级语言程序有的叫解释(Interpretation),有的叫编译(Compila-tion)。,通常又将翻译前的程序叫源程序,而将翻译后的机器语言程序叫目标程序。完成汇编、解释、编译的程序则分别叫作汇编程序(Assembler)、解释程序(Interpreter)、编译程序(Compiler),它们作为工具软件事先存放在计算机中。,机器语言 程 序汇编语言 程 序高级语言 程 序,1.3.2 指令与程序的概念,1-65,微型计算机每执行一条指令都分成三个阶段进行(即三步曲):,取指令 分析指令 执行指令,1.3.3 指令与程序的执行过程,1.指令的执行,根据程序计数器PC中的值从存储器读出现行指令,送到指令寄存器IR,然后PC自动加1,指向下一条指令地址或本条指令下一字节。,将IR中的指令操作码译码,分析其指令性质,如指令要求操作数,则寻找操作数地址。,取出操作数,执行指令规定的操作。根据指令不同还可能写入操作结果。,1-66,微机程序的执行过程,实际上就是周而复始地完成这三阶段操作的过程,直到遇到停机指令才结束运行。,1.3.3 指令与程序的执行过程,2.程序的执行,1-67,程序执行过程中的每条指令操作三步曲并非在各种微处理器中都是串行完成的,除早期的8位微处理器外,后来的各种16位机、32位机都可将这三步操作分配给两个或两个以上的独立部件并行完成。80386和80486采用了6级流水线结构,不同指令的取址、分析、执行三个阶段可并行处理。程序的指令和数据都存放在内存中,故在执行程序时,CPU和内存通过存储器地址寄存器MAR和存储器数据寄存器MDR以及若干读/写控制信号实现联系。,3.关于程序执行过程的两点说明:,1.3.3 指令与程序的执行过程,1-68,程序如下:ORG 1000H 对应机器码 1:MOV A,5CH;B0H 5CH 2:ADD A,2EH;04H 2EH 3:JO 100AH;70H 0AH 10H 4:MOV(0200H),A;A2H 00H 02H 5:HLT F4H,程序功能:5CH+2EH,如结果无溢出,将结果存放到内存0200H单元后停机;如有溢出,则直接停机。,程序执行,4.程序执行过程举例,1.3.3 指令与程序的执行过程,1-69,1.4.1 主流系统配置1.4.2 主板结构及其芯片组,1.4 目前主流微机系统的硬件配置与主板结构,1-70,主板。也叫母板或系统板。彩色显示器 标准键盘 鼠标 硬盘驱动器 光盘驱动器 约200W300W开关电源,配置中各种I/O设备都是通过相应I/O适配器控制的。,1.4.1 主流系统配置,目前主流微机系统的基本配置大体包括以下一些设备部件:,1-71,1.主板结构 微机主板的体系结构是随着微机系统总线技术的发展而发展的,所以微机主板的发展史实质上就是一部总线发展史。PC系列微机的主板,从基于8086的PC机和基于8088的PC/XT机以来,先后经历了如下发展阶段:XT总线主板 AT总线(ISA总线)主板 EISA主板 ISA/VL主板 EISA/PCI主板 ISA/PCI主板 PCI/AGP主板,1.4.2 主板结构及其芯片组,1-72,1.4.2 主板结构及其芯片组,就主板的组成和安装结构而言,主要有:AT主板 ATX(AT External)主板主流主板 NLX(New Low Profile Extention)主板,1-73,1.4.2 主板结构及其芯片组,北桥芯片,南桥芯片,CPU插槽,BIOS芯片,IDE接口,软驱接口,主板电源插座,AGP接口插槽,CPU电源插座,电池,1-74,1-75,1-76,1-77,1.4.2 主板结构及其芯片组,2.控制芯片组 控制芯片组是微处理器与内存、外设之间交换数据的桥梁,是协调和控制微机工作的核心控制逻辑,它与CPU构成紧密的配套关系。早期PC系列微机的控制逻辑都是用中小规模的IC芯片搭成,如8255A、8250、8259A、8237A、8253/8254等。从386微机开始,采用了专用的控制芯片组,把主板上各种控制逻辑集成到一片或多片VLSI芯片中。如82380、82C206等。Pentium系列微机,主要采用南、北桥结构芯片组。,1-78,1.4.2 主板结构及其芯片组,当前主流微机的逻辑结构,1-79,1-80,1-81,1-82,1-83,1.5 微机系统的主要性能指标,字长 存储器容量 运算速度 外设扩展能力 软件配置情况,一台计算机允许配接多少外部设备,对于系统接口和软件研制都有重大影响。,计算机运算速度一般用每秒钟所能执行的指令条数来表示。,字长是计算机内部一次可以处理的二进制数码的位数。字长越长,一个字所能表示的数据精度就越高;在完成同样精度的运算时,则数据的处理速度越高。,存储器容量是衡量计算机存储二进制信息量大小的一个重要指标。包括:内存容量 外存容量,软件是计算机系统必不可少的重要组成部分,它配置是否齐全,直接关系到计算机性能的好坏和效率的高低。,1-84,课外作业一,1-85,1.5 试填写出下表各数对应的8位原码、反码和补码。,1-86,1.7 填写下表中各机器码分别为原码、反码、补码、无符号二进制码和压缩BCD码时所对应的十进制真值。,