微机原理与接口技术 西安邮电大学计算机学院 宁晓菊.

Slides:



Advertisements
Similar presentations
個人傷害險-鐵馬逍遙專案 商品介紹 商品特色 保障內容 承保對象 保險費 案例 業務費用及淨業績 車險部業務規劃科.
Advertisements

長高 長壯 ㄋㄟㄋㄟ補給站 每天2份奶~~健康跟著來!.
输入输出程序设计 输入输出的基本概念 无条件方式输入输出 查询方式输入输出 中断方式输入输出.
代表机构年报操作指南 (代表机构端) 二〇一一年二月.
第2章 微型计算机基本原理 2.1 数的编码和字符的表示 二进制数 二进制数向十进制数的转换:
第7章 8086/8088汇编语言程序设计 7.1 引言 7.2 顺序程序设计 7.3 分支结构程序设计 7.4 循环结构程序设计
计算机基础知识 丁家营镇九年制学校 徐中先.
第3章 80x86汇编语言程序设计(下).
 指令系统  寻址方式 第3章 80x86的指令系统和寻址方式 一组指令的集合 指令 与数据有关的寻址方式 与转移地址有关的寻址方式
4.1 汇编语言 4.2 顺序结构程序 4.3 分支程序设计 4.4 循环程序设计 4.5 子程序设计
第3章 80x86汇编语言程序设计(上) 16位汇编版本 时间不够的情况下只讲16位汇编.
3.3.5 程序控制指令 控制转移指令分为: 转移指令 循环控制指令 调用和返回指令 中断指令.
微机原理与接口技术 微机原理与接口技术 朱华贵 2015年11月26日.
微机原理与接口技术 微机原理与接口技术 朱华贵 2015年10月09日.
第5章 循环与分支程序设计  循环程序设计  分支程序设计.
微型计算机技术 教 学 指 导(三) 太原广播电视大学 郭建勇.
第三章 寻址方式与指令系统 3.1 寻址方式 一条指令通常由两大部分构成: 操作码 操作数
第四章 典型CPU及指令系统举例.
Assembly Language Programming
第2章 汇编语言与汇编程序 ——8086/8088指令系统 mov ax,12h call display Jmp 1234h.
输入输出与中断 主要内容 CPU与外设之间数据传送方式 中断技术 8086中断系统和中断处理.
第八章 输入输出程序设计 总线 CPU MEM I/O接口 I/O设备.
总 复 习.
第3章 IA-32指令系统 3.1 基本数据类型 3.2 IA-32的指令格式 3.3 IA-32指令的操作数寻址方式
第3章 8086/8088指令系统 mov ax,12h call display Jmp 1234h.
微机原理与接口技术 ——80x86微处理器 西安邮电大学 计算机学院 范琳.
第一章 8086程序设计 第二章 MCS-51程序设计 第三章 微机基本系统的设计 第四章 存贮器与接口 第五章 并行接口
微机原理与接口技术 微机原理与接口技术 朱华贵 2015年11月20日.
微型计算机原理及应用.
8086 指令系统特点 可变长指令:指令格式比较复杂。
第五章 循环与分支程序设计 §5.1 循环与转移指令 §5.2 循环程序设计 §5.3 分支程序设计.
逆向工程-汇编语言
CPU结构和功能.
條件處理.
第四章 指令系统及汇编语言程序设计.
第5章 循环与分支程序设计 学习目标: 了解并掌握循环程序的构造方法,尤其是对循环控制条件的设置以及可能出现的边界情况的考虑。掌握起泡排序算法这种多重循环程序设计中的常用方法。交换标志位的设置在此算法中更能提高效率。学会在数组排序算法中采用折半查找法来提高查找效率。学会使用跳跃表法实现CASE结构。
第3章 MCS-51单片机指令系统 3.1 指令概述 3.2 寻址方式 3.3 MCS-51系列单片机的指令系统.
3.4.5 控制转移指令(Control transfer instructions) (一)、控制转移指令概述
教师:王晓甜 8086CPU 指令系统 教师:王晓甜
C语言程序设计 主讲教师:陆幼利.
得技通电子 问题 1.0 、选择题:本大题共15个小题,每小题1分,共15分,在每小题给出的四个选项中,只有一项符合题目要求,把所选项前的字母填在括号内。
习题3 1、 分别说明下列指令的原操作数和目的操作数各采用什么寻址方式。 设定如下: ①立即寻址 ② ① ②寄存器寻址
第四章 MCS-51定时器/计数器 一、定时器结构 1.定时器结构框图
微机原理与接口技术 微机原理与接口技术 朱华贵 2015年11月13日.
工业机器人知识要点解析 (ABB机器人) 主讲人:王老师
《微型计算机原理与接口技术》 第4版 王良 宁德师范学院 吴宁 乔亚男 编著 清华大学出版社 出版
第二章 补充知识 2.1 总线和三态门 一、总线(BUS) 三总线结构 数据总线DB(Data Bus)
<编程达人入门课程> 本节内容 内存的使用 视频提供:昆山爱达人信息技术有限公司 官网地址: 联系QQ: QQ交流群: ,
第5章 循环与分支程序设计  循环程序设计  分支程序设计.
1.2 有理数 第1课时 有理数 伏家营中学 付宝华.
本节内容 内存复制指令 视频提供:昆山爱达人信息技术有限公司 官网地址: 联系QQ: QQ交流群 : 联系电话:
第5章 循环与分支程序设计 5.1 循环程序设计 5.2 分支程序设计
微机原理与接口技术 西安邮电大学计算机学院 宁晓菊.
任务五 学习、应用控制转移类指令 单片机应用技术 认知1 掌握无条件转移指令格式及应用
单片机原理及应用 实践部分 主讲人:刘 强 四川工商学院单片机教学团队 单片机原理及应用 实践部分 主讲人:刘 强
College of Computer Science & Technology
第4课时 绝对值.
单片机应用技术 项目一 循环彩灯装置 第5讲 MCS-51单片机指令系统及指令格式 《单片机应用技术》精品课程组 湖北职业技术学院机电工程系.
本节内容 C语言的汇编表示 视频提供:昆山爱达人信息技术有限公司 官网地址: 联系QQ: QQ交流群 : 联系电话:
3. 逻辑运算指令 A、简单逻辑操作指令 CLR A. (不影响CY、AC、 OV标志) CPL A
本节内容 通用寄存器 视频提供:昆山爱达人信息技术有限公司 官网地址: 联系QQ: QQ交流群 : 联系电话:
本节内容 标志寄存器.
微机原理与接口技术 西安邮电大学计算机学院 宁晓菊.
C++语言程序设计 C++语言程序设计 第一章 C++语言概述 第十一组 C++语言程序设计.
循环程序设计 在程序中包含重复执行的程序段称为循环程序设计。循环程序可以使程序结构性强、可读性好,从而大大提高了程序质量。
4.3 汇编语言程序设计 顺序程序设计 顺序程序设计是最基本的程序设计。它是按照指令排列的先后顺序依次执行,每条指令都必须执行,且只执行一遍。顺序程序设计一般比较单一、简单,常常作为复杂程序的一部分。
微机原理与接口技术 第5章 汇编语言程序设计 西安邮电大学计算机学院 王 钰.
上节复习(11.7) 1、定时/计数器的基本原理? 2、定时/计数器的结构组成? 3、定时/计数器的控制关系?
第8章 并行接口芯片 并行接口一般具有两个或两个以上的8位I/O接口。各个口的工作方式可由程序分别确定或改变,使用灵活,便于和各种外部设备连接。因此,又称可编程的外部接口(PPI) 目前各主要微处理器厂商都有自己的PPI产品,但它们的功能基本类似.
第三章 8086的指令系统 8086指令特点 8086的寻址方式 8086的指令格式及数据类型 8086的指令集.
Presentation transcript:

微机原理与接口技术 西安邮电大学计算机学院 宁晓菊

第四章 80x86 指令系统(第八讲) 第一章 微型计算机系统导论(第一讲) 本讲主要内容 控制转移指令 1 2 处理器控制指令

第四章 80x86 指令系统—控制转移指令 控制转移类指令 能够使程序的执行流程发生改变的指令 1.无条件转移 JMP 转移指令 操作:有以下几种类型 ⑴ 段内直接短转移 JMP SHORT opr ;(IP)←(IP) + Data8 Data8是一个字节的补码数 范围:-128+127

第四章 80x86 指令系统—控制转移指令 ⑵ 段内直接近转移 JMP NEAR PTR opr ;(IP)←(IP)+Data16 范围:-32768  +32767 ⑶ 段内间接转移 JMP WORD PTR opr (IP)←寄存器或存储器操作数 ⑷ 段间直接转移 JMP FAR PTR opr 指令中用立即数的形式指出目标位置的段地址和偏移量

第四章 80x86 指令系统—控制转移指令 ⑸ 段间间接转移 JMP DWORD PTR opr 目标位置的段地址和偏移量保存在存储器中。 说明: ① 在汇编语言中通常使用标号表示要转移到的位置。 ② 使用该指令,可以使程序流程改变到任何目标位置。

第四章 80x86 指令系统—控制转移指令 2.条件转移 根据判断条件是否成立决定是否转移。按照判断条件的不同分为以下类型:单个标志、无符号数判断、有符号数判断、CX寄存器。 条件转移都是段内直接短转移,即(IP)=(IP)+Data8类型的转移。 指令格式:Jcc short_label “cc”表示条件 ⑴ 判断单个标志 ZF: JZ(JE),JNZ(JNE) SF: JS,JNS OF: JO,JNO PF: JP,JNP CF: JC,JNC

第四章 80x86 指令系统—控制转移指令 ⑵ 判断无符号数的大小 助记符中的意义: A(above):大于,B(below):小于, E(equal):等于 JB(JNAE),JNB(JAE), JA(JNBE), JNA(JBE) 判断CF and ZF ⑶ 判断有符号数的大小 助记符中的意义: G(greater):大于,L(less):小于, JL(JNGE),JNL(JGE),JLE(JNG),JNLE(JG) 判断CF and ZF and SF 使用比较大小的指令时,必须区分是有符号数还是无符号数。

第四章 80x86 指令系统—控制转移指令 ⑷ 判断CX寄存器 JCXZ: CX=0

第四章 80x86 指令系统—控制转移指令 3.循环控制 循环指令的转移也都是段内直接短转移,即(IP)←(IP)+Data8类型的转移。

第四章 80x86 指令系统—控制转移指令 (CX)0循环 LOOP disp8 (CX) (CX)-1 当 (CX)0 指令名称 指令格式 指令功能 测试条件 (CX)0循环 LOOP disp8 (CX) (CX)-1 当 (CX)0 则 (IP) (IP)+disp8 (CX)0 为零或相等循环 LOOPZ disp8 LOOPE disp8 当 (CX)0 且 (ZF)=1 (CX)0 且 (ZF)=1 非零或不等循环 LOOPNZ disp8 LOOPNE disp8 当 (CX)0 且 (ZF)=0 (CX)0 且 (ZF)=0

第四章 80x86 指令系统—控制转移指令 说明: ① 循环指令不影响状态标志。 ② 如果目标位置的位移量超出Data8所能够表示的范围,则需要用JMP辅助来完成循环。

第四章 80x86 指令系统—控制转移指令 例4.16 在内存的数据段中存放了若干个8位带符号数,数据块的长度为COUNT(不超过255),首地址为TABLE,试统计其中正数、负数及零的个数,并分别将统计结果存入PLUS、MINUS和ZERO单元中。

第四章 80x86 指令系统—控制转移指令 分析: 为了统计正数、负数和零的个数,可先将PLUS、MINUS和ZERO三个单元清零,然后将数据表中的带符号数逐个取入AL寄存器并使其影响状态标志位,再利用前面介绍的JS、JZ等条件转移指令测试该数是一个负数、零还是正数,然后分别在相应的单元中进行计数。 程序如下:

第四章 80x86 指令系统—控制转移指令 CHECK: LODSB XOR AL,AL OR AL,AL MOV PLUS,AL JS X1 JZ X2 INC PLUS JMP NEXT X1: INC MINUS X2: INC ZERO NEXT: LOOP  CHECK HLT XOR AL,AL MOV PLUS,AL MOV MINUS,AL MOV ZERO,AL LEA SI,TABLE MOV CX,COUNT CLD

第四章 80x86 指令系统—控制转移指令 4.子程序调用 CALL 子程序调用指令 用法:CALL dst 说明:由汇编程序自动匹配为某种寻址方式。 RET 子程序返回指令 用法:RET 段内返回:(IP)←((SP)+1:(SP)),(SP)←(SP)+2 段间返回:(IP)←((SP)+1:(SP)),(SP)←(SP)+2, (CS)←((SP)+1:(SP)),(SP)←(SP)+2 汇编程序自动匹配为段内或段间的返回

第四章 80x86 指令系统—处理器控制指令 处理器控制指令 1. 标志处理指令 CLC 对CF清零, CF ← 0 STC 对CF置位, CF ← 1 CMC 对CF取反,CF← CF CLD 对DF清零,DF ← 0 STD 对DF置位,DF ← 1 CLI 对IF清零,IF ← 0 STI 对IF置位,IF ← 1

第四章 80x86 指令系统—处理器控制指令 2. 处理器控制指令 NOP (No Operation) 空操作 一个字节的机器码,没有操作数,对状态标志位没有影响。不执行任何操作,但占用3个时钟周期,然后继续执行下一条指令。 HLT (Halt) 停机 处理器停止工作,进入暂停状态。外部中断或复位信号可使CPU退出暂停状态。对状态标志位没有影响。 WAIT (Wait) 等待 处理器处于等待状态,等到外部的TEST引脚上的低电平到来。

第四章 80x86 指令系统—处理器控制指令 ESC (Escape) 换码 该指令是一个交权的指令前缀,把指令给协处理处理。 一般和WAIT指令一起使用,通过TEST引脚和协处理器同步。 LOCK (Lock) 封锁 该指令是一个前缀,使得使用此前缀的指令执行时一直维持总线封锁状态。

学习要求 第四章 80x86 指令系统 指令系统是程序员编写程序的基础,因此很好地掌握本 章内容是后续进一步学习汇编语言程序设计的关键。通过本 章学习,应该达到如下要求: 1、熟练掌握8086/8088的寻址方式。 3、掌握8086/8088指令系统中的各种指令的名称、功能、 对操作数寻址方式的约定、 及指令执行对标志寄存器的 影响。

Thank you!