stringtranslate.com

Registro del procesador

Una descripción de nivel de transferencia de registro (RTL) de un registro de 8 bits con implementación detallada, que muestra cómo se pueden almacenar 8 bits de datos mediante el uso de flip-flops .

Un registro de procesador es una ubicación de acceso rápido disponible para el procesador de una computadora . [1] Los registros generalmente consisten en una pequeña cantidad de almacenamiento rápido , aunque algunos registros tienen funciones de hardware específicas y pueden ser de solo lectura o solo escritura. En la arquitectura de computadoras , los registros generalmente se direccionan 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 que tengan 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 por instrucciones de máquina . Los elementos manipulados luego suelen almacenarse nuevamente en la memoria principal, ya sea por la misma instrucción o por una posterior. Los procesadores modernos usan RAM estática o dinámica como memoria principal, y a esta última generalmente 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 memoria y proporcionan la forma más rápida de acceder a los datos. El término normalmente se refiere solo 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 .

Cuando un programa informático accede a los mismos datos repetidamente, se habla de localidad de referencia . Mantener valores utilizados con frecuencia en registros puede ser fundamental para el rendimiento de un programa. La asignación de registros la realiza un compilador en la fase de generación de código o un programador en lenguaje ensamblador de forma manual .

Tamaño

Los registros se miden normalmente por el número de bits que pueden almacenar, por ejemplo, un " registro de 8 bits ", " registro de 32 bits ", " 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 (32 bits en cuatro de 8 bits, por ejemplo) en las que se pueden cargar y operar múltiples datos (vector o matriz unidimensional de datos) al mismo tiempo. Por lo general, se implementa agregando registros adicionales que mapean su memoria en un registro más grande. Los procesadores que tienen la capacidad de ejecutar instrucciones individuales en múltiples datos se denominan procesadores vectoriales .

Tipos

Un procesador a menudo contiene varios tipos de registros, que pueden clasificarse según los tipos de valores que pueden almacenar o las instrucciones que operan sobre ellos:

Los registros de hardware son similares, pero ocurren fuera de las CPU.

En algunas arquitecturas (como SPARC y MIPS ), el primer o último registro del archivo de registros enteros es un pseudorregistro , ya 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 registros de punto flotante. Como resultado de esto, los archivos de registros se citan comúnmente como si tuvieran un registro más de la cantidad de ellos que son realmente utilizables; por ejemplo, se citan 32 registros cuando solo 31 de ellos encajan en la definición anterior de un 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 considera un registro entero, aunque existe una cantidad limitada de instrucciones que se pueden usar para operar sobre su contenido. Se aplican advertencias similares a la mayoría de las arquitecturas.

Aunque todas las arquitecturas que se enumeran a continuación son diferentes, casi todas se encuentran en una disposición básica conocida como arquitectura de von Neumann , propuesta por primera vez por el matemático húngaro-estadounidense John von Neumann . También es digno de mención que la cantidad de registros en las GPU es mucho mayor que en las CPU.

Uso

La cantidad de registros disponibles en un procesador y las operaciones que se pueden realizar con esos registros tienen un impacto significativo en la eficiencia del código generado por los compiladores optimizadores . El número de Strahler de un árbol de expresión proporciona la cantidad mínima de registros necesarios para evaluar ese árbol de expresión.

Véase también

Referencias

  1. ^ "¿Qué es un registro de procesador?". Educativo: Cursos interactivos para desarrolladores de software . Consultado el 12 de agosto de 2022 .
  2. ^ "Un estudio de técnicas para diseñar y gestionar archivos de registros de CPU".
  3. ^ "Manual de referencia del hardware del sistema informático Cray-1" (PDF) . Cray Research . Noviembre de 1977. Archivado (PDF) desde el original el 2021-11-07 . Consultado el 2022-12-23 .
  4. ^ "Manual del usuario del conjunto de microcomputadoras MCS-4" (PDF) . Intel. Febrero de 1973.
  5. ^ "8008 8 Bit Parallel Central Processor Unit Users Manual" (PDF) . Intel. Noviembre de 1973 . Consultado el 23 de enero de 2014 .
  6. ^ "Manual del usuario de los sistemas de microcomputadoras Intel 8080" (PDF) . Intel. Septiembre de 1975 . Consultado el 23 de enero de 2014 .
  7. ^ "Manual de referencia del programador de 80286 y 80287" (PDF) . Intel. 1987.
  8. ^ ab "Manuales para desarrolladores de software de arquitecturas Intel 64 e IA-32". Intel. 4 de diciembre de 2019.
  9. ^ "Manual del programador de la arquitectura AMD64, volumen 1: Programación de aplicaciones" (PDF) . AMD . Octubre de 2013.
  10. ^ "Referencia de programación de extensiones del conjunto de instrucciones de la arquitectura Intel y características futuras" (PDF) . Intel . Enero de 2018.
  11. ^ Guía de programación F8 (PDF) . División de microcomputadoras Fairchild MOS. 1977.
  12. ^ "Guía de referencia del procesador Nios II Classic" (PDF) . Altera . 2 de abril de 2015.
  13. ^ "Guía de referencia del procesador Nios II Gen2" (PDF) . Altera. 2 de abril de 2015.
  14. ^ "Manual de referencia de programación M6800" (PDF) . Motorola . Noviembre de 1976 . Consultado el 18 de mayo de 2015 .
  15. ^ "Manual de referencia del programador de la familia Motorola M68000" (PDF) . Motorola. 1992 . Consultado el 13 de junio de 2015 .
  16. ^ "Guía de programación CUDA C". Nvidia. 2019. Consultado el 9 de enero de 2020 .
  17. ^ 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].
  18. ^ "Arquitectura de sistemas empresariales IBM/370 y System/370 - Operaciones vectoriales" (PDF) . IBM. SA22-7125-3 . Consultado el 11 de mayo de 2020 .
  19. ^ "Microprocesador IBM S/390 G5" (PDF) .
  20. ^ "Página de inicio de MMIX".
  21. ^ "Libro de datos de la serie 32000" (PDF) . National Semiconductor .
  22. ^ "Arquitectura del conjunto de instrucciones de la unidad de procesamiento sinérgico versión 1.2" (PDF) . IBM. 27 de enero de 2007.
  23. ^ "Aprendiendo el ensamblaje 65816". Wiki de desarrollo de Super Famicom . Consultado el 14 de noviembre de 2019 .
  24. ^ "Estándar de llamada a procedimientos para la arquitectura ARM" (PDF) . ARM Holdings . 30 de noviembre de 2013 . Consultado el 27 de mayo de 2013 .
  25. ^ "2.6.2. El conjunto de registros de estado del pulgar". Manual de referencia técnica ARM7TDMI . ARM Holdings .
  26. ^ "Estándar de llamada a procedimiento para la arquitectura ARM de 64 bits" (PDF) . ARM Holdings. 22 de mayo de 2013 . Consultado el 27 de mayo de 2013 .
  27. ^ "Referencia de arquitectura de la Epifanía" (PDF) .