《汇编语言课件》第1章 基础知识第2章 80x86计算机组织.ppt

《汇编语言课件》第1章 基础知识第2章 80x86计算机组织.ppt

ID:55344136

大小:320.00 KB

页数:50页

时间:2020-05-14

《汇编语言课件》第1章   基础知识第2章 80x86计算机组织.ppt_第1页
《汇编语言课件》第1章   基础知识第2章 80x86计算机组织.ppt_第2页
《汇编语言课件》第1章   基础知识第2章 80x86计算机组织.ppt_第3页
《汇编语言课件》第1章   基础知识第2章 80x86计算机组织.ppt_第4页
《汇编语言课件》第1章   基础知识第2章 80x86计算机组织.ppt_第5页
资源描述:

《《汇编语言课件》第1章 基础知识第2章 80x86计算机组织.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、80X86微处理器对程序员来说,80x86内部结构的最重要的是其寄存器组8个通用寄存器1个指令指针寄存器1个标志寄存器4个段寄存器80x86内部结构内部暂存器IPESSSDSCS输入/输出控制电路外部总线执行部分控制电路123456∑ALU标志寄存器AHALBHBLCHCLDHDLSPBPSIDI通用寄存器地址加法器指令队列缓冲器执行部件(EU)总线接口部件(BIU)16位20位16位8位80x86的通用寄存器80x86的16位通用寄存器是:AXBXCXDXSIDIBPSP其中前4个数据寄存器都还可以分成高8位和低8位两个独立的寄存

2、器80x86的8位通用寄存器是:AHBHCHDHALBLCLDL对其中某8位的操作,并不影响另外对应8位的数据数据寄存器数据寄存器用来存放计算的结果和操作数,也可以存放地址每个寄存器又有它们各自的专用目的AX--累加器,使用频度最高,用于算术、逻辑运算以及与外设传送信息等;BX--基址寄存器,常用做存放存储器地址;CX--计数器,作为循环和串操作等指令中的隐含计数器;DX--数据寄存器,常用来存放双字长数据的高16位,或存放外设端口地址。变址寄存器变址寄存器常用于存储器寻址时提供地址SI是源变址寄存器DI是目的变址寄存器串操作类指令

3、中,SI和DI具有特别的功能指针寄存器指针寄存器用于寻址内存堆栈内的数据SP为堆栈指针寄存器,指示栈顶的偏移地址SP不能再用于其他目的,具有专用目的BP为基址指针寄存器,表示数据在堆栈段中的基地址SP和BP寄存器与SS段寄存器联合使用以确定堆栈段中的存储单元地址堆栈(Stack)堆栈是主存中一个特殊的区域它采用先进后出FILO(FirstInLastOut)或后进先出LIFO(LastInFirstOut)的原则进行存取操作,而不是随机存取操作方式。堆栈通常由处理器自动维持。在80x86中,由堆栈段寄存器SS和堆栈指针寄存器SP共同

4、指示指令指针IP指令指针寄存器IP,指示代码段中指令的偏移地址它与代码段寄存器CS联用,确定下一条指令的物理地址计算机通过CS:IP寄存器来控制指令序列的执行流程IP寄存器是一个专用寄存器标志寄存器标志(Flag)用于反映指令执行结果或控制指令执行形式80x86处理器的各种标志形成了一个16位的标志寄存器FLAGS(程序状态字PSW寄存器)OF111512DF10IF9TF8SF7ZF65AF43PF21CF0程序设计需要利用标志的状态标志的分类状态标志--用来记录程序运行结果的状态信息,许多指令的执行都将相应地设置它CFZFSFP

5、FOFAF控制标志--可由程序根据需要用指令设置,用于控制处理器执行指令的方式DFIFTF进位标志CF(CarryFlag)当运算结果的最高有效位有进位(加法)或借位(减法)时,进位标志置1,即CF=1;否则CF=0。3AH+7CH=B6H,没有进位:CF=0AAH+7CH=(1)26H,有进位:CF=1零标志ZF(ZeroFlag)若运算结果为0,则ZF=1;否则ZF=03AH+7CH=B6H,结果不是零:ZF=084H+7CH=(1)00H,结果是零:ZF=1注意:ZF为1表示的结果是0符号标志SF(SignFlag)运算结果最

6、高位为1,则SF=1;否则SF=03AH+7CH=B6H,最高位D7=1:SF=184H+7CH=(1)00H,最高位D7=0:SF=0有符号数据用最高有效位表示数据的符号所以,最高有效位就是符号标志的状态奇偶标志PF(ParityFlag)当运算结果最低字节中“1”的个数为零或偶数时,PF=1;否则PF=03AH+7CH=B6H=10110110B结果中有5个1,是奇数:PF=0PF标志仅反映最低8位中“1”的个数是 偶或奇,即使是进行16位字操作溢出标志OF(OverflowFlag)若算术运算的结果有溢出,则OF=1;否则OF

7、=03AH+7CH=B6H,产生溢出:OF=1AAH+7CH=(1)26H,没有溢出:OF=0溢出标志OF(OverflowFlag)问题什么是溢出?溢出和进位有什么区别?处理器怎么处理,程序员如何运用?如何判断是否溢出?什么是溢出处理器内部以补码表示有符号数8位表达的整数范围是:+127~-12816位表达的范围是:+32767~-32768如果运算结果超出这个范围,就产生了溢出有溢出,说明有符号数的运算结果不正确3AH+7CH=B6H,就是58+124=182,已经超出-128~+127范围,产生溢出,故OF=1;另一方面,补码

8、B6H表达真值是-74,显然运算结果也不正确溢出和进位溢出标志OF和进位标志CF是两个意义不同的标志进位标志表示无符号数运算结果是否超出范围,运算结果仍然正确;溢出标志表示有符号数运算结果是否超出范围,运算结果已经不正确。请看例子溢出

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。