汇编的使用总结

一、汇编的组成

1、汇编指令(指令集)

        数据处理指令:

                数据搬移指令

                数据移位指令

                位运算指令

                算术运算指令

                比较指令

        跳转指令

        内存读写指令

        状态寄存器传送指令

        异常产生指令等

2、伪指令

        不是汇编指令,但是可以起到指令的作用,伪指令也会占用一定内存空间

3、伪操作

        不占用指令内存,能够在程序编译过程中起到编译引导作用的内容

4、注释

二、汇编指令

2.1基本格式 

<opcode>{<cond>}{s}        <Rd>,<Rn>,<shifter_operand>

注释:

        opcode:指令的功能码,用来表示当前指令的作用

(可以写,也可以不写        

        cond:条件码

        s:表示进行运算时运算的结果会影响到CPSR条件位

  )

        Rd:目标寄存器

        Rn:第一操作寄存器

        shifter_operand:第二操作寄存器

 2.2数据搬移指令

1、mov{条件码}        目标寄存器 操作数

        将操作数搬移到目标寄存器

2、mvn{条件码}        目标寄存器 操作数

        将操作数按位取反后搬移到目标寄存器

注意:

        操作数可以是一个寄存器,也可以是一个立即数

立即数:能够经过编码之后保存到指令空间中直接当作指令一部分去执行的数据。

如果想要把一个非立即数搬移到目标寄存器,使用伪指令ldr,格式:ldr  目标寄存器,=数据

2.3数据移位指令

1、逻辑左移

        lsl{条件码}        目标寄存器,第一操作寄存器,第二操作数

                将第一操作寄存器的数据左移第二操作数位数,结果保存到目标寄存器

2、逻辑右移

        lsr{条件码}        目标寄存器,第一操作寄存器,第二操作数

                将第一操作寄存器的数据右移第二操作数位数,结果保存到目标寄存器

3、循环右移

        ror{条件码}        目标寄存器,第一操作寄存器,第二操作数

                将第一操作寄存器的数据循环右移第二操作数位数,结果保存到目标寄存器

2.4位运算指令 

1、与运算

        and{条件码}        目标寄存器,第一操作寄存器,第二操作数

                将第一操作寄存器的数据和第二操作数进行与运算,结果保存到目标寄存器

2、或运算

        orr{条件码}        目标寄存器,第一操作寄存器,第二操作数

                将第一操作寄存器的数据和第二操作数进行或运算,结果保存到目标寄存器

3、异或运算

        eor{条件码}        目标寄存器,第一操作寄存器,第二操作数

                将第一操作寄存器的数据和第二操作数进行异或运算,结果保存到目标寄存器

4、按位取反

        mvn{条件码}        目标寄存器,第一操作寄存器,第二操作数

5、按位清零

        bic{条件码}        目标寄存器,第一操作寄存器,第二操作数

                将第一操作寄存器的数据和第二操作数进行与运算,结果保存到目标寄存器

2.5算术运算

1、加法运算

         add{条件码}{s}        目标寄存器,第一操作寄存器,第二操作数

                目标寄存器=第一操作寄存器+第二操作数

2、考虑CPSR条件位的加法运算

         adc{条件码}{s}        目标寄存器,第一操作寄存器,第二操作数

                目标寄存器=第一操作寄存器+第二操作数+cpsr寄存器c位的值

3、减法运算

         sub{条件码}{s}        目标寄存器,第一操作寄存器,第二操作数

                目标寄存器=第一操作寄存器-第二操作数

4、考虑CPSR条件位的减法运算

         sbc{条件码}{s}        目标寄存器,第一操作寄存器,第二操作数

                目标寄存器=第一操作寄存器-第二操作数-cpsr寄存器c位的值

5、乘法运算

         mul{条件码}{s}        目标寄存器,第一操作寄存器,第二操作数

                目标寄存器=第一操作寄存器*第二操作数

 2.6比较指令

1、cmp        第一操作寄存器,第二操作数

        将第一操作寄存器和第二操作数进行比较

2、tst        目标寄存器,#(0x1<<N)

        用来判断目标寄存器的第N位是否为0

3、teq         目标寄存器,第二操作数

        判断目标寄存器的值是否和第二操作数相等

2.7跳转指令 

1、b        标签

        跳转到指定的标签下,跳转后LR寄存器不保存程序返回地址

2、bl        标签

        跳转到指定的标签下,跳转后LR寄存器保存程序返回地址

2.8内存读写指令 

①单寄存器内存读写指令

写:

        1、str        目标寄存器,[目标地址]

                将目标寄存器中四字节数据写入到目标地址对应的内存中  

        2、strh        目标寄存器,[目标地址]

                将目标寄存器中二字节数据写入到目标地址对应的内存中

        3、strb        目标寄存器,[目标地址]

                将目标寄存器中一字节数据写入到目标地址对应的内存中

读:

        1、ldr        目标寄存器,[目标地址]

                从目标寄存器中读取四字节数据到目标地址对应的内存中  

        2、ldrh        目标寄存器,[目标地址]

                将目标寄存器中读取二字节数据到目标地址对应的内存中

        3、ldrb        目标寄存器,[目标地址]

                将目标寄存器中读取一字节数据到目标地址对应的内存中


②批量寄存器内存读写指令

写:

        1、stm        基地址,{寄存器列表}

                将寄存器列表中所有寄存器的数据写入到基地址为首地址的内存中 

读:

        1、ldm        基地址,{寄存器列表}

                从基地址开始往下读取数据,保存到寄存器列表中的每一个寄存器中

批量寄存器地址增长方式

        Ⅰ、ia后缀        先向基地址读写数据,基地址再往大地址方向增长

        Ⅱ、ib后缀       基地址先往大地址方向增长,再向基地址读写数据

        Ⅲ、da后缀         先向基地址读写数据,基地址再往小地址方向增长

        Ⅳ、da后缀        基地址先往小地址方向增长,再向基地址读写数据         


③栈内存读写

        压栈:

                push        {寄存器列表}

        出栈:

                pop        {寄存器列表}

栈的分类:

        1、空栈和满栈

        2、增栈和减栈

        组合:空增栈(EA)        空减栈(ED)        满增栈(FA)        满减栈(FD)

2.9状态寄存器传送指令

1、读状态寄存器指令

        mrs        目标寄存器,CPSR

                读取CPSR寄存器数值,保存到目标寄存器

2、修改状态寄存器

        msr        CPSR,操作数

                修改CPSR寄存器的数值为操作数

2.10软中断产生指令 

1、swi        操作数

        操作数是一个立即数,就是产生软中断的中断号

异常模式和异常源

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【玩转全栈】----Django模板的继承

先赞后看&#xff0c;养成习惯&#xff01;&#xff01;&#xff01; 目录 模板继承的好处 模板继承的语法规则 更新代码 上文中的部门管理页面&#xff1a; 【玩转全栈】----Django制作部门管理页面-CSDN博客 大家会发现&#xff0c;由于定义了多个html文件&#xff0c;多个ht…

nosql mysql的区别

NoSQL 和 MySQL 是两种不同类型的数据库管理系统&#xff0c;它们在设计理念、数据模型、可扩展性和应用场景等方面有着本质的区别。 NoSQL 数据库 特点: 灵活的数据模型: NoSQL 数据库通常没有固定的表结构&#xff0c;可以很容易地存储不同结构的文档或键值对。水平扩展: …

python实现dbscan

python实现dbscan 原理 DBSCAN(Density-Based Spatial Clustering of Applications with Noise)是一个比较有代表性的基于密度的聚类算法。它将簇定义为密度相连的点的最大集合&#xff0c;能够把具有足够高密度的区域划分为簇&#xff0c;并可在噪声的空间数据库中发现任意形…

Lustre Core 语法 - 比较表达式

概述 Lustre v6 中的 Lustre Core 部分支持的表达式种类中&#xff0c;支持比较表达式。相关的表达式包括 , <>, <, >, <, >。 相应的文法定义为 Expression :: Expression Expression | Expression <> Expression | Expression < Expression |…

gesp(C++六级)(4)洛谷:B3874:[GESP202309 六级] 小杨的握手问题

gesp(C六级)&#xff08;4&#xff09;洛谷&#xff1a;B3874&#xff1a;[GESP202309 六级] 小杨的握手问题 题目描述 小杨的班级里共有 N N N 名同学&#xff0c;学号从 0 0 0 至 N − 1 N-1 N−1。 某节课上&#xff0c;老师安排全班同学进行一次握手游戏&#xff0c;具…

【自然语言处理(NLP)】机器翻译之数据处理(数据收集、数据清洗、数据分词、数据标注、数据划分)

文章目录 介绍机器翻译之数据处理数据收集数据清洗数据分词数据标注数据划分代码实现导包数据查看处理函数数据预处理词元化统计每句话的长度的分布情况截断或者填充文本序列将机器翻译的文本序列转换成小批量tensor加载数据试用一下 个人主页&#xff1a;道友老李 欢迎加入社区…

【物联网】ARM核常用指令(详解):数据传送、计算、位运算、比较、跳转、内存访问、CPSR/SPSR、流水线及伪指令

文章目录 指令格式&#xff08;重点&#xff09;1. 立即数2. 寄存器位移 一、数据传送指令1. MOV指令2. MVN指令3. LDR指令 二、数据计算指令1. ADD指令1. SUB指令1. MUL指令 三、位运算指令1. AND指令2. ORR指令3. EOR指令4. BIC指令 四、比较指令五、跳转指令1. B/BL指令2. l…

过年之无用知识研究:std::is_assignable到底怎么个事?

下面是gcc的std::is_assignable相关源码&#xff1a;template<typename _Tp, typename _Up>class __is_assignable_helper{template< typename _Tp1, typename _Up1,typename decltype(declval<_Tp1>() declval<_Up1>()) //注意这行 >static true_ty…

单链表算法实战:解锁数据结构核心谜题——链表的回文结构

题目如下&#xff1a; 解题过程如下&#xff1a; 回文结构举例&#xff1a; 回文数字&#xff1a;12521、12321、1221…… 回文字符串&#xff1a;“abcba”、“abba”…… 并不是所有的循环嵌套的时间复杂度都是O(n^2) 可以用C写C程序&#xff1a; C里可以直接使用ListNode…

C++ 包装器与绑定器的应用之回调函数的实现

回调函数的实现 在消息队列和网络库的框架中&#xff0c;当接收到消息&#xff08;报文&#xff09;时&#xff0c;回调用户自定义的函数对象&#xff0c;把消息&#xff08;报文&#xff09;参数传给它&#xff0c;由它决定如何处理。 queue参考文章:C queue(STL queue&…

除了layui.js还有什么比较好的纯JS组件WEB UI?在谷歌浏览上显示

以下是一些比较好的纯JS组件WEB UI&#xff0c;可以在谷歌浏览器上良好显示&#xff1a; 1. Sencha 特点&#xff1a;提供超过140个高性能UI组件&#xff0c;用于构建现代应用程序。支持与Angular和React集成&#xff0c;提供企业级网格解决方案。 适用场景&#xff1a;适用于…

计算机网络 (58)无线局域网WLAN

前言 无线局域网WLAN&#xff08;Wireless Local Area Network&#xff09;是一种利用无线通信技术将计算机设备互联起来&#xff0c;构成可以互相通信和实现资源共享的网络体系。 一、定义与特点 定义&#xff1a; WLAN通过无线信道代替有线传输介质连接两个或多个设备形成一个…

AIP-132 标准方法:List

编号132原文链接AIP-132: Standard methods: List状态批准创建日期2019-01-21更新日期2022-06-02 在许多API中&#xff0c;通常会向集合URI&#xff08;例如 /v1/publishers/1/books &#xff09;发出GET请求&#xff0c;获取集合中资源的列表。 面向资源设计&#xff08;AIP…

Vue.js组件开发-Vue实现上传word模版打印设置自定义样式和布局

要使用 Vue 实现上传 Word 模板、打印并设置自定义样式和布局&#xff0c;可以借助一些工具和库来完成这个任务。 实现步骤 创建 Vue 项目&#xff1a;使用 Vue CLI 创建一个新的 Vue 项目。安装依赖&#xff1a;安装 docx-templates 库来处理 Word 模板&#xff0c;file-sav…

算法随笔_28:最大宽度坡_方法2

上一篇:算法随笔_27:最大宽度坡-CSDN博客 题目描述如下: 给定一个整数数组 nums&#xff0c;坡是元组 (i, j)&#xff0c;其中 i < j 且 nums[i] < nums[j]。这样的坡的宽度为 j - i。 找出 nums 中的坡的最大宽度&#xff0c;如果不存在&#xff0c;返回 0 。 示例 …

C++中函数返回值当引用

文章目录 一、概述二、返回值当引用的基本语法三、返回局部变量的引用四、返回引用的常见用途五、返回右值引用六、总结 一、概述 在 C 中&#xff0c;函数返回值当引用&#xff08;即返回引用&#xff09;是一个常见的编程技巧。它可以让你返回一个函数内部的局部变量或对象的…

10 款《医学数据库和期刊》查阅网站

在毕业设计过程中,需要查阅到关于医学的相关文献和图片作为参考,发现下面10款非常的好用,作为分享。 1. PubMed: PubMed 搜索关键词如“lung cancer CT images”或“lung cancer CT scan”。 Radiopaedia: https://radiopaedia.org/ 这是一个放射学专业网站,有大量肺癌的CT…

OpenCV:形态学梯度

目录 简述 1. 用图像运算和腐蚀实现形态学梯度 1.1 代码示例 1.2 运行结果 2. 形态学梯度接口 2.1 参数解释 2.2 代码示例 2.3 运行结果 3. 形态学梯度与边缘检测 4. 形态学梯度的应用场景 5. 注意事项 相关阅读 OpenCV&#xff1a;图像的腐蚀与膨胀-CSDN博客 简述…

Java 大视界 -- Java 大数据在生物信息学中的应用与挑战(67)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…

MySQL中InnoDB逻辑存储结构

在MySQL中&#xff0c;InnoDB是最常用的存储引擎之一&#xff0c;它具有高度的事务支持、行级锁、ACID特性以及自动崩溃恢复等特性。InnoDB的逻辑存储结构可以分为多个层次&#xff0c;下面是详细的解析。 1. 表空间 (Tablespace) InnoDB的物理存储结构以表空间为基础。表空间…