【汇编】#5 80x86指令系统其一(数据传送与算术)

文章目录

  • 一、数据传送指令
    • 1. 通用数据传送指令
      • 1.1 MOV传送指令
        • tips:MOV指令几条特殊规定
      • 1.2 XCHG交换指令
      • 1.3 进栈指令PUSH
      • 1.4 出栈指令POP
      • 1.5 所有寄存器进出栈指令PUSHA/POPA
        • tips:SP特别处理
    • 2. 累加器专用传送指令
      • 2.1 输入指令IN
      • 2.2 OUT输出指令
      • 2.3 IO端口与8086CPU通讯关系
      • 2.4 XLAT 换码指令
    • 3. 地址传送指令
      • 3.1 有效地址送寄存器指令LEA (Load Effective Address)
      • 3.2 指针送寄存器及相应段寄存器指令LDS和LES
      • 3.3 标志寄存器传送指令
  • 二、算术运算指令
    • 1. 加法指令
    • 2. 减法指令
    • 3. 乘法指令
    • 4. 除法指令
    • 5. 类型转换指令指令
    • 6. 十进制调整指令
      • 6.1 压缩的BCD码调整指令
      • 6.2 非压缩的BCD码调整指令


一、数据传送指令

数据传送指令负责把数据、地址或立即数传送到寄存器、存储器或端口号寄存器。它相对高级语言里的赋值语句。

  • 通用数据传送:MOV、XCHG、PUSH、POP

  • 累加器专用传送(输入输出):IN、OUT、XLAT

  • 地址传送:LEA、LDS、LES

  • 标志寄存器传送:LAHF、SAHF、PUSHF、POPF

1. 通用数据传送指令

1.1 MOV传送指令

把源操作数(第二操作数)的值传给目的操作数(第一操作数)该操作数的寻址方式可以是任意一种存储单元寻址方式

格式:MOV Reg/Mem,Reg/Mem/Imm

  • Reg—Register(寄存器)
  • Mem—Memory(存储器)
  • Imm—Immediate(立即数)
tips:MOV指令几条特殊规定
  1. 两个操作数的数据类型要相同,如:MOV BL,AXMOV AX,BL等都是不正确的;
  2. 两个操作数不能同时为段寄存器,如:MOV ES,DS等;
  3. 代码段寄存器CS不能为目的操作数,但可作为源操作数, 如:指令MOV CS, AX等不正确,但指令MOV AX,CS 等是正确的;
  4. 立即数不能直接传给段寄存器, 如:MOV DS,100H等;
  5. 立即数不能作为目的操作数,如:MOV 100H,AX等;
  6. 指令指针IP,不能作为MOV指令的操作数
  7. 两个操作数不能同时为存储单元,如:MOV VARA,VARB等,其中VARA和VARB是同数据类型的内存变量

1.2 XCHG交换指令

可以将一个字节或一个字的源操作数与目的操作数相交换。交换能在通用寄存器之间、通用寄存器与存储器之间进行。但段寄存器和立即数不能作为一个操作数

格式:XCHG OPD,OPS
eg:
(AL)=2AH,(DS)=1000H, (1204DH)=5BH,指令XCHG AL,[204DH]执行后,(AL)=5BH,(AL)=2AH


1.3 进栈指令PUSH

将寄存器、段寄存器或存储器中的一个字数据压入堆栈,堆栈指针减2(栈向低地址增长,且由于小端对齐,先高8位数据进栈,然后低8位数据进栈

格式:PUSH Reg/Mem/Seg

在这里插入图片描述


1.4 出栈指令POP

将栈顶元素弹出送至某一寄存器、段寄存器(除CS外)或存储器,堆栈指针加2。 (先低8位数据出栈,然后高8位数据出栈 )

格式:POP Reg/Mem/Seg
过程逆向PUSH即可


1.5 所有寄存器进出栈指令PUSHA/POPA

  • PUSHA:16位通用寄存器依次进栈,次序为AX、CX、DX、BX(不是ABCD!!),指令执行前的SP、BP、SI、DI。
    指令执行后(SP)-16→(SP),SP仍指向栈顶。
  • POPA:16位通用寄存器依次出栈,次序为DI、SI、BP、SP,指令执行前的BX、DX、CX、AX。
    指令执行后(SP)+16→(SP) ,SP仍指向栈顶

格式:PUSHA/POPA

tips:SP特别处理

SP出栈只是修改了指针,使其后的BX能够出栈,而堆栈中原先由PUSHA指令存入的SP的原始内容被丢弃,并未真正送到SP寄存器中。


2. 累加器专用传送指令

仅限于使用累加器AX或AL传送信息

2.1 输入指令IN

输入指令用来从指定的外设寄存器取信息送入累加器

Func:从端口中读入一个字节或字(取决于寄存器),并保存在寄存器AL或AX中。如果某输入设备的端口地址0~255范围之内,那么,可在指令IN中直接给出,否则,要把该端口地址先存入寄存器DX中,然后在指令中由DX来给出其端口地址

格式:

  • 长格式IN AL, PORT (字节)/IN AX, PORT (字)
  • 短格式IN AL, DX (字节)/IN AX, DX (字)

eg:
IN DX,2F8H不可,需要先MOV DX,2F8H再 进行IN指令

  • IN AL,DX;从端口2F8H读入一个字节到AL中
  • IN AX,DX;把端口2F8H、2F9H按“高高低低”组成
    的字读入AX

2.2 OUT输出指令

把累加器的内容送往指定的外设存储器

将寄存器AL或AX的内容输出到指定端口。如果某输出设备的端口地址在0~255范围之内,那么,可在指令OUT中直接给出,否则,要把该端口地址先存入寄存器DX中,然后在指令中由DX来给出其端口地址。

类似IN指令


2.3 IO端口与8086CPU通讯关系

所有I/O端口与CPU之间的通信都由IN和OUT指令来完成。外部设备最多有65536个I/O端口,端口号为0000~0FFFFH。

  • 前256个端口(00~0FFH)可以直接在指令中指定,这就是所谓的长格式
  • 当端口号≥256时,只能使用短格式,此时必须先将端口号放到DX寄存器中(端口号为0000~0FFFFH),然后再用IN和OUT指令来传送信
    息。
  • 注意:这里的端口号或DX的内容均为地址,而传送的是端口中的信息,在使用短格式时,DX内容才是端口号本身

2.4 XLAT 换码指令

XLAT指令有两个隐含操作数BX和AL

Function:把BX的值作为内存字节数组首地址、下标为AL的数组元素的值传送给AL。

格式:XLAT OPRXLAT

eg:
若(BX)=0040H
MOV AL,3
XLAT则指令执行后AL的值为33H
在这里插入图片描述

tips:可用来查表或访问数组,但表和数组的长度不能超过256.


3. 地址传送指令

3.1 有效地址送寄存器指令LEA (Load Effective Address)

Function: 将源操作数的有效地址送到指定的寄存器中。

格式:LEA REG,OPS

tips

  • 源操作数必须是一个内存操作数
  • 目的操作数必须是一个16位的通用寄存器。这条指令通常用来建立串操作指令所须的寄存器指针。
  • OPS不允许是直接地址。如lea bx,[2000h]。但可以使用符号地址,如 lea bx,varx 。

3.2 指针送寄存器及相应段寄存器指令LDS和LES

LDS_Function:

  • 完成一个地址指针的传送。地址指针包括段地址部分和偏移量部分。指令将段地址(EA+2)送入DS,偏移量部分(EA)送入一个16位的基址寄存器或变址寄存器

LES_Function:

  • 将地址指针的段地址部分送入ES外,与LDS类似

格式为: LDS/LES REG,OPS

tips:

  • 源操作数是一个内存操作数
  • 目的操作数是一般基址寄存器或变址寄存器。(其它16位寄存器也可以,但不能是段寄存器)例如:LDS SI,[BX] ;将把BX所指的32位地址指针的段地址部分送入DS,偏移量部分送入SI。
  • 本组指令不影响标志位。

3.3 标志寄存器传送指令

  • 标志送AH指令: LAHF;操作:(AH)<—(FLAGS的低字节)
  • AH送标志寄存器指令:SAHF;操作: (FLAGS的低字节)<—(AH)
  • 标志进栈指令:PUSHF;操作: (SP)<—(SP) - 2、((SP)+1, (SP))<—(FLAGS)
  • 标志出栈指令:POPF;操作: (FLAGS)<—((SP)+1,(SP))、(SP)<—(SP)+ 2

二、算术运算指令

该组指令的操作数可以是8位、16位。当存储单元是该类指令的操作数时,该操作数的寻址方式可以是任意一种存储单元寻址方式。

  • 加法指令 ADD、ADC、INC
  • 减法指令 SUB、SBB、DEC、NEG、CMP
  • 乘法指令 MUL、IMUL
  • 除法指令 DIV、IDIV
  • 类型转换指令: CBW CWD
  • 十进制调整指令 DAA、DAS、 AAA、AAS、AAM、AAD

1. 加法指令

  • ADD_Function: 将目的操作数与源操作数相加,结果存入目的地址中,源地址的内容不改变

  • ADC_Function:将目的操作数加源操作数再加低位进位,结果送目的地址

  • INC_Function:将目的操作数加1,结果送目的地址(INC指令不影响CF标志)

格式:

  • ADD DST,SRC
  • 带进位加法指令ADC DST,SRC
  • 加1指令:INC OPR

2. 减法指令

  • SUB_Function:目的操作数减去源操作数,结果存于目的地址,源地址的内容不变

  • SBB_Function:目的操作数减源操作数再减低位借位CF,结果送目的地址

  • DEC_Function:将目的操作数减1,结果送目的地址(不影响CF标志)

  • NEG_Function:将目的操作数的每一位取反(包括符号位)后加1,结果送目的地址。(允许存储器或寄存器操作数,不允许段寄存器)

  • CMP_Function:目的操作数减源操作数,结果只影响标志位,不送入目的地址

格式:

  • SUB DST,SRC
  • 带借位减法指令 SBB DST,SRC
  • 减1指令 DEC OPR
  • 求补指令: NEG OPR
  • 比较指令:CMP OPR1, OPR2

tips
对于字节操作时,数据-128和字操作时数据-32768的情况,求补后不变,OF=1


3. 乘法指令

Function: 若是字节数据相乘,(AL寄存器)与SRC相乘得到字数据存入AX中;若是数据相乘,则(AX)与SRC相乘得到双字数据高字存入DX、低字存入AX中SRC不允许是立即数

格式:

  • 无符号数乘法指令:MUL SRC
  • 带符号数乘法指令:IMUL SRC

tip:对OF和CF标志的影响:

  • MUL指令——若乘积的高一半(AH或DX)为0,则OF=CF=0;否则OF=CF=1。(用来检查字节相乘的结果是字节还是字,或字相乘的结果是字还是双字)
  • IMUL指令——若乘积的高一半是低一半的符号扩展,则OF=CF=0;否则均为1。

4. 除法指令

寄存器使用与乘法相同

格式:

  • 无符号数除法指令: DIV SRC
  • 带符号数除法指令: IDIV SRC

tips:

  • 对DIV指令,在除数为0,或者在字节除时商超过8位,或者在字除时商超过16位时发生除法溢出。
  • 对IDIV指令,除数为0,或者在字节除时商不在-128~127范围内,或者在字除时商不在-32768~32767范围内,发生除法溢出。
  • SRC不允许是立即数

5. 类型转换指令指令

  • 字节扩展为字指令 CBW AL -> AX
    执行操作: 若(AL)的最高有效位为0,则(AH)= 00H若(AL)的最高有效位为1,则(AH)= FFH
  • 字扩展成双字指令CWD AX -> (DX,AX)
    执行操作:若(AX)的最高有效位为0,则(DX)= 0000H若(AX)的最高有效位为1,则(DX)= FFFFH

6. 十进制调整指令

6.1 压缩的BCD码调整指令

  • 加法的十进制调整指令DAA
    格式:DAA
    • 如果AL寄存器中低4位大于9或辅助进位AF=1,则AL=AL+6且AF=1;
    • 如果AL>=0A0H或CF=1,则AL=AL+60H且CF=1。
    • 该指令对SF、ZF、PF均有影响。
  • 减法的十进制调整指令DAS
    格式:DAS
    • 如果AF=1或AL寄存器中低4位大于9,则AL=AL-6且AF=1;
    • 如果AL>=0A0H或CF=1,则AL=AL-60H且CF=1。
    • SF、ZF、PF均受影响。

6.2 非压缩的BCD码调整指令

  • 加法的非压缩的BCD调整指令AAA
    格式:AAA

    • 如果AL的低4位大于9或AF=1,则AL=AL+6,AH=AH+1,AF=CF=1, 且AL高4位清零。
      否则CF=AF=0,AL高4位清零。
  • 减法的非压缩的BCD调整指令AAS
    格式:AAS

    • 如果AL的低4位大于9或AF=1,则AL=AL-6,AH=AH-1,AF=CF=1,AL高4位清零。
      否则CF=AF=0, AL高4位清零。
    • 其他标志位OF、PF、SF、ZF不确定。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/461493.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

栈及其Java实现

栈及其Java实现 ​ 栈&#xff08;Stack)又名堆栈&#xff0c;是允许在同一端进行插入和删除操作的特殊线性表。其中&#xff0c;允许进行插入和删除操作的一端叫做栈顶&#xff08;Top&#xff09;,另一端叫做栈底&#xff08;Bottom&#xff09;,栈底固定&#xff0c;栈顶浮…

常见面试题之计算机网络

1. OSI 五层模型&#xff08;或七层模型&#xff09;是什么&#xff0c;每一层的作用是什么 应用层&#xff1a;又可细分为应用层、表示层、会话层。其中应用层主要做的工作就是为应用程序提供服务&#xff0c;常见的协议为 HTTP、HTTPS、DNS等&#xff1b;表示层主要做的工作…

如何从笔记本电脑恢复已删除的照片

人们相信照片是回忆一生中最难忘事件的最佳媒介。人们在计算机上收集超过 5 GB 的照片是很常见的。然而&#xff0c;在笔记本电脑上保存照片并不安全&#xff0c;因为您可能会因以下原因有意或无意地删除笔记本电脑上的照片&#xff1a; 您的笔记本电脑存储空间几乎已满。您必…

模型、算法、数据模型、模型结构是什么?它们之间有什么关联和区别?

模型、算法、数据模型、模型结构是什么&#xff1f;它们之间有什么关联和区别&#xff1f; 导读一、算法1、算法定义2、机器学习算法定义 二、模型1、模型定义2、数据模型定义3、机器学习模型定义 三、模型结构1、线性模型2、基于实例的模型3、决策树模型4、支持向量机5、集成方…

分析基于解析物理模型的E模式p沟道GaN高电子迁移率晶体管(H-FETs)

来源&#xff1a;Analyzing E-Mode p-Channel GaN H-FETs Using an Analytic Physics-Based Compact Mode&#xff08;TED 24年&#xff09; 摘要 随着近期对用于GaN互补技术集成电路&#xff08;ICs&#xff09;开发的p沟道GaN器件研究兴趣的激增&#xff0c;一套全面的模型…

程序员要失业?全球首位“AI程序员”Deven真的适合职场吗

制造Devin的公司&#xff0c;是一家叫Cognition的10人初创公司&#xff0c;才成立不到2个月。 一、引言 一家成立不到两个月但拥有十名天才工程师的初创公司Cognition&#xff0c;搞了一个引爆科技圈的大动作。 他们推出了一款名为Devin的人工智能&#xff08;AI&#xff09;助…

C语言数据结构易错知识点(3)(堆)

1.堆的本质&#xff1a;完全二叉树 堆在物理结构上是顺序结构&#xff0c;实现方式类似于顺序表&#xff08;数组&#xff09;&#xff1b;但在逻辑结构上是树形结构&#xff0c;准确来说堆是一棵完全二叉树。因为堆的实现在代码上和顺序表有很高的相似度&#xff0c;所以在写…

机试:偶数分解

题目描述: 代码示例: #include <bits/stdc.h> using namespace std; int main(){ // 算法思想1:遍历小于该偶数的所有素数,存入数组中,遍历数组找出两个数之和等于偶数的数int n;cout << "输入样例" << endl;cin >> n;int nums[n];int k …

Android 地图 判断一点是否在某区域内

问题 Android 地图 判断一点是否在某区域内 详细问题 笔者进行Android项目开发&#xff0c;接入高德地图绘制区域后&#xff0c;需要判断一点是否在某区域内&#xff0c;如何实现 代码 mMapView.getMap().addPolygon(polygonOptions).contains(latLng)代码含义解释 这段代…

【C#】【SAP2000】读取SAP2000中frame单元列表到Grasshopper中

private void RunScript(bool build, ref object p1, ref object p2, ref object Profile, ref object stressRatio, ref object temperatureLoad, ref object displacement, ref object frameList){if (build true){// 声明变量int ret;int Numit 0;int[] ObjType new int[…

在Vue中使用wangeditor创建富文本编辑器的完整指南

&#x1f31f; 前言 欢迎来到我的技术小宇宙&#xff01;&#x1f30c; 这里不仅是我记录技术点滴的后花园&#xff0c;也是我分享学习心得和项目经验的乐园。&#x1f4da; 无论你是技术小白还是资深大牛&#xff0c;这里总有一些内容能触动你的好奇心。&#x1f50d; &#x…

Jmeter+Ant 接口自动化环境配置指南

一 、Jmeter安装与配置 https://blog.csdn.net/tester_sc/article/details/80746405 注&#xff1a;Jmeter5.0的环境变量配置与4.0或历往老版本有部分小差异&#xff0c;笔者用的Jmeter 5.0 二 、Ant的安装与配置 # Ant下载地址(下载到指定目录后&#xff0c;进行解压到当前…

链表详解-leetcode203.移除链表元素

链表 移除链表元素 题目&#xff1a; 题意&#xff1a;删除链表中等于给定值 val 的所有节点。 示例 1&#xff1a; 输入&#xff1a;head [1,2,6,3,4,5,6], val 6 输出&#xff1a;[1,2,3,4,5] 示例 2&#xff1a; 输入&#xff1a;head [], val 1 输出&#xff1a;[…

C++中的多值返回:解锁函数返回值的神奇力量

C中的多值返回&#xff1a;解锁函数返回值的神奇力量 在C编程中&#xff0c;有时候我们需要从函数中返回多个值。虽然C中的函数通常只能返回一个值&#xff0c;但有几种技术和惯用法可以实现返回多个值的效果。本文将介绍C中实现多值返回的几种常用方法&#xff0c;包括引用、指…

F5怎么样?保障AI服务的安全性和交付

伴随着人工智能时代的快速发展&#xff0c;AI已成为企业数字化转型的得力工具&#xff0c;比如为用户提供更好的服务&#xff0c;降低企业成本等。与此同时&#xff0c;AI技术的应用也会带来应用安全等方面的新风险&#xff0c;可见其有着双刃剑效应。作为一家提供多云应用安全…

react-面试题

一、组件基础 1. React 事件机制 <div onClick{this.handleClick.bind(this)}>点我</div> React并不是将click事件绑定到了div的真实DOM上&#xff0c;而是在document处监听了所有的事件&#xff0c;当事件发生并且冒泡到document处的时候&#xff0c;React将事…

差分逻辑电平 — LVDS、CML、LVPECL、HCSL互连

前言 首先了解差分逻辑电平、单端逻辑电平的基础知识 地址&#xff1a;常见的逻辑电平_常用的逻辑电平-CSDN博客 注&#xff1a; ECL >> PECL >> LVPECL演变&#xff1b; ECL速度快&#xff0c;驱动能力强&#xff0c;噪声小&#xff0c;但是功耗大&#xff0c;使…

STM32-位带操作及位带别名区

这里写自定义目录标题 一、位带操作的基本含义及作用二、以STM32为例三、位带别名区和位带区(寄存器地址位地址)的转换关系四、使用例程 一、位带操作的基本含义及作用 位带别名区的设计主要是为了**方便对位带区单个比特位进行读写操作**。在某些应用场景下&#xff0c;需要频…

手把手学会pycharm中使用git

学习教程&#xff1a;http://【git pycharm的使用 连接github】 https://www.bilibili.com/video/BV1sv4y1D7SW/?share_sourcecopy_web&vd_source1a32dd27a726236a74603cf06b7302aa 1. 上传到本地仓库 &#xff08;1&#xff09;直接上传本地仓库 &#xff08;2&#xf…

OpenOFDM接收端信号处理流程

Overview — OpenOFDM 1.0 documentation 本篇文章为学习OpenOFDM之后的产出PPT&#xff0c;仅供学习参考。 ​​​​​​​