80386registers
来源:互联网 发布:python commands模块 编辑:程序博客网 时间:2024/06/05 09:53
寄存器(Register)是CPU内部的元件,所以在寄存器之间的数据传送非常快。用途:1.可将寄存器内的数据执行算术及逻辑运算。2.存于寄存器内的地址可用来指向内存的某个位置,即寻址。3.可以用来读写数据到电脑的周边设备。8086 有8个8位数据寄存器,这些8位寄存器可分别组成16位寄存器:AH&AL=AX:累加寄存器,常用于运算;BH&BL=BX:基址寄存器,常用于地址索引;CH&CL=CX:计数寄存器,常用于计数;DH&DL=DX:数据寄存器,常用于数据传递。为了运用所有的内存空间,8086设定了四个段寄存器,专门用来保存段地址:CS(Code Segment):代码段寄存器;DS(Data Segment):数据段寄存器;SS(Stack Segment):堆栈段寄存器;ES(Extra Segment):附加段寄存器。当一个程序要执行时,就要决定程序代码、数据和堆栈各要用到内存的哪些位置,通过设定段寄存器 CS,DS,SS 来指向这些起始位置。通常是将DS固定,而根据需要修改CS。所以,程序可以在可寻址空间小于64K的情况下被写成任意大小。 所以,程序和其数据组合起来的大小,限制在DS 所指的64K内,这就是COM文件不得大于64K的原因。8086以内存做为战场,用寄存器做为军事基地,以加速工作。除了前面所提的寄存器外,还有一些特殊功能的寄存器:IP(Intruction Pointer):指令指针寄存器,与CS配合使用,可跟踪程序的执行过程;SP(Stack Pointer):堆栈指针,与SS配合使用,可指向目前的堆栈位置。BP(Base Pointer):基址指针寄存器,可用作SS的一个相对基址位置;SI(Source Index):源变址寄存器可用来存放相对于DS段之源变址指针;DI(Destination Index):目的变址寄存器,可用来存放相对于 ES 段之目的变址指针。还有一个标志寄存器FR(Flag Register),有九个有意义的标志(
OF: 溢出标志位OF用于反映有符号数加减运算所得结果是否溢出。如果运算结果超过当前运算位数所能表示的范围,则称为溢出,OF的值被置为1,否则,OF的值被清为0.
DF: 方向标志DF位用来决定在串操作指令执行时有关指针寄存器发生调整的方向。
IF: 中断允许标志IF位用来决定CPU是否响应CPU外部的可屏蔽中断发出的中断请求。但不管该标志为何值,CPU都必须响应CPU外部的不可屏蔽中断所发出的中断请求,以及CPU内部产生的中断请求。具体规定如下:
(1)、当IF=1时,CPU可以响应CPU外部的可屏蔽中断发出的中断请求;
(2)、当IF=0时,CPU不响应CPU外部的可屏蔽中断发出的中断请求。
TF: 状态控制标志位是用来控制CPU操作的,它们要通过专门的指令才能使之发生改变
SF: 符号标志SF用来反映运算结果的符号位,它与运算结果的最高位相同。在微机系统中,有符号数采用补码表示法,所以,SF也就反映运算结果的正负号。运算结果为正数时,SF的值为0,否则其值为1。
ZF: 零标志ZF用来反映运算结果是否为0。如果运算结果为0,则其值为1,否则其值为0。在判断运算结果是否为0时,可使用此标志位。
AF: 下列情况下,辅助进位标志AF的值被置为1,否则其值为0:
(1)、在字操作时,发生低字节向高字节进位或借位时;
(2)、在字节操作时,发生低4位向高4位进位或借位时。
PF: 奇偶标志PF用于反映运算结果中“1”的个数的奇偶性。如果“1”的个数为偶数,则PF的值为1,否则其值为0。
CF: 进位标志CF主要用来反映运算是否产生进位或借位。如果运算结果的最高位产生了一个进位或借位,那么,其值为1,否则其值为0。)
32位x86 CPU段寄存器除原有的4个外:CS∕SS∕DS∕ES,还增加了两个用于数据段的段寄存器:FS∕GS;为了与8086保持兼容,段寄存器的长度未变,还是16位。
DS段寄存器指向程序中的主要数据段,它也是除访问堆栈外的其他存储器数据所使用的默认段寄存器。某些串操作指令总是使用ES段寄存器作为目的操作数的段寄存器。
对于32位微处理器来说,其通用寄存器自然应该是32位的:EAX∕EBX∕ECX∕EDX∕ESI∕EDI∕EBP∕ESP,它们是原8个16位寄存器的扩展。同时,它们也支持原来的8∕16位操作,其命名也与原来相同。
- 80386registers
- [CUJ] Debugging With The 80386 Hardware Debug Registers
- x86 Registers
- CPU Registers
- ARM registers
- Smali Registers
- VIM Registers
- x86 Registers
- Shift registers
- HLSL Registers
- 80x86 Registers
- C51 Parameters and Registers
- vim Multiple Registers
- Smali语法:Registers(寄存器)
- Smali语法:Registers(寄存器)
- x86 Registers and Architecture
- Registers and Processor Modes
- PTX ISA Special Registers
- 找工作第二天
- 高性能的通讯库-ZeroMQ的几个高性能特征
- 16 利用scipy.misc等库对jpg以及png等图像数据预处理(用于深度学习喂数据)
- SQLserver中用convert函数转换日期格式
- Thymeleaf设置特定属性
- 80386registers
- [Git]本地代码上传到github
- java swing 组件初探
- B. Code For 1
- ZeroMQ阅读笔记
- 静态(static)成员的继承
- HDU 4861 Couple doubi
- 暂时告别C#的学习,开时Java入门,以后,定时定点做笔记
- SqlServer 行转列函数pivot