cpu中都有哪些寄存器资源,他们的初始值分别是多少

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了cpu中都有哪些寄存器资源,他们的初始值分别是多少相关的知识,希望对你有一定的参考价值。

参考技术A 寄存器是CPU内部重要的数据存储资源,是汇编程序员能直接使用的硬件资源之一。
由于寄存器的存取速度比内存快,所以,在用汇编语言编写程序时,要尽可能充分利用寄存器的存储功能。
寄存器一般用来保存程序的中间结果,为随后的指令快速提供操作数,从而避免把中间结果存入内存,再读取内存的操作。在高级语言(如:C/C++语言)中,也有定义变量为寄存器类型的,这就是提高寄存器利用率的一种可行的方法。

另外,由于寄存器的个数和容量都有限,不可能把所有中间结果都存储在寄存器中,所以,要对寄存器进行适当的调度。根据指令的要求,如何安排适当的寄存器,避免操作数过多的传送操作是一项细致而又周密的工作。
有关“寄存器的分配策略”在《编译原理》中会有详细的介绍。
1、 16位寄存器组

16位CPU所含有的寄存器有(见图2.1中16位寄存器部分):

4个数据寄存器(AX、BX、CX和DX)
2个变址和指针寄存器(SI和DI) 2个指针寄存器(SP和BP)
4个段寄存器(ES、CS、SS和DS)
1个指令指针寄存器(IP) 1个标志寄存器(Flags)

2、 32位寄存器组

32位CPU除了包含了先前CPU的所有寄存器,并把通用寄存器、指令指针和标志寄存器从16位扩充成32位之外,还增加了2个16位的段寄存器:FS和GS。

32位CPU所含有的寄存器有(见图2.1中的寄存器):

4个数据寄存器(EAX、EBX、ECX和EDX)
2个变址和指针寄存器(ESI和EDI) 2个指针寄存器(ESP和EBP)
6个段寄存器(ES、CS、SS、DS、FS和GS)
1个指令指针寄存器(EIP) 1个标志寄存器(EFlags)

8086CPU复位后,内容不为0的寄存器都有哪些?系统的初始地址是啥?

参考技术A 8086CPU复位后,(CS)=FFFFH,其余各寄存器的状态均为0。
要看得看你的复位是用什么实现的。如果是硬件实现的话,第一条cpu的指令的起始地址在rom,如果是软件实现的话,你的软件复位是针对cpu还是整个系统,如果是针对cpu复位,那第一条指令的起始地址可能是ram,如果是对整个系统复位,那第一条cpu的指令的起始地址在rom。
参考技术B Reset引脚上为高电平时,引起cpu复位,复位后cpu内部的段寄存器,标志寄存器,指令指针ip及指令队列都将被清零,只有段寄存器cs被设置为FFFFH。一旦复位完成,cpu将从CS:IP值为FFFFH:0000H,即物理地址为0FFFF0H的地址开始执行程序。

以上是关于cpu中都有哪些寄存器资源,他们的初始值分别是多少的主要内容,如果未能解决你的问题,请参考以下文章

通用寄存器都有哪些?

在Linux中都有哪些工具可以查看存储在内存的“进程中的数据结构”?

8086寄存器初始值是多少

CPU的功能部件都有哪些?

X86指令集的内容都有哪些?

常用的BIM引擎都有哪些,分别有啥优劣?