学习 Linux 系统启动流程,必须熟悉几个汇编指令,总结给大家。 这里不是最全的,只列出一些最常用的汇编指令。...二.转移指令 【跳转指令】 B 跳转指令 BL 带返回的跳转指令 BLX 带返回和状态切换的跳转指令 BX 带状态切换的跳转指令 三.程序状态寄存器访问指令 1、【MRS指令】 MRS 通用寄存器...【AREA】 一个汇编程序至少要包含一个段,当程序太长时,也可以将程序分为多个代码段和数据段,因此在汇编程序的开头,我们一般的语句会用到AREA。...ENTRY 伪指令用于指定汇编程序的入口点。...在一个完整的汇编程序中至少要有一个 ENTRY (也可以有多个,当有多个 ENTRY 时,程序的真正入口点由链接器指定),但在一个源文件里最多只能有一个 ENTRY (可以没有)。
汇编指令: JO、JNO、JB、JNB、JE、JNE、JBE、JA、JS、JNS、JP、JNP、JL、JNL、JNG、JG、JCXZ、JECXZ、JMP、JMPE 名称 功能 操作数 操作码 模数 寄存器
ARM汇编指令集 指令与伪指令(汇编) 指令:指令是CPU机器指令的助记符,经过编译后会得到一串10组成的机器码,可以由CPU读取执行。...两种风格 ARM官方的指令风格:指令一般用大写,一般用于Windows的开发环境(ADS,MDK等)如: LDR R0, [R1]。 GNU风格:指令一般用小写字母、linux中常用。...ARM汇编伪指令 伪指令的意义 伪指令不是指令,伪指令和指令的根本区别是经过编译后会不会生成机器码。 伪指令的意义在于指导编译过程。...伪指令是和具体的编译器相关的,我们使用gnu工具链,因此学习gnu环境下的汇编伪指令。 GUN汇编中的一些符号 @ 用来做注释。可以在行首也可以在代码后面同一行直接跟,和C语言中//类似。...点号在gnu汇编中表示当前指令的地址。 # 立即数前面要加#或 $,表示这是个立即数。
80×86指令系统,指令按功能可分为以下七个部分。 (1) 数据传送指令。 (2) 算术运算指令。 (3) 逻辑运算指令。 (4) 串操作指令。 (5) 控制转移指令。 ...(6) 处理器控制指令。 (7) 保护方式指令。 3.3.1数据传送指令 数据传送指令包括:通用数据传送指令、地址传送指令、标志寄存器传送指令、符号扩展指令、扩展传送指令等。 ...一、通用数据传送指令 1传送指令 传送指令是使用最频繁的指令,格式:MOV DEST,SRC 功能:把一个字节,字或双字从源操作数SRC传送至目的操作数DEST。 ...移位指令分一般移位指令和循环移位指令。 1一般移位指令 (1) 算术/逻辑左移指令。 ...例 3.56 JMP NEXT NEXT:MOV AL,BL 本例为无条件转移到本段内,标号为NEXT的地址去执行指令,汇编程序可以确定目的地址与JMP指令的距离。
汇编语言特点:与机器相关,执行效率高,调试复杂 汇编语言优缺点:汇编语言和高级语言混合编写,互补 数据表示类型:二进制B,八进制Q,十进制D,十六进制H BCD编码:用二进制来表示十进制数 CPU...(处理器每执行一条指令便产生一个内部中断,可以对程序进行单步调试) 16位汇编物理地址与逻辑地址转换:逻辑地址<< 4位 + 偏移 = 物理地址(可以有多个逻辑地址) CS(代码段),表示代码段的起始地址...,[BX(BP)+SI] 相对基址变址寻址,mov AX,[BX+SI+05] 段内转移也称近转移(near ptr) 段内转移也称短转移(short) 段间转移也称远转移(far ptr) 8086汇编指令...[ASM]8088汇编指令 一、数据传输指令 ─────────────────────────────────────── 它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据. 1....输入输出端口传送指令.
str -(Store Register)存储指令 格式: str{条件} 源寄存器, 将源寄存器中数据存到存储器地址中。 ...中的值存到r2+4所指定的地址中 str r1,[r2],#4 ;将r1中的值存到r2所指定的地址中, 同时r2=r2+4 实例2(以u-boot中lowlevel_init函数的一段代码说明str指令的用法
移位指令包括了 算术移位指令、逻辑移位指令、循环移位指令。 格式为:xxx oper1,CL/1 ;移位次数只能是1或者存放在CL里面。...一、算术移位指令 1、算术左移指令SAL 功能:左移一次,最低位补0,最高位送入CF标志位,如图: 意义:左移n次,等于x2的n次幂。所以可用于有符号操作数做x2的n次幂运算。...2、算术右移指令SAR 功能:右移一次,最高位保持不变,最低位送入CF标志位,如图: 意义:右移n次,等于/2的n次幂。所以可用于有符号操作数做/2的n次幂运算。...二、逻辑移位指令 1、逻辑左移SHL 功能:同SAL,如图: 意义:同SAL 2.逻辑右移SHR 功能:右移一次,最高位补0.区别!最低位送入CF标志位。...三.循环移位指令 1.循环左移指令ROL 功能:左移一次,左移前的最高位送入最低位以及CF.如图: 2.循环右移指令ROR 功能:右移一次,右移前的最低位送入最高位以及CF.如图: 3、带进位的循环左移
汇编知识扫盲之常见汇编指令 一、数据传输指令 它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据. 1. 通用数据传送指令. ....CPU执行到这条指令的时候会待机.所以这个指令只为填充字节. 2....输入输出端口传送指令. ...五、程序转移指令 1>无条件转移指令 (长转移) JMP 无条件转移指令 CALL 过程调用 RET/RETF过程返回. 2>条件转移指令 (短转移,-128到+127...JECXZ ECX为零时转移. 4>中断指令 INT 中断指令 INTO 溢出中断 IRET 中断返回 5>处理器控制指令 HLT 处理器暂停,
中断指令 INT 中断指令 INTO 溢出中断 IRET 中断返回 5....END 程序结束. ——————————— 七、处理机控制指令:标志处理指令 ——————————— CLC 进位位置0指令 CMC 进位位求反指令...STC 进位位置为1指令 CLD 方向标志置1指令 STD 方向标志位置1指令 CLI 中断标志置0指令 STI...====================== 浮点运算指令集======================== ———– 一、控制指令(带9B的控制指令前缀F变为FN时浮点不检查,机器码去掉9B)———-...00 四舍五入 01 向负无限大舍入 10 向正无限大舍入 11 向零舍去 ---- Reference: x86汇编指令集大全(带注释) – 17岁boy
今天我们来说一下arm的汇编指令和伪指令。 一、指令和伪指令 我们首先来了解一下什么叫做指令和伪指令。 指令是CPU机器指令的助记符,经过编译后会得到一串10组成的机器码,可以由CPU读取执行。...arm汇编有两种风格,ARM官方的ARM汇编风格:指令一般用大写、Windows中IDE开发环境(如ADS、MDK等)常用。如:LDR R0, [R1]。...GNU风格的ARM汇编:指令一般用小写字母、linux中常用。如:ldr r0, [r1]。 二、arm汇编特点 ARM汇编特点1:LDR/STR架构。..., {r2-r7,lr} 相对寻址 beqflag ARM汇编特点3:指令后缀。同一指令经常附带不同后缀,变成不同的指令。...那么arm汇编指令就暂时介绍这几个,接下来介绍几个伪指令。 伪指令不是指令,伪指令和指令的根本区别是经过编译后会不会生成机器码。伪指令的意义在于指导编译过程。
cmp:(compare)指令进行比较两个操作数的大小 格式: cmp oprd1,oprd2 比较oprd1和oprd2操作数,然后通过助记符来实现想要的判断。...teq: (test equal)测试相等,该指令通常用于比较操作数1和操作数2是否相等。 ...格式: teq oprd1,oprd2 TEQ指令用于把一个寄存器的内容和另一个寄存器的内容或立即数进行按位的异或运算,并根据运算结果更新CPSR中条件标志位的值。...该指令通常用于比较操作数1和操作数2是否相等。(EOR指令也是实现异或运算,只是不更新CPSR) cmp和teq助记符如下 ? ?
: inc bx inc bx 指令执行前: bx=1000H; 指令执行后: bx=0002H; (4)再看第七条指令:mov [bx],ax, 指令执行前: ds=2000H,bx=1002H...Loop指令 这个指令和循环有关; 1、指令的格式是:loop 标号,CPU 执行 loop 指令的时候,要进行两步操作: (cx)=(cx)-1; 判断 cx 中的值,若不为零,则转至标号处执行;程序若为零...add ax,ax loop s mov ax,4c00h int 21h code ends end 分析: (1)标号:在汇编语言中,标号代表一个地址,此程序中有一个标号 s...Debug 中跟踪供 loop 指令实现的循环程序 注意:在汇编程序中,数据不能以字母开头,如果要输入像 FFFFH 这样的数,则要在前面添加一个0; 在 debug 程序中引入 G 命令和 P 命令:...直到程序结束; G命令后面如果带参数,则执行到 ip 为那个参数地址停止; P命令 T命令相当于单步进入(step into); P命令相当于单步通过(step over); Debug 和汇编编译器
指令 功能 AAA 调整加 AAD 调整除 AAM 调整乘 AAS 调整减 ADC 进位加 ADD 加 AND 与 ARPL 调整优先级 BOUND 检查数组 BSF 位右扫描 BSR 位左扫描 BSWAP...保存双字串 STOSW 保存字串 STR 保存任务 SUB 减 SYSCALL 系统调用 SYSENTER 系统进入 SYSEXIT 系统退出 SYSRET 系统返回 TEST 数测试 UD0 未定义指令...0 UD1 未定义指令1 UD2 未定义指令2 UMOV VERW 校验写 WAIT 等 WBINVD 回写无效高速缓存 WRMSR 写专用模式 WRSHR XADD 交换加 XBTS XCHG...交换 XLAT 换码 XOR 异或 XSTORE ---- 指令 功能 EMMS 媒体空MMX状态 F2XM1 浮点栈顶绝对值 FADD 浮点加 FADDP 浮点加出栈 FBLD 浮点加载十数 FBSTP...PUNPCKHWD 媒体字高位解压 PUNPCKLBW 媒体字节低位解压 PUNPCKLDQ 媒体双字低位解压 PUNPCKLWD 媒体字低位解压 ---- Delphi 2010 VCL、JCL 源码中用到的汇编指令
在根本上,将cs,ip寄存器所指向的内存当做代码,指令转移就是修改cs,ip寄存器的指向,汇编中提供了一种修改它们的指令——jmp。...jmp指令可以修改IP或cs和IP的值来实现指令转移,指令格式为:”jmp 标号“将指令转移到标号处,例如: CODES SEGMENT ASSUME CS:CODES START:...jmp s所对应的机器码为”EB01”,在“Inc ax”后面再加其他的指令(加两个 nop指令)此时jmp所对应的机器码为”EB03”,每一个nop指令占一个字节,在添加或删除它们之间的代码可以看到jmp...指令所对应的机器码占两个字节,第一个字节的机器码并不发生改变,改变的是第二个字节的内容,并且第二个字节的内容存储的是跳转目标指令所在内存与jmp指令所在内存之间的位移。...其实cup在执行jmp指令时并不会记录标号所在的内存地址,而是通过标号与jmp指令之间的位移,假设jmp指令的下一条指令的地址为org,位移为idata,则目标的内存地址为dec = org + idata
cmp:(compare)指令进行比较两个操作数的大小 格式: cmp oprd1,oprd2 比较oprd1和oprd2操作数,然后通过助记符来实现想要的判断。...teq: (test equal)测试相等,该指令通常用于比较操作数1和操作数2是否相等。...格式: teq oprd1,oprd2 TEQ指令用于把一个寄存器的内容和另一个寄存器的内容或立即数进行按位的异或运算,并根据运算结果更新CPSR中条件标志位的值。...该指令通常用于比较操作数1和操作数2是否相等。...(EOR指令也是实现异或运算,只是不更新CPSR) cmp和teq助记符如下 助记符 含 义 EQ 相等equal NE 不相等not equal CS 无符号数大于或等于Carry Set CC
POP 堆栈操作指令 PUSH和POP 格式: PUSH OPRD POP OPRD 功能: 实现压入操作的指令是PUSH指令;实现弹出操作的指令是POP指令....PUSH 堆栈操作指令 PUSH和POP 格式: PUSH OPRD POP OPRD 功能: 实现压入操作的指令是PUSH指令;实现弹出操作的指令是POP指令....指令中不使用操作数时,可用指令格式SCASB,SCASW,分别表示字节串或字串搜索指令....指令中不使用操作数时,可用指令格式SCASB,SCASW,分别表示字节串或字串搜索指令....指令中不使用操作数时,可用指令格式SCASB,SCASW,分别表示字节串或字串搜索指令.
adr r0, _start ldr r0, =_start nop mov pc, lr _start: nop 得出以下汇编...0C008000): 0c008000 : c008000: e59f000c ldr r0, [pc, #12] ; c008014 //ldr指令...(不带=) : r0= c008014里面内容= e1a00000 c008004: e28f0008 add r0, pc, #8 ; 0x8 //adr指令: r0=...(当前PC值+8)+0x8=c008014 c008008: e59f0008 ldr r0, [pc, #8] ; c008018 //ldr指令(带=) : ...看上去这只是一个指令,但是它要占用 2 个 32bit 的空间,一条是指令,另一条是 _start 的数据(因为在编译的时候不能确定 _start 的值,而且也不能用 mov 指令来给 r0 赋一个 32bit
markdown不能合并表格真麻烦。还得先用exel打好。
16位汇编第九讲汇编指令以及逆向中的花指令 一丶LOOP指令(循环指令) 作用: 循环指令利用cx计数器自动减1,方便实现计数循环的程序结构...返回指令回到主程序继续执行 如果懂C语言或者别的更高级的语言的请看 这个其实就是函数,为了代码的重用性,可利用性研究出来的,否则汇编代码一多就会很乱,比如有效的管理代码 比如ret指令,其实就是平衡栈的...四丶花指令 请看下面的汇编代码 ?...我们发现jmp的地方下面申请了一个字节,但是在汇编的时候,这1个字节和mov的机器码在一起了 因而产生的汇编代码就出错了,花指令混淆就是这样,这段代码还是可以正常执行的 对抗手法 1.如果是动态的调试,...那么花指令是没用的(动态调试就是一步一步走)为什么,因为为了保证汇编代码不出错 每走一次代码都会重新反汇编 2.花指令主要对抗的是静态调试,因为病毒是不能运行的,只能看二进制和汇编,这个时候怎么办 我们发现了
本文参考了马维华老师的《微机原理与接口技术》一书 指令格式: MUL REG/MEM ;REG寄存器,MEM存储器 IMUL REG/MEM MUL和IMUL指令分别用于实现无符号数的乘法和有符号数的乘法运算...1)MUL指令 (a)、字节乘法,则AL×REG8/MEM8,乘积存于AX中。...2)IMUL指令 IMUL指令除了是完成两个有符号数的相乘以外,其他与MUL完全类似。 注:由于乘法指令为乘积保留了两倍于原来操作数的存储空间,因而不会出现溢出。
领取专属 10元无门槛券
手把手带您无忧上云