汇编中的寄存器
来源:互联网 发布:网络赚钱入门必读pdf 编辑:程序博客网 时间:2024/05/13 10:27
1.通用寄存器:EAX,EBX,ECX,EDX,ESI,EDI,EBP,ESP(一般作为堆栈指针)
这些寄存器的默认功能:
EAX 是"累加器"(accumulator), 它是很多加法乘法指令的缺省寄存器,函数的返回值经常被放在EAX中.
EBX 是"基地址"(base)寄存器, 在内存寻址时存放基地址
ECX 是计数器(counter), 是重复(REP)前缀指令和LOOP指令的内定计数器.
EDX 它总是被用来放整数除法产生的余数.
这4个寄存器的低16位可以被单独访问,分别用AX,BX,CX和DX. AX又可以单独访问低8位(AL)和高8位(AH),
BX,CX,DX也类似
ESI/EDI分别叫做"源/目标索引寄存器"(source/destination index),因为在很多字符串操作指令中, DS:ESI指向源串,而ES:EDI指向目标串
EBP是"基址指针"(BASE POINTER), 它最经常被用作高级语言函数调用的"框架指针"(frame pointer). 在函数调用中生成的汇编指令中,经常可以看见一个标准的函数起始代码:
push ebp ;保存当前ebp
mov ebp,esp ;EBP设为当前堆栈指针
sub esp, xxx ;预留xxx字节给函数临时变量.
此时EBP 构成了该函数的一个框架, 在EBP上方分别是原来的EBP, 返回地址和参数. EBP下方则是临时变量.
函数返回时作 mov esp,ebp/pop ebp/ret 即可
ESP 专门用作堆栈指针
2.段寄存器:
CS(Code Segment,代码段) 指定当前执行的代码段.
EIP (Instruction pointer, 指令指针)则指向该段中一个具体的指令.
CS:EIP指向哪个指令, CPU 就执行它.
一般只能用jmp, ret, jnz, call 等指令来改变程序流程,而不能直接对它们赋值.
DS(DATA SEGMENT, 数据段) 指定一个数据段.
注意:在当前的计算机系统中, 代码和数据没有本质差别, 都是一串二进制数, 区别只在于你如何用它.
CS 指定的段总是被用作代码, 一般不能通过CS指定的地址去修改该段.然而,你可以为同一个段申请一个
数据段描述符"别名"而通过DS来访问/修改. 自修改代码的程序常如此做.
ES,FS,GS 是辅助的段寄存器, 指定附加的数据段.
SS(STACK SEGMENT)指定当前堆栈段.
ESP 则指出该段中当前的堆栈顶. 所有push/pop 系列指令都只对SS:ESP指出的地址进行操作.
3.标志寄存器
该寄存器有32位,组合了各个系统标志.
EFLAGS一般不作为整体访问, 而只对单一的标志位感兴趣.
常用的标志有:
进位标志C(CARRY), 在加法产生进位或减法有借位时置1, 否则为0.
零标志Z(ZERO), 若运算结果为0则置1, 否则为0
符号位S(SIGN), 若运算结果的最高位置1, 则该位也置1.
溢出标志O(OVERFLOW), 若(带符号)运算结果超出可表示范围, 则置1.
JXX 系列指令就是根据这些标志来决定是否要跳转, 从而实现条件分枝.
要注意,很多JXX 指令是等价的, 对应相同的机器码.
例如, JE 和JZ 是一样的,都是当Z=1是跳转.
只有JMP 是无条件跳转.
JXX 指令分为两组, 分别用于无符号操作和带符号操作.
JXX 后面的"XX" 有如下字母:
无符号操作: 带符号操作:
A = "ABOVE", 表示"高于" G = "GREATER", 表示"大于"
B = "BELOW", 表示"低于" L = "LESS", 表示"小于"
通用符号: E = "EQUAL" 表示"等于", 等价于Z (ZERO)
N = "NOT" 表示"非", 即标志没有置位.
4. 端口 端口是直接和外部设备通讯的地方。外设接入系统后,系统就会把外设的数据接口映射到特定的
端口地址空间,这样,从该端口读入数据就是从外设读入数据,而向外设写入数据就是向端口写入数据。
当然这一切都必须遵循外设的工作方式。端口的地址空间与内存地址空间无关,系统总共提供对64K个8位
端口的访问,编号0-65535. 相邻的8位端口可以组成成一个16位端口,相邻的16位端口可以组成一个32位
端口。端口输入输出由指令IN,OUT,INS和OUTS实现
参考文章:http://blog.csdn.net/jiangredsheep/article/details/318072
- 汇编中的寄存器说明
- 汇编中的寄存器说明
- 汇编中的寄存器
- 汇编中的寄存器
- 汇编中的寄存器
- 汇编中的寄存器
- p217 8086汇编FLAG寄存器中的OF标志 | 8086汇编标志寄存器 | 标志寄存器OF标志
- 汇编中的函数调用与寄存器
- 汇编中的所有寄存器类型与作用
- 汇编中的所有寄存器类型与作用
- 汇编寄存器
- 汇编寄存器
- 汇编寄存器
- 汇编寄存器
- 汇编 寄存器
- 汇编-寄存器
- (2011.10.20) 汇编知识:CPU中的寄存器知识整理
- MIPS汇编:协处理器CP0中的寄存器的功能
- Open vSwitch Q&A
- 《Unix & Linux 大学教程》 - 第十一、十二章 学习笔记
- 查看Oracle当前用户下的信息(用户,表视图,索引,表空间,同义词,存储过程函数,约束条件)
- OpenGL中设置颜色到底应该用小数还是整数?
- 旧上海黑社会老大杜月笙的名言 蛮有道理
- 汇编中的寄存器
- Java面向接口编程与多态的示例学习
- HDOJ2109
- 推荐8个IT类网站
- memcached源码学习-hashtable
- WPF idle
- linux c++ socket入门之tcp server端
- API级别
- OJDBC版本介绍