stringtranslate.com

Ley de hierro del rendimiento del procesador

En arquitectura informática , la ley de hierro del rendimiento del procesador (o simplemente ley de hierro del rendimiento) describe el equilibrio de rendimiento entre la complejidad y la cantidad de instrucciones primitivas que los procesadores utilizan para realizar cálculos. [1] Esta formulación de la compensación impulsó el desarrollo [ cita necesaria ] de computadoras con conjunto de instrucciones reducido (RISC) cuyas arquitecturas de conjunto de instrucciones (ISA) aprovechan un conjunto más pequeño de instrucciones básicas para mejorar el rendimiento. El término fue acuñado por Douglas Clark [2] basándose en una investigación realizada por Clark y Joel Emer en la década de 1980. [3]

Explicación

El rendimiento de un procesador es el tiempo que tarda en ejecutar un programa: . Esto se puede dividir en tres factores: [4]

La selección de la arquitectura de un conjunto de instrucciones afecta , mientras que está determinada en gran medida por la tecnología de fabricación. ISA de computadora con conjunto de instrucciones complejas clásicas (CISC) optimizadas al proporcionar un conjunto más grande de instrucciones de CPU más complejas . Sin embargo, en términos generales, las instrucciones complejas inflan el número de ciclos de reloj por instrucción porque deben decodificarse en microoperaciones más simples que realmente realiza el hardware. Después de convertir el binario X86 a las microoperaciones utilizadas internamente, el número total de operaciones se acerca al que se produce para un RISC ISA comparable. [5] La ley de hierro del rendimiento del procesador hace explícita esta compensación e impulsa la optimización en su conjunto, no solo de un solo componente.

Si bien se atribuye a la ley de hierro el mérito de impulsar el desarrollo de arquitecturas RISC, [ cita necesaria ] no implica que una ISA más simple sea siempre más rápida. Si ese fuera el caso, el ISA más rápido consistiría en lógica binaria simple. Una sola instrucción CISC puede ser más rápida que el conjunto equivalente de instrucciones RISC cuando permite realizar múltiples microoperaciones en un solo ciclo de reloj. En la práctica, sin embargo, la regularidad de las instrucciones RISC permitió una implementación canalizada donde el tiempo total de ejecución de una instrucción era (normalmente) ~5 ciclos de reloj, pero cada instrucción seguía la instrucción anterior ~1 ciclo de reloj después [ cita requerida ] . Los procesadores CISC también pueden lograr un mayor rendimiento utilizando técnicas como extensiones modulares, lógica predictiva, instrucciones comprimidas y fusión de macrooperaciones. [6] [5] [7]

Ver también

Referencias

  1. ^ Eeckhout, Lieven (2010). Métodos de evaluación del rendimiento de la arquitectura informática. Morgan y Claypool. págs. 5–6. ISBN 9781608454679. Consultado el 9 de marzo de 2021 .
  2. ^ Joel, Emer (13 de abril de 2021), Keynote de YArch 2021 , consultado el 2 de septiembre de 2021
  3. ^ Una caracterización del rendimiento del procesador en VAX-11/780, Joel S. Emer, Douglas W. Clark, 1984, IEEE
  4. ^ Asanovic, Krste (2019). "Conferencia 4: Canalización" (PDF) . Departamento de Ingeniería Eléctrica y Ciencias de la Computación de UC Berkeley (diapositivas de conferencias). pag. 2. Archivado (PDF) desde el original el 12 de marzo de 2021 . Consultado el 11 de marzo de 2020 .
  5. ^ ab Celio, Christopher; Dabbelt, Palmer; Patterson, David A.; Asanović, Krste (8 de julio de 2016). "El caso renovado para la computadora con conjunto de instrucciones reducido: evitar la hinchazón de ISA con Macro-Op Fusion para RISC-V". arXiv : 1607.02318 [cs.AR].
  6. ^ Engheim, Erik (28 de diciembre de 2020). "El genio de los microprocesadores RISC-V". Medio . Consultado el 11 de marzo de 2021 .
  7. ^ Celio, Christopher (26 de julio de 2016), Una comparación de RISC V, ARM y x86 , consultado el 11 de marzo de 2021