Almacenamiento de trabajo de acceso rápido disponible como parte de un procesador digital
Un registro de procesador es una ubicación de rápido acceso disponible para el procesador de una computadora . [1] Los registros generalmente constan de una pequeña cantidad de almacenamiento rápido , aunque algunos registros tienen funciones de hardware específicas y pueden ser de solo lectura o de solo escritura. En la arquitectura de computadoras , los registros generalmente se abordan mediante mecanismos distintos a la memoria principal , pero en algunos casos se les puede asignar una dirección de memoria , por ejemplo, DEC PDP-10 , ICT 1900 . [2]
Casi todas las computadoras, ya sea con arquitectura de carga/almacenamiento o no, cargan elementos de datos desde una memoria más grande en registros donde se usan para operaciones aritméticas , operaciones bit a bit y otras operaciones, y son manipulados o probados mediante instrucciones de máquina . Los elementos manipulados a menudo se almacenan en la memoria principal, ya sea mediante la misma instrucción o mediante una posterior. Los procesadores modernos utilizan RAM estática o dinámica como memoria principal, a la que normalmente se accede a través de uno o más niveles de caché .
Los registros del procesador normalmente se encuentran en la parte superior de la jerarquía de la memoria y proporcionan la forma más rápida de acceder a los datos. El término normalmente se refiere sólo al grupo de registros que están codificados directamente como parte de una instrucción, según lo definido por el conjunto de instrucciones . Sin embargo, las CPU modernas de alto rendimiento a menudo tienen duplicados de estos "registros arquitectónicos" para mejorar el rendimiento mediante el cambio de nombre de los registros , lo que permite la ejecución paralela y especulativa . El diseño x86 moderno adquirió estas técnicas alrededor de 1995 con los lanzamientos de Pentium Pro , Cyrix 6x86 , Nx586 y AMD K5 .
Los registros normalmente se miden por la cantidad de bits que pueden contener, por ejemplo, un " registro de 8 bits ", un " registro de 32 bits ", un " registro de 64 bits " o incluso más. En algunos conjuntos de instrucciones , los registros pueden operar en varios modos, dividiendo su memoria de almacenamiento en partes más pequeñas (de 32 bits en cuatro de 8 bits, por ejemplo) a las que se agregan múltiples datos (vectoriales o una matriz unidimensional de datos). Se puede cargar y operar al mismo tiempo. Normalmente se implementa agregando registros adicionales que asignan su memoria a un registro más grande. Los procesadores que tienen la capacidad de ejecutar instrucciones únicas sobre múltiples datos se denominan procesadores vectoriales .
Tipos
Un procesador suele contener varios tipos de registros, que se pueden clasificar según los tipos de valores que pueden almacenar o las instrucciones que operan sobre ellos:
Los registros accesibles al usuario se pueden leer o escribir mediante instrucciones de la máquina. La división más común de los registros accesibles al usuario es una división en registros de datos y registros de direcciones.
Los registros de direcciones contienendireccionesy son utilizados por instrucciones que acceden indirectamenteala memoria primaria.
Algunos procesadores contienen registros que solo pueden usarse para contener una dirección o solo para contener valores numéricos (en algunos casos se usan como un registro de índice cuyo valor se agrega como un desplazamiento de alguna dirección); otros permiten que los registros contengan cualquier tipo de cantidad. Existe una amplia variedad de posibles modos de direccionamiento , utilizados para especificar la dirección efectiva de un operando.
Registros de propósito general (Los GPR s) pueden almacenar tanto datos como direcciones, es decir, son registros combinados de datos/direcciones; En algunas arquitecturas, elarchivo de registroestáunificadopara que los GPR también puedan almacenar números de punto flotante.
Los registros de punto flotante (FPR) almacenan números de punto flotante en muchas arquitecturas.
Los registros constantes contienen valores de solo lectura como cero, uno opi.
Los registros vectoriales contienen datos parael procesamiento de vectoresrealizado medianteSIMD(Instrucción única, datos múltiples).
Los registros de propósito especial ( SPR ) contienen algunos elementos del estado del programa ; suelen incluir el contador de programa , también llamado puntero de instrucción, y el registro de estado ; el contador de programa y el registro de estado pueden combinarse en un registro de palabra de estado de programa (PSW). El puntero de pila antes mencionado a veces también se incluye en este grupo. Los microprocesadores integrados también pueden tener registros correspondientes a elementos de hardware especializados.
Los registros específicos del modelo (también llamadosregistros específicos de la máquina) almacenan datos y configuraciones relacionados con el propio procesador. Debido a que sus significados están ligados al diseño de un procesador específico, no se espera que sigan siendo estándar entre generaciones de procesadores.
Registros arquitectonicosSon los registros visibles para el software y están definidos por una arquitectura. Es posible que no se correspondan con el hardware físico si el cambio de nombre de los registros lo realiza el hardware subyacente.
En algunas arquitecturas (como SPARC y MIPS ), el primer o último registro en el archivo de registro de enteros es un pseudo-registro en el sentido de que está programado para devolver siempre cero cuando se lee (principalmente para simplificar los modos de indexación) y no se puede sobrescribir. . En Alpha , esto también se hace para el archivo de registro de punto flotante. Como resultado de esto, se suele decir que los archivos de registro tienen un registro más que el número de ellos que realmente se pueden utilizar; por ejemplo, se citan 32 registros cuando sólo 31 de ellos encajan dentro de la definición anterior de registro.
Ejemplos
La siguiente tabla muestra la cantidad de registros en varias arquitecturas de CPU convencionales. Tenga en cuenta que en los procesadores compatibles con x86 , el puntero de pila ( ESP) se cuenta como un registro entero, aunque hay un número limitado de instrucciones que pueden usarse para operar con su contenido. Se aplican advertencias similares a la mayoría de las arquitecturas.
La cantidad de registros disponibles en un procesador y las operaciones que se pueden realizar usando esos registros tienen un impacto significativo en la eficiencia del código generado mediante la optimización de los compiladores . El número de Strahler de un árbol de expresión proporciona el número mínimo de registros necesarios para evaluar ese árbol de expresión.
^ "¿Qué es un registro de procesador?". Educativo: Cursos interactivos para desarrolladores de software . Consultado el 12 de agosto de 2022 .
^ "Un estudio de técnicas para diseñar y gestionar archivos de registro de CPU".
^ "Manual de referencia del hardware del sistema informático Cray-1" (PDF) . Investigación de Cray . Noviembre de 1977. Archivado (PDF) desde el original el 7 de noviembre de 2021 . Consultado el 23 de diciembre de 2022 .
^ "Manual de usuario del microordenador MCS-4" (PDF) . Intel. Febrero de 1973.
^ "Manual de usuario de la unidad de procesador central paralelo 8008 de 8 bits" (PDF) . Intel. Noviembre de 1973 . Consultado el 23 de enero de 2014 .
^ "Manual del usuario de los sistemas de microcomputadora Intel 8080" (PDF) . Intel. Septiembre de 1975 . Consultado el 23 de enero de 2014 .
^ "Manual de referencia del programador 80286 y 80287" (PDF) . Intel. 1987.
^ ab "Manuales para desarrolladores de software de arquitecturas Intel 64 e IA-32". Intel. 4 de diciembre de 2019.
^ "Manual del programador de arquitectura AMD64 Volumen 1: Programación de aplicaciones" (PDF) . AMD . Octubre de 2013.
^ "Referencia de programación de funciones futuras y extensiones del conjunto de instrucciones de la arquitectura Intel" (PDF) . Intel . Enero de 2018.
^ Guía de programación F8 (PDF) . División de microcomputadoras Fairchild MOS. 1977.
^ "Guía de referencia del procesador Nios II Classic" (PDF) . Altera . 2 de abril de 2015.
^ "Guía de referencia del procesador Nios II Gen2" (PDF) . Altera. 2 de abril de 2015.
^ "Manual de referencia de programación del M6800" (PDF) . Motorola . Noviembre de 1976 . Consultado el 18 de mayo de 2015 .
^ "Manual de referencia del programador familiar Motorola M68000" (PDF) . Motorola. 1992 . Consultado el 13 de junio de 2015 .
^ "Guía de programación CUDA C". NVIDIA. 2019 . Consultado el 9 de enero de 2020 .
^ Jia, Zhe; Maggioni, Marco; Staiger, Benjamín; Scarpazza, Daniele P. (2018). "Disección de la arquitectura de la GPU NVIDIA Volta mediante microbenchmarking". arXiv : 1804.06826 [cs.DC].
^ "IBM Enterprise Systems Architecture/370 y System/370 - Operaciones vectoriales" (PDF) . IBM. SA22-7125-3 . Consultado el 11 de mayo de 2020 .
^ "Arquitectura del conjunto de instrucciones de la unidad de procesador sinérgico versión 1.2" (PDF) . IBM. 27 de enero de 2007.
^ "Asamblea de aprendizaje 65816". Wiki de desarrollo de Super Famicom . Consultado el 14 de noviembre de 2019 .
^ "Estándar de llamada de procedimiento para la arquitectura ARM" (PDF) . Participaciones ARM . 30 de noviembre de 2013 . Consultado el 27 de mayo de 2013 .
^ "2.6.2. Conjunto de registros de estado del pulgar". Manual de referencia técnica ARM7TDMI . Participaciones ARM .
^ "Estándar de llamada de procedimiento para la arquitectura ARM de 64 bits" (PDF) . Participaciones ARM. 22 de mayo de 2013 . Consultado el 27 de mayo de 2013 .
^ "Referencia de la arquitectura de la Epifanía" (PDF) .