ARM指令集

  

ADC 带进位的32位数加法
ADD 32位数相加
AND 32位数的逻辑与
B 在32M空间内的相对跳转指令
BIC 32位数的逻辑位清零
BKPT 断点指令
BL 带链接的相对跳转指令
BLX 带链接的切换跳转
BX 切换跳转
CDP CDP2 协处理器数据处理操作
CLZ 零计数
CMN 比较两个数的相反数
CMP 32位数比较
EOR 32位逻辑异或
LDC LDC2 从协处理器取一个或多个32位值
LDM 从内存送多个32位字到ARM寄存器
LDR 从虚拟地址取一个单个的32位值
MCR MCR2 MCRR 从寄存器送数据到协处理器
MLA 32位乘累加
MOV 传送一个32位数到寄存器
MRC MRC2 MRRC 从协处理器传送数据到寄存器
MRS 把状态寄存器的值送到通用寄存器
MSR 把通用寄存器的值传送到状态寄存器
MUL 32位乘
MVN 把一个32位数的逻辑“非”送到寄存器
ORR 32位逻辑或
PLD 预装载提示指令
QADD 有符号32位饱和加
QDADD 有符号双32位饱和加
QSUB 有符号32位饱和减
QDSUB 有符号双32位饱和减
RSB 逆向32位减法
RSC 带进位的逆向32法减法
SBC 带进位的32位减法
SMLAxy 有符号乘累加(16位*16位)+32位=32位
SMLAL 64位有符号乘累加((32位*32位)+64位=64位)
SMALxy 64位有符号乘累加((32位*32位)+64位=64位)
SMLAWy 号乘累加((32位*16位)>>16位)+32位=32位
SMULL 64位有符号乘累加(32位*32位)=64位
SMULxy 有符号乘(16位*16位=32位)
SMULWy 有符号乘(32位*16位>>16位=32位)
STC STC2 从协处理器中把一个或多个32位值存到内存
STM 把多个32位的寄存器值存放到内存
STR 把寄存器的值存到一个内存的虚地址内间
SUB 32位减法
SWI 软中断
SWP 把一个字或者一个字节和一个寄存器值交换
TEQ 等值测试
TST 位测试
UMLAL 64位无符号乘累加((32位*32位)+64位=64位)
UMULL 64位无符号乘累加(32位*32位)=64位
时间: 2024-11-08 19:23:30

ARM指令集的相关文章

ARM_Instruction_Set_Encoding_hacking(ARM指令集编码格式解读)

ARM指令集编码格式解读 说明: 1.本文参考的书籍<ARM Architecture Reference Manual ARMv7-A and ARMv7-R edition>中的Chapter A5: ARM Instruction Set Encoding. 2.本人对本文最终效果中的表格缩进没有对齐的现象表示歉意,因为目前本人解决不了   :) 3.本文的解读流程如下: 1.Format of the CPSR and SPSRs:因为CPSR中有影响指令执行的条件标志: 2.The

ARM:Denver架构会最大限度延展ARM指令集

据国外媒体报道,英伟达近日发布了丹佛(Denver)高性能计算处理器计划,但并未公布具体上市时间. 公司首席执行官Jen-Hsun Huang在本周四的公司财务会议上指出该处理器可进行64位单线程计算,"我们致力于创造能够延展ARM指令集的新架构,不光考虑到高效节能,还要满足我们日益增长的市场的高性能要求.我们一直努力推行丹佛计划,目前计划运行顺利." 丹佛计划是今年1月在消费者电子产品展上首次推出的,英伟达并未具体指明该ARM架构芯片的技术,之前ARM v8架构下64位芯片是10月2

ARM及指令集

   常常能看到ARM7,ARM9,ARM11,以及armv6k等不同的表达.且在GCC编译中,常常要用到 -march, -mcpu等.他们分别表达什么涵义呢?今天就仔细研究一下.   ARM(Advanced RISC Machines)是微处理器行业的一家知名企业.设计了大量高性能.廉价.耗能低的RISC处理器.相关技术及软件.1985年,第一个ARM原型在英国剑桥诞生.ARM公司的特点是只设计芯片,而不生产.ARM将其技术授权给世界上许多著名的半导体.软件和OEM厂商,每个厂商得到的都是

ARM架构

ARM架构(过去称作进阶精简指令集机器(Advanced RISC Machine),更早称作Acorn RISC Machine)是一个32位元精简指令集(RISC) 中央处理器(processor)架构,其广泛地使用在许多嵌入式系统(embedded)设计.由于节能的特点,ARM处理器非常适用于移动通讯领域,符合其主要设计目标为低耗电的特性. 目录 历史 内核种类 内核发展历程 1.发展历程 2.ARM内核与架构对照表 设计文件 Thumb Jazelle Thumb-2 Thumb Exe

iOS逆向工程之Hopper中的ARM指令

虽然前段时间ARM被日本软银收购了,但是科技是无国界的,所以呢ARM相关知识该学的学.现在看ARM指令集还是倍感亲切的,毕竟大学里开了ARM这门课,并且做了不少的实验,当时自我感觉ARM这门课学的还是可以的.虽然当时感觉学这门课以后似乎不怎么用的上,可曾想这不就用上了吗,不过之前学的都差不多忘了,还得捡起来呢.ARM指令集是精简指令集,从名字我们就能看出指令的个数比那些负责指令集要少一些.当然本篇所涉及的ARM指令集是冰山一角,不过也算是基础,可以阅读Hopper中的汇编了,实践出真知,看多了自

ARM相关知识

ARM7采用冯·诺依曼(Von-Neumann)结构,数据存储器和程序存储器重合在一起.    同时,此结构也被大多数计算机所采用. ARM7为三级流水线结构(取指,译码,执行),平均功耗为0.6mW/MHz,时钟速度为66MHz,每条指令平均执行1.9个时钟周期 ARM7系列微处理器包括如下几种类型的核:ARM7TDMI.ARM7TDMI-S. ARM720T.ARM7EJ ARM7采用的Neumann结构,取指令和取操作数都是通过一条总线分时进行,这样,在高速运算时,不但不能同时取指令和取操

Android ARM常用的汇编指令合集

               ARM   处理器的指令集可以分为 跳转指令.数据处理指令.程序状态寄存器(PSR)处理指令.加载/存储指令.协处理器指令和异常产生指令  六大指令,这里把其它几个指令一起发了出来,可以查看具体的目录,请点击头部左上角 一.跳转指令 跳转指令用于实现程序流程的跳转,在ARM程序中有以下两种方法可以实现程序流程的跳转.Ⅰ.使用专门的跳转指令: Ⅱ.直接向程序计数器PC写入跳转地址值,通过向程序计数器PC写入跳转地址值,可以实现在4GB的地址空间中的任意跳转,在跳转之前

arm平台函数传递参数,反汇编实例分析

测试前,需要了解下sysv的传参方式: 1.输入参数通过r0-r3传递,多余的放入堆栈中:返回值放入r0,不够的话放入{r0,r1}或者{r0,r1,r2,r3},比如: int foo(int a, int b, int c, int d), 输入:r0 = a, r1 = b, r2 = c, r3 = d,返回:r0 = 类型为int的retvalue int *foo(char a, double b, int c, char d), 输入:r0 = a, r1用于对齐(double 要

ART世界探险(3) - ARM 64位CPU的架构快餐教程

ART世界探险(3) - ARM 64位CPU的架构快餐教程 前面我们说过,Dalvik如果没有JIT的话,可以做到架构无关,让Dalvik指令都解释执行.但是ART是AOT,要编译成针对芯片具体的机器指令. 所以,研究Dalvik的时候可以不用太关心目标指令,而我们研究ART必须对目前最流行的微处理器的架构有个基本的了解. 在上一讲我们对于ART从java byte code到ARM64 v8指令的整个流程有了一个大概的了解之后,我们就目前最流行的ARM64位芯片的知识进行一些探索. 我们的目