Power ISA es una arquitectura de conjunto de instrucciones (ISA) reducido (RISC) actualmente desarrollada por la Fundación OpenPOWER, dirigida por IBM. Originalmente fue desarrollado por IBM y el ahora desaparecido grupo industrial Power.org. Power ISA es una evolución de la arquitectura PowerPC, creada por la fusión del núcleo ISA PowerPC ISA y el Libro E opcional para aplicaciones integradas. La fusión de estos dos componentes en 2006 fue liderada por los fundadores de Power.org, IBM y Freescale Semiconductor.
Power ISA | ||
---|---|---|
Información | ||
Tipo | Microprocesador | |
Desarrollador |
Power.org Fundación OpenPOWER | |
Fecha de lanzamiento | 1990 | |
Datos técnicos | ||
Conjunto de instrucciones | 32 bits/64 bits | |
Microarquitectura | IBM POWER RISC | |
La ISA se divide en varias categorías que se describen en un determinado Libro. Los procesadores implementan un conjunto de estas categorías según sea necesario para su tarea. Se requieren diferentes clases de procesadores para implementar ciertas categorías, por ejemplo, un procesador de clase de servidor incluye las categorías: Base, Servidor, Coma flotante, 64 bits, etc. Todos los procesadores implementan la categoría Base.
Power ISA es una RISC arquitectura de carga-almacenamiento. Tiene varios conjuntos de registros:
Las instrucciones hasta la versión 3.0 tienen una longitud de 32 bits, con la excepción del subconjunto VLE (codificación de longitud variable) que proporciona una densidad de código más alta para aplicaciones integradas de gama baja, y la versión 3.1 que introdujo prefijos para crear instrucciones de 64 bits. La mayoría de las instrucciones son triádicas, es decir, tienen dos operandos de origen y un destino. Se admiten operaciones de coma flotante compatibles con precisión simple y precisión doble IEEE-754, incluidas instrucciones adicionales de multiplicar-sumar (FMA) y coma flotante decimal. Existen provisiones para operaciones instrucción única, datos múltiples (SIMD) en datos enteros y de coma flotante en hasta 16 elementos en una instrucción.
Power ISA tiene soporte para caché Harvard, es decir, cachés de instrucciones y datos divididas y soporte para cachés unificadas. Las operaciones de memoria son estrictamente de carga/almacenamiento, pero permiten la ejecución fuera de orden. También hay soporte para direccionamiento big y little-endian con categorías separadas para endianness por página y modo, y soporte para direccionamiento 32 bits y 64 bits.
Los diferentes modos de operación incluyen usuario, supervisor e hipervisor.
La especificación Power ISA se divide en cinco partes, llamadas "libros":
Lo nuevo en la versión 3 de Power ISA es que no tiene que implementar toda la especificación para cumplir. La proliferación de instrucciones y tecnologías ha hecho que la especificación completa sea difícil de manejar, por lo que Foundación OpenPOWER decidió habilitar el cumplimiento por niveles.
Estos niveles incluyen requisitos «opcionales» y «obligatorios». Sin embargo, se recomienda que se proporcione una opción para deshabilitar cualquier función adicional más allá del nivel de subconjunto declarado del diseño.
Un diseño debe cumplir con su nivel de subconjunto declarado para hacer uso de la protección de la Fundación con respecto al uso de propiedad intelectual, ya sea patentes o marcas registradas. Esto se explica en el EULA de OpenPOWER.[1]
Un diseño compatible debe:[2]
Si la extensión es lo suficientemente general, OpenPOWER Foundation solicita a los implementadores que la envíen como una solicitud de comentarios (RFC) al OpenPOWER ISA Workgroup. Tenga en cuenta que no es estrictamente necesario unirse a la Fundación OpenPOWER para enviar RFC.[3]
Las especificaciones de EABI son anteriores al anuncio y la creación de los subconjuntos de Cumplimiento.
Con respecto al subconjunto de cumplimiento de Linux que tiene VSX (SIMD) opcional: en 2003 EABI v1.9 de 64 bits hizo que SIMD fuera opcional,[4] pero en julio de 2015, para mejorar el rendimiento de los sistemas IBM POWER9, SIMD se hizo obligatorio en EABI v2.0.[5] Esta discrepancia entre que SIMD sea opcional en el nivel de cumplimiento de Linux pero obligatorio en EABI v2.0 no se puede rectificar sin un esfuerzo considerable: la incompatibilidad con versiones anteriores de las distribuciones de Linux no es una opción viable. En la actualidad, esto deja a los nuevos implementadores de OpenPOWER que deseen ejecutar distribuciones Linux estándar teniendo que implementar instrucciones en gran cantidad: 962. Por el contrario, RISC-V RV64GC, el mínimo para ejecutar Linux requiere solo 165.[6]
La especificación para Power ISA v2.03[7] se basa en el antiguo PowerPC ISA v2.02[8] del POWER5+ y el Libro E[9] de la extensión de la especificación PowerPC. El Libro I incluía cinco nuevos capítulos sobre unidades auxiliares de procesamiento como DSP y la extensión AltiVec.
La especificación para Power ISA v2.04[10] se finalizó en junio de 2007. Se basa en Power ISA v2.03 e incluye cambios, principalmente en la parte del Libro III-S, con respecto a la virtualización, funciones de hipervisor, particionamiento lógico y manejo de página virtual.
La especificación para Power ISA v2.05[11] se publicó en diciembre de 2007. Se basa en Power ISA v.2.04 e incluye cambios principalmente en el "Libro I" y el "Libro III-S", incluidas mejoras significativas como la aritmética decimal (Categoría: Coma flotante decimal en Libro I) y mejoras en el hipervisor del servidor.
La especificación para Power ISA v2.06[12] se lanzó en febrero de 2009 y se revisó en julio de 2010.[13] Se basa en Power ISA v2.05 e incluye extensiones para el procesador POWER7 y el núcleo e500-mc. Una nueva característica importante son las instrucciones de coma flotante escalar vectorial (VSX).[14] El Book III-E también incluye mejoras significativas para la especificación integrada con respecto al hipervisor y la virtualización en implementaciones de uno o varios núcleos.
La especificación se revisó en noviembre de 2010 con respecto a la especificación Power ISA v2.06 revisión B, mejorando las funciones de virtualización.[13][15]
La especificación para Power ISA v2.07[16] se lanzó en mayo de 2013. Se basa en Power ISA v2.06 e incluye importantes mejoras en funciones de partición lógica, memoria transaccional, monitoreo de rendimiento, nuevas funciones de control de almacenamiento, adiciones a las instalaciones de vector VMX y VSX (VSX-2), junto con AES[16]< ref>Barbosa, Leonidas (21 de septiembre de 2014). «POWER8 in-core cryptography». IBM.</ref> y Modo de contador de Galois (GCM), extensiones criptográficas SHA-224, SHA-256,[16] SHA-384 y SHA-512[16] (SHA-2) y algoritmos de comprobación de redundancia cíclica (CRC).[17]
La especificación se revisó en abril de 2015 a la especificación Power ISA v.2.07 B.[18]
La especificación para Power ISA v3.0[19][20] se lanzó en noviembre de 2015. Es el primero en salir después de la creación de la Fundación OpenPOWER e incluye mejoras para un amplio espectro de cargas de trabajo y elimina el servidor y las categorías incrustadas mientras conserva la compatibilidad con versiones anteriores y agrega soporte para Instrucciones VSX-3. Las nuevas funciones incluyen operaciones de coma flotante de precisión cuádruple de 128 bits, un generador de números aleatorios, recolección de basura asistida por hardware y computación confiable aplicada por hardware.
La especificación se revisó en marzo de 2017 con respecto al Power ISA v3.0 B.[21] y revisado nuevamente a v3.0C en mayo de 2020.[22] La diferencia clave entre v3.0B y v3.0C es que los niveles de cumplimiento enumerados en v3.1 también se agregaron a v3.0C.
La especificación para Power ISA v3.1[24] se lanzó en mayo de 2020. Principalmente brinda soporte para las nuevas funciones introducidas en Power10, pero también incluye la noción de opcionalidad para la especificación PowerISA. Las instrucciones ahora pueden tener ocho bytes de largo, «instrucciones prefijadas», en comparación con las habituales «instrucciones de palabras» de cuatro bytes. También se agregan muchas funciones nuevas a las instrucciones SIMD y VSX.
Un beneficio clave de las nuevas instrucciones prefijadas de 64 bits es la extensión de las instrucciones inmediatas en las ramas a 34 bits.