Familia de arquitectura ARM

Familia de arquitecturas de computadores

BRAZO
Diseñador
Pedazos32 bits , 64 bits
Introducido1985 ; hace 39 años ( 1985 )
DiseñoRIESGO
TipoCargar-almacenar
DerivaciónCódigo de condición , comparar y ramificar
AbiertoPropiedad
ARM de 64/32 bits
Introducido2011 ; hace 13 años ( 2011 )
VersiónARMv8-R, ARMv8-A, ARMv8.1-A, ARMv8.2-A, ARMv8.3-A, ARMv8.4-A, ARMv8.5-A, ARMv8.6-A, ARMv8.7-A, ARMv8.8-A, ARMv8.9-A, ARMv9.0-A, ARMv9.1-A, ARMv9.2-A, ARMv9.3-A, ARMv9.4-A, ARMv9.5-A, ARMv9.6-A
CodificaciónAArch64 /A64 y AArch32/A32 utilizan instrucciones de 32 bits, AArch32/T32 (Thumb-2) utiliza instrucciones mixtas de 16 y 32 bits [1]
EndianidadBi (pequeño por defecto)
ExtensionesSVE , SVE2, SME, AES, SM3, SM4, SHA, CRC32, TME; todos obligatorios: Thumb-2, Neon, VFPv4-D16, VFPv4; obsoletos: Jazelle
Registros
De propósito general31 registros enteros de 64 bits [1]
Punto flotanteRegistros de 32 × 128 bits [1] para FP escalar de 32 y 64 bits o FP SIMD o entero; o criptografía
ARM de 32 bits
VersiónARMv9-R, ARMv9-M, ARMv8-R, ARMv8-M, ARMv7-A, ARMv7-R, ARMv7E-M, ARMv7-M, ARMv6-M
Codificación32 bits, excepto que las extensiones Thumb-2 utilizan instrucciones mixtas de 16 y 32 bits.
EndianidadBi (pequeño por defecto)
ExtensionesPulgar-2, Neón, Jazelle , AES, SM3, SM4, SHA, CRC32, DSP, Saturado, FPv4-SP, FPv5, Helio
Registros
De propósito general15 registros enteros de 32 bits, incluido R14 (registro de enlace), pero no R15 (PC)
Punto flotanteHasta 32 registros de 64 bits, [2] SIMD/punto flotante (opcional)
ARM de 32 bits (heredado)
VersiónARMv6, ARMv5, ARMv4T, ARMv3, ARMv2
Codificación32 bits, excepto que la extensión Thumb utiliza instrucciones mixtas de 16 y 32 bits.
EndianidadBi (pequeño como predeterminado) en ARMv3 y superior
ExtensionesPulgar , Jazelle
Registros
De propósito general15 registros enteros de 32 bits, incluido R14 (registro de enlace), pero no R15 (PC, direccionamiento de 26 bits en versiones anteriores)
Punto flotanteNinguno

ARM (estilizado en minúsculas como arm , anteriormente un acrónimo de Advanced RISC Machines y originalmente Acorn RISC Machine ) es una familia de arquitecturas de conjunto de instrucciones (ISA) RISC para procesadores de computadoras . Arm Holdings desarrolla las ISA y las licencia a otras compañías, que construyen los dispositivos físicos que utilizan el conjunto de instrucciones. También diseña y licencia núcleos que implementan estas ISA.

Debido a sus bajos costos, bajo consumo de energía y baja generación de calor, los procesadores ARM son útiles para dispositivos livianos, portátiles y alimentados por batería, incluidos teléfonos inteligentes , computadoras portátiles y tabletas , así como sistemas integrados . [3] [4] [5] Sin embargo, los procesadores ARM también se utilizan para computadoras de escritorio y servidores , incluida la supercomputadora más rápida del mundo ( Fugaku ) ​​desde 2020 [6] hasta 2022. Con más de 230 mil millones de chips ARM producidos, [7] [8] desde al menos 2003, y con su dominio aumentando cada año [actualizar], ARM es la familia de arquitecturas de conjuntos de instrucciones más utilizada. [9] [4] [10] [11] [12]

Ha habido varias generaciones del diseño ARM. El ARM1 original usaba una estructura interna de 32 bits pero tenía un espacio de direcciones de 26 bits que lo limitaba a 64 MB de memoria principal . Esta limitación se eliminó en la serie ARMv3, que tiene un espacio de direcciones de 32 bits, y varias generaciones adicionales hasta ARMv7 mantuvieron los 32 bits. Lanzada en 2011, la arquitectura ARMv8-A agregó soporte para un espacio de direcciones de 64 bits y aritmética de 64 bits con su nuevo conjunto de instrucciones de longitud fija de 32 bits. [13] Arm Holdings también ha lanzado una serie de conjuntos de instrucciones adicionales para diferentes reglas; la extensión "Thumb" agrega instrucciones de 32 y 16 bits para una densidad de código mejorada , mientras que Jazelle agregó instrucciones para manejar directamente el bytecode de Java . Los cambios más recientes incluyen la adición de subprocesamiento múltiple simultáneo (SMT) para un rendimiento mejorado o tolerancia a fallas . [14]

Historia

BBC Micro

El primer diseño de gran éxito de Acorn Computers fue el BBC Micro , presentado en diciembre de 1981. Se trataba de una máquina relativamente convencional basada en la CPU MOS Technology 6502 , pero que funcionaba aproximadamente al doble del rendimiento de diseños de la competencia, como el Apple II, debido a su uso de memoria dinámica de acceso aleatorio (DRAM) más rápida. La DRAM típica de la época funcionaba a unos 2 MHz; Acorn llegó a un acuerdo con Hitachi para el suministro de piezas más rápidas de 4 MHz. [15]

Las máquinas de la época generalmente compartían memoria entre el procesador y el framebuffer , lo que permitía al procesador actualizar rápidamente el contenido de la pantalla sin tener que realizar entradas y salidas (E/S) por separado. Como la sincronización de la visualización de video es exigente, el hardware de video tenía que tener acceso prioritario a esa memoria. Debido a una peculiaridad del diseño del 6502, la CPU dejaba la memoria intacta durante la mitad del tiempo. Por lo tanto, al ejecutar la CPU a 1 MHz, el sistema de video podía leer datos durante esos tiempos de inactividad, ocupando el ancho de banda total de 2 MHz de la RAM. En el BBC Micro, el uso de RAM de 4 MHz permitió utilizar la misma técnica, pero funcionando al doble de velocidad. Esto le permitió superar a cualquier máquina similar en el mercado. [16]

Computadora de negocios Acorn

1981 fue también el año en que se presentó la IBM Personal Computer . Utilizando el recientemente presentado Intel 8088 , una CPU de 16 bits en comparación con el diseño de 8 bits del 6502 , ofrecía un rendimiento general superior. Su introducción cambió radicalmente el mercado de las computadoras de escritorio: lo que había sido en gran medida un mercado de pasatiempos y juegos que surgió durante los cinco años anteriores comenzó a cambiar a una herramienta empresarial imprescindible donde los diseños anteriores de 8 bits simplemente no podían competir. Incluso los diseños más nuevos de 32 bits también estaban llegando al mercado, como el Motorola 68000 [17] y el National Semiconductor NS32016 [18] .

Acorn comenzó a considerar cómo competir en este mercado y produjo un nuevo diseño en papel llamado Acorn Business Computer . Se fijaron el objetivo de producir una máquina con diez veces el rendimiento del BBC Micro, pero al mismo precio. [19] Esto superaría y costaría menos que el PC. Al mismo tiempo, la reciente introducción del Apple Lisa llevó el concepto de interfaz gráfica de usuario (GUI) a una audiencia más amplia y sugirió que el futuro pertenecía a las máquinas con una GUI. [20] Sin embargo, el Lisa costaba $ 9,995, ya que estaba equipado con chips de soporte, grandes cantidades de memoria y una unidad de disco duro , todo muy caro en ese entonces. [21]

Los ingenieros comenzaron entonces a estudiar todos los diseños de CPU disponibles. Su conclusión sobre los diseños de 16 bits existentes fue que eran mucho más caros y todavía eran "un poco basura", [22] ofreciendo solo un rendimiento ligeramente superior al de su diseño BBC Micro. También casi siempre exigían una gran cantidad de chips de soporte para operar incluso a ese nivel, lo que aumentaba el costo de la computadora en su conjunto. Estos sistemas simplemente no alcanzarían el objetivo de diseño. [22] También consideraron los nuevos diseños de 32 bits, pero costaban aún más y tenían los mismos problemas con los chips de soporte. [23] Según Sophie Wilson , todos los procesadores probados en ese momento tenían un rendimiento similar, con un ancho de banda de aproximadamente 4 Mbit/s. [24] [a]

Dos eventos clave llevaron a Acorn por el camino hacia ARM. Uno fue la publicación de una serie de informes de la Universidad de California, Berkeley , que sugerían que un diseño de chip simple podría, no obstante, tener un rendimiento extremadamente alto, mucho mayor que los últimos diseños de 32 bits en el mercado. [25] El segundo fue una visita de Steve Furber y Sophie Wilson al Western Design Center , una empresa dirigida por Bill Mensch y su hermana, que se había convertido en el sucesor lógico del equipo MOS y estaba ofreciendo nuevas versiones como la WDC 65C02 . El equipo de Acorn vio a estudiantes de secundaria produciendo diseños de chips en máquinas Apple II, lo que sugería que cualquiera podía hacerlo. [26] [27] En contraste, una visita a otra empresa de diseño que trabajaba en CPU modernas de 32 bits reveló un equipo con más de una docena de miembros que ya estaban en la revisión H de su diseño y, sin embargo, todavía contenía errores. [b] Esto consolidó su decisión a fines de 1983 de comenzar su propio diseño de CPU, la Acorn RISC Machine. [28]

Conceptos de diseño

Los diseños originales de Berkeley RISC eran, en cierto sentido, sistemas de enseñanza, no diseñados específicamente para un rendimiento absoluto. A los conceptos básicos de RISC, basados ​​en registros y carga/almacenamiento, ARM agregó una serie de notas de diseño bien recibidas del 6502. La principal de ellas era la capacidad de servir interrupciones rápidamente , lo que permitía a las máquinas ofrecer un rendimiento de entrada/salida razonable sin hardware externo agregado. Para ofrecer interrupciones con un rendimiento similar al del 6502, el diseño de ARM limitó su espacio de dirección física a 64 MB de espacio direccionable total, lo que requería 26 bits de dirección. Como las instrucciones tenían una longitud de 4 bytes (32 bits) y debían estar alineadas en límites de 4 bytes, los 2 bits inferiores de una dirección de instrucción siempre eran cero. Esto significaba que el contador de programa (PC) solo necesitaba tener 24 bits, lo que permitía almacenarlo junto con los indicadores de procesador de ocho bits en un solo registro de 32 bits. Esto significaba que al recibir una interrupción, todo el estado de la máquina podía ser guardado en una sola operación, mientras que si el PC hubiera sido un valor completo de 32 bits, se necesitarían operaciones separadas para almacenar el PC y los indicadores de estado. Esta decisión redujo a la mitad la sobrecarga de interrupciones. [29]

Otro cambio, y uno de los más importantes en términos de rendimiento práctico en el mundo real, fue la modificación del conjunto de instrucciones para aprovechar el modo de página de la DRAM . Introducido recientemente, el modo de página permitía que los accesos posteriores a la memoria se ejecutaran el doble de rápido si se encontraban aproximadamente en la misma ubicación, o "página", en el chip DRAM. El diseño de Berkeley no consideró el modo de página y trató a toda la memoria por igual. El diseño ARM agregó instrucciones especiales de acceso a la memoria de tipo vectorial, los "ciclos S", que se podían usar para llenar o guardar múltiples registros en una sola página utilizando el modo de página. Esto duplicó el rendimiento de la memoria cuando se podían usar, y fue especialmente importante para el rendimiento gráfico. [30]

Los diseños RISC de Berkeley utilizaban ventanas de registro para reducir la cantidad de guardados y restauraciones de registros realizados en llamadas a procedimientos ; el diseño ARM no adoptó esto.

Wilson desarrolló el conjunto de instrucciones, escribiendo una simulación del procesador en BBC BASIC que se ejecutaba en un BBC Micro con un segundo procesador 6502. [31] [32] Esto convenció a los ingenieros de Acorn de que estaban en el camino correcto. Wilson se acercó al director ejecutivo de Acorn, Hermann Hauser , y solicitó más recursos. Hauser dio su aprobación y reunió a un pequeño equipo para diseñar el procesador real basado en el ISA de Wilson. [33] El proyecto oficial de la máquina RISC de Acorn comenzó en octubre de 1983.

BRAZO1

Segundo procesador ARM1 para BBC Micro

Acorn eligió a VLSI Technology como "socio de silicio", ya que eran una fuente de ROM y chips personalizados para Acorn. Acorn proporcionó el diseño y VLSI proporcionó la disposición y la producción. Las primeras muestras de silicio ARM funcionaron correctamente cuando se recibieron y probaron por primera vez el 26 de abril de 1985. [3] Conocidas como ARM1, estas versiones funcionaban a 6 MHz. [34]

La primera aplicación de ARM fue como segundo procesador para el BBC Micro, donde ayudó a desarrollar software de simulación para finalizar el desarrollo de los chips de soporte (VIDC, IOC, MEMC) y aceleró el software CAD utilizado en el desarrollo de ARM2. Posteriormente, Wilson reescribió BBC BASIC en lenguaje ensamblador ARM . El profundo conocimiento adquirido al diseñar el conjunto de instrucciones permitió que el código fuera muy denso, lo que convirtió a ARM BBC BASIC en una prueba extremadamente buena para cualquier emulador ARM.

ARM2

El resultado de las simulaciones en las placas ARM1 condujo a la introducción a fines de 1986 del diseño ARM2 que funcionaba a 8 MHz, y a principios de 1987 a la versión con aumento de velocidad de 10 a 12 MHz. [c] Un cambio significativo en la arquitectura subyacente fue la adición de un multiplicador de Booth , mientras que anteriormente la multiplicación tenía que realizarse en software. [36] Además, un nuevo modo Fast Interrupt reQuest, FIQ para abreviar, permitió que los registros 8 a 14 se reemplazaran como parte de la interrupción en sí. Esto significaba que las solicitudes FIQ no tenían que guardar sus registros, lo que aceleraba aún más las interrupciones. [37]

El primer uso del ARM2 fueron los modelos de computadoras personales Acorn Archimedes A305, A310 y A440, lanzados en 1987.

Según el benchmark Dhrystone , el ARM2 ofrecía aproximadamente siete veces el rendimiento de un sistema típico basado en 68000 de 7 MHz como el Amiga o el Macintosh SE . Era el doble de rápido que un Intel 80386 funcionando a 16 MHz, y aproximadamente la misma velocidad que un superminiordenador multiprocesador VAX-11/784 . Los únicos sistemas que lo superaban eran las estaciones de trabajo basadas en RISC Sun SPARC y MIPS R2000 . [38] Además, como la CPU estaba diseñada para E/S de alta velocidad, prescindía de muchos de los chips de soporte que se ven en estas máquinas; en particular, carecía de cualquier controlador de acceso directo a memoria (DMA) dedicado que a menudo se encontraba en las estaciones de trabajo. El sistema gráfico también se simplificó basándose en el mismo conjunto de suposiciones subyacentes sobre la memoria y la sincronización. El resultado fue un diseño drásticamente simplificado, que ofrecía un rendimiento a la par con las costosas estaciones de trabajo pero a un precio similar al de los ordenadores de sobremesa contemporáneos. [38]

El ARM2 presentaba un bus de datos de 32 bits , un espacio de direcciones de 26 bits y 27 registros de 32 bits , de los cuales 16 son accesibles en cualquier momento (incluido el PC ). [39] El ARM2 tenía un recuento de transistores de solo 30 000, [40] en comparación con el modelo 68000 de Motorola, seis años más antiguo, con alrededor de 68 000. Gran parte de esta simplicidad provenía de la falta de microcódigo , que representa aproximadamente entre un cuarto y un tercio de los transistores del 68000, y la falta de (como la mayoría de las CPU de la época) una caché . Esta simplicidad permitió que el ARM2 tuviera un bajo consumo de energía y un empaquetado térmico más simple al tener menos transistores alimentados. Sin embargo, ARM2 ofrecía un mejor rendimiento que el IBM PS/2 Modelo 50 de 1987 , que inicialmente utilizaba un Intel 80286 , ofreciendo 1,8 MIPS a 10 MHz, y más tarde, en 1987, los 2 MIPS del PS/2 70, con su Intel 386 DX a 16 MHz. [41] [42]

Se produjo un sucesor, ARM3, con una caché de 4 KB, que mejoró aún más el rendimiento. [43] El bus de direcciones se amplió a 32 bits en el ARM6, pero el código del programa todavía tenía que estar dentro de los primeros 64 MB de memoria en modo de compatibilidad de 26 bits, debido a los bits reservados para los indicadores de estado. [44]

Advanced RISC Machines Ltd. – ARM6

Sistema basado en microprocesador en un chip
Matriz de un microprocesador ARM610

A finales de los años 1980, Apple Computer y VLSI Technology empezaron a trabajar con Acorn en nuevas versiones del núcleo ARM. En 1990, Acorn escindió el equipo de diseño y lo convirtió en una nueva empresa llamada Advanced RISC Machines Ltd., [45] [46] [47] que se convirtió en ARM Ltd. cuando su empresa matriz, Arm Holdings plc, salió a bolsa en la Bolsa de Londres y en el Nasdaq en 1998. [48] El nuevo trabajo de Apple con ARM acabaría evolucionando hasta convertirse en el ARM6, que se lanzó por primera vez a principios de 1992. Apple utilizó el ARM610 basado en ARM6 como base para su PDA Apple Newton .

Licenciatarios tempranos

En 1994, Acorn utilizó el ARM610 como la unidad central de procesamiento (CPU) principal en sus computadoras RiscPC . DEC licenció la arquitectura ARMv4 y produjo el StrongARM . [49] A 233  MHz , esta CPU consumía solo un vatio (las versiones más nuevas consumen mucho menos). Este trabajo fue luego transferido a Intel como parte de un acuerdo judicial, e Intel aprovechó la oportunidad para complementar su línea i960 con el StrongARM. Intel desarrolló más tarde su propia implementación de alto rendimiento llamada XScale , que desde entonces ha vendido a Marvell . El recuento de transistores del núcleo ARM se mantuvo esencialmente igual a lo largo de estos cambios; ARM2 tenía 30.000 transistores, [50] mientras que ARM6 creció solo a 35.000. [51]

Cuota de mercado

En 2005, aproximadamente el 98% de todos los teléfonos móviles vendidos utilizaban al menos un procesador ARM. [52] En 2010, los productores de chips basados ​​en arquitecturas ARM informaron envíos de 6.100 millones de procesadores basados ​​en ARM , lo que representa el 95% de los teléfonos inteligentes , el 35% de los televisores digitales y decodificadores , y el 10% de las computadoras móviles . En 2011, la arquitectura ARM de 32 bits fue la arquitectura más utilizada en dispositivos móviles y la de 32 bits más popular en sistemas integrados. [53] En 2013, se produjeron 10 mil millones [54] y "los chips basados ​​en ARM se encuentran en casi el 60 por ciento de los dispositivos móviles del mundo". [55]

Licencias

Matriz de un microcontrolador ARM Cortex-M3 STM32 F103VGT6 con  memoria flash de STMicroelectronics

Licencia básica

El negocio principal de Arm Holdings es la venta de núcleos de propiedad intelectual , que los licenciatarios utilizan para crear microcontroladores (MCU), CPU y sistemas en chips basados ​​en esos núcleos. El fabricante del diseño original combina el núcleo ARM con otras partes para producir un dispositivo completo, normalmente uno que se puede construir en plantas de fabricación de semiconductores (fabs) existentes a bajo costo y aún así ofrecer un rendimiento sustancial. La implementación más exitosa ha sido el ARM7TDMI con cientos de millones vendidos. Atmel ha sido un centro de diseño precursor en el sistema integrado basado en ARM7TDMI.

Las arquitecturas ARM utilizadas en teléfonos inteligentes, PDA y otros dispositivos móviles varían desde ARMv5 hasta ARMv8-A .

En 2009, algunos fabricantes introdujeron netbooks basados ​​en CPU de arquitectura ARM, en competencia directa con los netbooks basados ​​en Intel Atom . [56]

Arm Holdings ofrece una variedad de condiciones de licencia, que varían en costo y resultados. Arm Holdings proporciona a todos los licenciatarios una descripción integrable del hardware del núcleo ARM, así como un conjunto completo de herramientas de desarrollo de software ( compilador , depurador , kit de desarrollo de software ) y el derecho a vender silicio fabricado que contenga la CPU ARM.

Los paquetes SoC que integran los diseños centrales de ARM incluyen las primeras tres generaciones de Nvidia Tegra, la familia Quatro de CSR plc, Nova y NovaThor de ST-Ericsson, el MCU Precision32 de Silicon Labs, los productos OMAP de Texas Instruments , los productos Hummingbird y Exynos de Samsung , los A4 , A5 y A5X de Apple , y el i.MX de NXP .

Los licenciatarios fabless , que desean integrar un núcleo ARM en su propio diseño de chip, normalmente solo están interesados ​​en adquirir un núcleo de propiedad intelectual de semiconductores verificado y listo para fabricar . Para estos clientes, Arm Holdings ofrece una descripción de la lista de conexiones de puertas del núcleo ARM elegido, junto con un modelo de simulación abstracto y programas de prueba para ayudar a la integración y verificación del diseño. Los clientes más ambiciosos, incluidos los fabricantes de dispositivos integrados (IDM) y los operadores de fundiciones, optan por adquirir la propiedad intelectual del procesador en forma de RTL sintetizable ( Verilog ). Con el RTL sintetizable, el cliente tiene la capacidad de realizar optimizaciones y extensiones a nivel arquitectónico. Esto permite al diseñador lograr objetivos de diseño exóticos que de otro modo no serían posibles con una lista de conexiones sin modificar ( alta velocidad de reloj , muy bajo consumo de energía, extensiones del conjunto de instrucciones, etc.). Si bien Arm Holdings no otorga al licenciatario el derecho a revender la arquitectura ARM en sí, los licenciatarios pueden vender libremente productos fabricados, como dispositivos de chip, placas de evaluación y sistemas completos. Las fundiciones comerciales pueden ser un caso especial; No sólo se les permite vender núcleos ARM que contienen silicio terminado, sino que generalmente tienen el derecho de refabricar núcleos ARM para otros clientes.

Arm Holdings establece el precio de su propiedad intelectual en función del valor percibido. Los núcleos ARM de menor rendimiento suelen tener costes de licencia más bajos que los núcleos de mayor rendimiento. En términos de implementación, un núcleo sintetizable cuesta más que un núcleo macrohard (blackbox). Para complicar aún más las cosas, una fundición comercial que posea una licencia ARM, como Samsung o Fujitsu, puede ofrecer a los clientes de la fábrica costes de licencia reducidos. A cambio de adquirir el núcleo ARM a través de los servicios de diseño internos de la fundición, el cliente puede reducir o eliminar el pago de la tarifa de licencia inicial de ARM.

En comparación con las fundiciones de semiconductores dedicadas (como TSMC y UMC ) sin servicios de diseño internos, Fujitsu/Samsung cobran entre dos y tres veces más por oblea fabricada . [ cita requerida ] Para aplicaciones de volumen bajo a medio, una fundición de servicios de diseño ofrece precios generales más bajos (a través de la subvención de la tarifa de licencia). Para piezas producidas en masa en gran volumen, la reducción de costos a largo plazo que se puede lograr a través de precios más bajos de las obleas reduce el impacto de los costos de ingeniería no recurrente (NRE ) de ARM, lo que hace que la fundición dedicada sea una mejor opción.

Las empresas que han desarrollado chips con núcleos diseñados por Arm incluyen la subsidiaria Annapurna Labs de Amazon.com , [57] Analog Devices , Apple , AppliedMicro (ahora: MACOM Technology Solutions [58] ), Atmel , Broadcom , Cavium , Cypress Semiconductor , Freescale Semiconductor (ahora NXP Semiconductors ), Huawei , Intel , [ dudosodiscutir ] Maxim Integrated , Nvidia , NXP , Qualcomm , Renesas , Samsung Electronics , ST Microelectronics , Texas Instruments y Xilinx .

Desarrollado con licencia de tecnología ARM Cortex

En febrero de 2016, ARM anunció la licencia Built on ARM Cortex Technology, a menudo abreviada como licencia Built on Cortex (BoC). Esta licencia permite a las empresas asociarse con ARM y realizar modificaciones a los diseños ARM Cortex. Estas modificaciones de diseño no se compartirán con otras empresas. Estos diseños de núcleo semipersonalizados también tienen libertad de marca, por ejemplo, Kryo 280 .

Las empresas que actualmente son licenciatarias de Built on ARM Cortex Technology incluyen a Qualcomm . [59]

Licencia de arquitectura

Las empresas también pueden obtener una licencia de arquitectura ARM para diseñar sus propios núcleos de CPU utilizando los conjuntos de instrucciones ARM. Estos núcleos deben cumplir plenamente con la arquitectura ARM. Entre las empresas que han diseñado núcleos que implementan una arquitectura ARM se encuentran Apple, AppliedMicro (ahora: Ampere Computing ), Broadcom, Cavium (ahora: Marvell), Digital Equipment Corporation , Intel, Nvidia, Qualcomm, Samsung Electronics, Fujitsu y NUVIA Inc. (adquirida por Qualcomm en 2021).

Acceso flexible ARM

El 16 de julio de 2019, ARM anunció ARM Flexible Access, que brinda acceso ilimitado a la propiedad intelectual (PI) de ARM incluida para el desarrollo. Se requieren tarifas de licencia por producto una vez que el cliente llega a la etapa de producción o de creación de prototipos. [60] [61]

El 75 % de las IP más recientes de ARM durante los últimos dos años están incluidas en ARM Flexible Access. A octubre de 2019:

  • Procesadores: Cortex-A5 , Cortex-A7 , Cortex-A32 , Cortex-A34 , Cortex-A35 , Cortex-A53 , Cortex-R5 , Cortex-R8 , Cortex-R52 , Cortex-M0 , Cortex-M0+ , Cortex-M3 , Cortex-M4 , Cortex-M7 , Cortex-M23 , Cortex-M33
  • GPU: Mali-G52 , Mali-G31 . Incluye kits de desarrollo de controladores Mali (DDK).
  • Interconexión: CoreLink NIC-400, CoreLink NIC-450, CoreLink CCI-400, CoreLink CCI-500, CoreLink CCI-550, ADB-400 AMBA, XHB-400 AXI-AHB
  • Controladores del sistema: CoreLink GIC-400, CoreLink GIC-500, PL192 VIC, BP141 TrustZone Memory Wrapper, CoreLink TZC-400, CoreLink L2C-310, CoreLink MMU-500, interfaz de memoria BP140
  • IP de seguridad: CryptoCell-312, CryptoCell-712, generador de números aleatorios reales TrustZone
  • Controladores periféricos: PL011 UART, PL022 SPI, PL031 RTC
  • Depuración y seguimiento: CoreSight SoC-400, CoreSight SDC-600, CoreSight STM-500, CoreSight System Trace Macrocell, CoreSight Trace Memory Controller
  • Kits de diseño: Corstone-101, Corstone-201
  • IP física: Artisan PIK para Cortex-M33 TSMC 22ULL, incluidos compiladores de memoria, bibliotecas lógicas, GPIO y documentación
  • Herramientas y materiales: Socrates IP ToolingARM Design Studio, modelos de sistemas virtuales
  • Soporte: Soporte técnico ARM estándar, capacitación en línea ARM, actualizaciones de mantenimiento, créditos para capacitación en el sitio y revisiones de diseño

Núcleos

Arquitectura
Ancho de bits del núcleo
NúcleosPerfilReferencias
Brazo Ltda.Tercero
ARMv1
BRAZO1
Clásico
[un 1]
ARMv2
32
ARM2 , ARM250, ARM3Ámbar , núcleo blando abierto STORM [62]
Clásico
[un 1]
ARMv3
32
ARM6 , ARM7
Clásico
[un 2]
ARMv4
32
ARM8Núcleo de procesador de código abierto StrongARM , FA526, ZAP
Clásico
[un 2]
[63]
ARMv4T
32
ARM7TDMI , ARM9TDMI y SecurCore SC100
Clásico
[un 2]
ARMv5TE
32
ARM7EJ , ARM9E , ARM10EXScale , FA626TE, Feroceon, PJ1/Mohawk
Clásico
ARMv6
32
ARM11
Clásico
ARMv6-M
32
ARM Cortex-M0 , ARM Cortex-M0+ , ARM Cortex-M1 , SecurCore SC000
ARMv7-M
32
ARM Cortex-M3 , SecurCore SC300Coprocesador de movimiento Apple M7
Microcontrolador
ARMv7E-M
32
ARM Cortex-M4 , ARM Cortex-M7
Microcontrolador
ARMv8-M
32
ARM Cortex-M23 , [64] ARM Cortex-M33 [65]
Microcontrolador
[66]
ARMv8.1-M
32
ARM Cortex-M55 , ARM Cortex-M85
Microcontrolador
[67]
ARMv7-R
32
ARM Cortex-R4 , ARM Cortex-R5 , ARM Cortex-R7 , ARM Cortex-R8
ARMv8-R
32
ARM Cortex-R52
En tiempo real
[68] [69] [70]
64
ARM Cortex-R82
En tiempo real
ARMv7-A
32
ARM Cortex-A5 , ARM Cortex-A7 , ARM Cortex-A8 , ARM Cortex-A9 , ARM Cortex-A12 , ARM Cortex-A15 , ARM Cortex-A17Qualcomm Scorpion / Krait , PJ4/Sheeva, Apple Swift ( A6 , A6X )
ARMv8-A
32
ARM Cortex-A32 [71]
Solicitud
64 /32
ARM Cortex-A35 , [72] ARM Cortex-A53 , ARM Cortex-A57 , [73] ARM Cortex-A72 , [74] ARM Cortex-A73 [75]X-Gene , Nvidia Denver 1/2 , Cavium ThunderX , AMD K12 , Apple Cyclone ( A7 ), Typhoon ( A8 , A8X ), Twister ( A9 , A9X ), Hurricane+Zephyr ( A10 , A10X ), Qualcomm Kryo y Samsung M1/M2 ("Mongoose")/M3 ("Meerkat")
Solicitud
[76] [1] [77] [78] [79] [80]
ARM Cortex-A34 [81]
Solicitud
ARMv8.1-A
64/32
Por confirmarThunderX2 de Cavium
Solicitud
[82]
ARMv8.2-A
64/32
ARM Cortex-A55 , [83] ARM Cortex-A75 , [84] ARM Cortex-A76 , [85] ARM Cortex-A77 , ARM Cortex -A78 , ARM Cortex-X1 , ARM Neoverse N1Nvidia Carmel , Samsung M4 ("Cheetah"), Fujitsu A64FX (ARMv8 SVE de 512 bits)
Solicitud
[86] [87] [88]
64
ARM Cortex-A65 , ARM Neoverse E1 con subprocesamiento múltiple simultáneo (SMT), ARM Cortex-A65AE [89] (que también tiene, por ejemplo, ARMv8.4 Dot Product; creado para tareas críticas de seguridad como sistemas avanzados de asistencia al conductor (ADAS))Apple Monsoon+Mistral ( A11 ) (septiembre de 2017)
Solicitud
ARMv8.3-A
64/32
Por confirmar
Solicitud
64
Por confirmarApple Vortex+Tempest ( A12 , A12X , A12Z ), Marvell ThunderX3 (v8.3+) [90]
Solicitud
ARMv8.4-A
64/32
Por confirmar
Solicitud
64
ARM Neoverse V1Apple Lightning+Thunder ( A13 ), Apple Firestorm+Icestorm ( A14 , M1 )
Solicitud
ARMv8.5-A
64/32
Por confirmar
Solicitud
64
Por confirmar
Solicitud
ARMv8.6-A
64
Por confirmarManzana Avalanche+Blizzard ( A15 , M2 ), Manzana Everest+Sawtooth ( A16 ) [91]
Solicitud
ARMv8.7-A
64
Por confirmar
Solicitud
[92]
ARMv8.8-A
64
Por confirmar
Solicitud
ARMv8.9-A
64
Por confirmar
Solicitud
ARMv9.0-A
64
ARM Cortex-A510 , ARM Cortex-A710 , ARM Cortex-A715 , ARM Cortex-X2 , ARM Cortex-X3 , ARM Neoverse E2 , ARM Neoverse N2 , ARM Neoverse V2
Solicitud
[93] [94]
ARMv9.1-A
64
Por confirmar
Solicitud
ARMv9.2-A
64
ARM Cortex-A520 , ARM Cortex-A720 , ARM Cortex-X4 , ARM Neoverse V3 , [95] ARM Cortex-X925 [96]Manzana M4 [97]
Solicitud
ARMv9.3-A
64
Por confirmar
Solicitud
[98]
ARMv9.4-A
64
Por confirmar
Solicitud
[99]
ARMv9.5-A
64
Por confirmar
Solicitud
[100]
ARMv9.6-A
64
Por confirmar
Solicitud
[101]
  1. ^ ab Aunque la mayoría de las rutas de datos y los registros de CPU en los primeros procesadores ARM eran de 32 bits, la memoria direccionable estaba limitada a 26 bits ; los bits superiores, entonces, se usaban para indicadores de estado en el registro del contador del programa.
  2. ^ abc ARMv3 incluía un modo de compatibilidad para admitir las direcciones de 26 bits de versiones anteriores de la arquitectura. Este modo de compatibilidad era opcional en ARMv4 y se eliminó por completo en ARMv5.

Arm proporciona una lista de proveedores que implementan núcleos ARM en sus diseños (productos estándar específicos de la aplicación (ASSP), microprocesadores y microcontroladores). [102]

Ejemplos de aplicaciones de núcleos ARM

Tronsmart MK908, una "mini PC" Android de cuatro núcleos basada en Rockchip , con una tarjeta microSD al lado para comparar el tamaño

Los núcleos ARM se utilizan en varios productos, en particular en PDA y teléfonos inteligentes . Algunos ejemplos informáticos son los dispositivos Surface , Surface 2 y Pocket PC de primera generación de Microsoft (posteriores a 2002 ), los iPads de Apple , las tabletas Eee Pad Transformer de Asus y varios portátiles Chromebook . Otros ejemplos incluyen los teléfonos inteligentes iPhone y los reproductores multimedia portátiles iPod de Apple , las cámaras digitales Canon PowerShot , el híbrido Nintendo Switch , el procesador de seguridad Wii y las consolas de juegos portátiles 3DS , y los sistemas de navegación paso a paso TomTom .

En 2005, Arm participó en el desarrollo de la computadora SpiNNaker de la Universidad de Manchester , que utilizaba núcleos ARM para simular el cerebro humano . [103]

Los chips ARM también se utilizan en Raspberry Pi , BeagleBoard , BeagleBone , PandaBoard y otros ordenadores de placa única , porque son muy pequeños, económicos y consumen muy poca energía.

Arquitectura de 32 bits

Se utilizó un ARMv7 para alimentar versiones anteriores de las populares computadoras de placa única Raspberry Pi, como esta Raspberry Pi 2 de 2015.
También se utiliza un ARMv7 para alimentar la familia de computadoras de placa única CuBox .

La arquitectura ARM de 32 bits ( ARM32 ), como ARMv7-A (que implementa AArch32; consulte la sección sobre Armv8-A para obtener más información), fue la arquitectura más utilizada en dispositivos móviles en 2011. [actualizar][ 53]

Desde 1995, varias versiones del Manual de referencia de arquitectura ARM (consulte § Enlaces externos) han sido la principal fuente de documentación sobre la arquitectura y el conjunto de instrucciones de los procesadores ARM, y distinguen las interfaces que todos los procesadores ARM deben admitir (como la semántica de las instrucciones) de los detalles de implementación que pueden variar. La arquitectura ha evolucionado con el tiempo y la versión siete de la arquitectura, ARMv7, define tres "perfiles" de arquitectura:

  • Perfil A, el perfil de "Aplicación", implementado por núcleos de 32 bits de la serie Cortex-A y por algunos núcleos que no son ARM
  • Perfil R, el perfil "en tiempo real", implementado por los núcleos de la serie Cortex-R
  • Perfil M, el perfil "Microcontrolador", implementado por la mayoría de los núcleos de la serie Cortex-M

Aunque los perfiles de arquitectura se definieron primero para ARMv7, ARM posteriormente definió la arquitectura ARMv6-M (utilizada por Cortex M0 / M0+ / M1 ) como un subconjunto del perfil ARMv7-M con menos instrucciones.

Modos de CPU

Excepto en el perfil M, la arquitectura ARM de 32 bits especifica varios modos de CPU, según las características de la arquitectura implementadas. En cualquier momento, la CPU puede estar en un solo modo, pero puede cambiar de modo debido a eventos externos (interrupciones) o programáticamente. [104]

  • Modo de usuario: el único modo sin privilegios.
  • Modo FIQ: un modo privilegiado al que se ingresa siempre que el procesador acepta una solicitud de interrupción rápida .
  • Modo IRQ: un modo privilegiado al que se ingresa siempre que el procesador acepta una interrupción.
  • Modo supervisor (svc): un modo privilegiado al que se ingresa siempre que se reinicia la CPU o cuando se ejecuta una instrucción SVC.
  • Modo de aborto: un modo privilegiado al que se ingresa siempre que ocurre una excepción de aborto de precarga o de aborto de datos.
  • Modo indefinido: un modo privilegiado al que se ingresa siempre que ocurre una excepción de instrucción indefinida.
  • Modo de sistema (ARMv4 y superior): el único modo privilegiado al que no se ingresa mediante una excepción. Solo se puede ingresar ejecutando una instrucción que escriba explícitamente en los bits de modo del Registro de estado del programa actual (CPSR) desde otro modo privilegiado (no desde el modo de usuario).
  • Modo de monitor (extensiones de seguridad ARMv6 y ARMv7, ARMv8 EL3): se introduce un modo de monitor para admitir la extensión TrustZone en núcleos ARM.
  • Modo Hyp (extensiones de virtualización ARMv7, ARMv8 EL2): un modo de hipervisor que admite los requisitos de virtualización de Popek y Goldberg para el funcionamiento no seguro de la CPU. [105] [106]
  • Modo de subproceso (ARMv6-M, ARMv7-M, ARMv8-M): un modo que se puede especificar como privilegiado o no privilegiado. También se puede especificar si se utiliza el puntero de pila principal (MSP) o el puntero de pila de proceso (PSP) en el registro CONTROL con acceso privilegiado. Este modo está diseñado para tareas de usuario en el entorno RTOS, pero se utiliza normalmente en hardware físico para superbucles.
  • Modo controlador (ARMv6-M, ARMv7-M, ARMv8-M): un modo dedicado al manejo de excepciones (excepto las REINICIO, que se manejan en modo de subproceso). El modo controlador siempre utiliza MSP y funciona en un nivel privilegiado.

Conjunto de instrucciones

La implementación original (y posterior) de ARM estaba cableada sin microcódigo , como el procesador 6502 de 8 bits mucho más simple utilizado en las microcomputadoras Acorn anteriores.

La arquitectura ARM de 32 bits (y la arquitectura de 64 bits en su mayor parte) incluye las siguientes características RISC:

  • Arquitectura de carga y almacenamiento .
  • La versión original de la arquitectura no admite accesos no alineados a la memoria . ARMv6 y posteriores, excepto algunas versiones de microcontroladores, admiten accesos no alineados para instrucciones de carga/almacenamiento de media palabra y de una sola palabra con algunas limitaciones, como la falta de atomicidad garantizada . [107] [108]
  • Archivo de registro uniforme de 16 × 32 bits (incluye el contador de programa, el puntero de pila y el registro de enlace).
  • Se arregló el ancho de instrucción de 32 bits para facilitar la decodificación y la segmentación , a costa de una menor densidad de código . Más tarde, el conjunto de instrucciones Thumb agregó instrucciones de 16 bits y aumentó la densidad de código.
  • Ejecución principalmente de un solo ciclo de reloj.

Para compensar el diseño más simple, en comparación con procesadores como el Intel 80286 y el Motorola 68020 , se utilizaron algunas características de diseño adicionales:

Instrucciones aritméticas

ARM incluye operaciones aritméticas de números enteros para sumar, restar y multiplicar; algunas versiones de la arquitectura también admiten operaciones de división.

ARM admite multiplicaciones de 32 bits × 32 bits con un resultado de 32 bits o de 64 bits, aunque los núcleos Cortex-M0 / M0+ / M1 no admiten resultados de 64 bits. [109] Algunos núcleos ARM también admiten multiplicaciones de 16 bits × 16 bits y de 32 bits × 16 bits.

Las instrucciones de división solo están incluidas en las siguientes arquitecturas ARM:

  • Las arquitecturas Armv7-M y Armv7E-M siempre incluyen instrucciones de división. [110]
  • La arquitectura Armv7-R siempre incluye instrucciones de división en el conjunto de instrucciones Thumb, pero opcionalmente en su conjunto de instrucciones de 32 bits. [111]
  • La arquitectura Armv7-A incluye opcionalmente las instrucciones de división. Es posible que las instrucciones no se implementen, o que se implementen solo en el conjunto de instrucciones Thumb, o que se implementen tanto en el conjunto de instrucciones Thumb como en el ARM, o que se implementen si se incluyen las extensiones de virtualización. [111]

Registros

Registros en todos los modos de CPU
usuariosistemaservicioAcerca deyirqfiq
R0
R1
R2
R3
R4
R5
R6
R7
R8R8_fiq
R9R9_fiq
R10R10_fiq
R11R11_fiq
R12R12_fiq
R13R13_servicioR13_aproximadamenteR13_yR13_irqR13_fiq
R14R14_servicioR14_aproximadamenteR14_undR14_irqR14_fiq
R15
CPSR
Servicio SPSRSPSR_abtSPSR_yirq_SPSRFicha técnica SPSR

Los registros R0 a R7 son los mismos en todos los modos de CPU; nunca están bancarizados.

Los registros R8 a R12 son los mismos en todos los modos de CPU, excepto en el modo FIQ. El modo FIQ tiene sus propios registros R8 a R12.

R13 y R14 se almacenan en todos los modos de CPU privilegiados, excepto en el modo de sistema. Es decir, cada modo al que se puede ingresar debido a una excepción tiene su propio R13 y R14. Estos registros generalmente contienen el puntero de pila y la dirección de retorno de las llamadas de función, respectivamente.

Alias:

El registro de estado del programa actual (CPSR) tiene los siguientes 32 bits. [112]

  • M (bits 0–4) son los bits del modo del procesador.
  • T (bit 5) es el bit de estado del pulgar.
  • F (bit 6) es el bit de desactivación de FIQ.
  • I (bit 7) es el bit de desactivación de IRQ.
  • A (bit 8) es el bit de desactivación de cancelación de datos imprecisos.
  • E (bit 9) es el bit de orden de bytes de los datos.
  • IT (bits 10-15 y 25-26) son los bits de estado si-entonces.
  • GE (bits 16–19) son los bits mayores o iguales a.
  • DNM (bits 20–23) son los bits que no se modifican.
  • J (bit 24) es el bit de estado de Java.
  • Q (bit 27) es el bit de desbordamiento persistente.
  • V (bit 28) es el bit de desbordamiento.
  • C (bit 29) es el bit de transporte/préstamo/extensión.
  • Z (bit 30) es el bit cero.
  • N (bit 31) es el bit negativo/menor que.

Ejecución condicional

Casi todas las instrucciones ARM tienen una función de ejecución condicional llamada predicación , que se implementa con un selector de código de condición de 4 bits (el predicado). Para permitir la ejecución incondicional, uno de los códigos de cuatro bits hace que la instrucción se ejecute siempre. La mayoría de las demás arquitecturas de CPU solo tienen códigos de condición en las instrucciones de bifurcación. [113]

Aunque el predicado ocupa cuatro de los 32 bits de un código de instrucción y, por lo tanto, reduce significativamente los bits de codificación disponibles para desplazamientos en instrucciones de acceso a memoria, evita las instrucciones de bifurcación al generar código para ifinstrucciones pequeñas . Además de eliminar las instrucciones de bifurcación en sí, esto preserva el proceso de obtención/decodificación/ejecución a costa de solo un ciclo por instrucción omitida.

Un algoritmo que proporciona un buen ejemplo de ejecución condicional es el algoritmo euclidiano basado en la resta para calcular el máximo común divisor . En el lenguaje de programación C , el algoritmo se puede escribir de la siguiente manera:

int gcd ( int a , int b ) { while ( a != b ) // Entramos al bucle cuando a < b o a > b, pero no cuando a == b if ( a > b ) // Cuando a > b hacemos esto a -= b ; else // Cuando a < b hacemos aquello (no se necesita "if (a < b)" ya que a != b está marcado en la condición while) b -= a ; return a ; }                         

El mismo algoritmo se puede reescribir de una manera más cercana a las instrucciones ARM objetivo de la siguiente manera:

bucle : // Comparar a y b GT = a > b ; LT = a < b ; NE = a != b ;                 // Realizar operaciones basadas en los resultados de las banderas si ( GT ) a -= b ; // Restar *solo* si es mayor que si ( LT ) b -= a ; // Restar *solo* si es menor que si ( NE ) goto loop ; // Repetir *solo* si los valores comparados no fueron iguales devolver a ;                   

y codificado en lenguaje ensamblador como:

; asignar a al registro r0, b al r1 bucle: CMP r0 , r1 ; establecer condición "NE" si (a ≠ b), ; "GT" si (a > b), ; o "LT" si (a < b) SUBGT r0 , r0 , r1 ; si "GT" (Mayor que), entonces a = a − b SUBLT r1 , r1 , r0 ; si "LT" (Menor que), entonces b = b − a BNE bucle ; si "NE" (No igual), entonces bucle B lr ; retorna                      

que evita las ramificaciones alrededor de las cláusulas thenand else. Si r0y r1son iguales, entonces ninguna de las SUBinstrucciones se ejecutará, eliminando la necesidad de una ramificación condicional para implementar la whilecomprobación en la parte superior del bucle, por ejemplo, si se SUBLEhubiera utilizado (menor o igual que).

Una de las formas en que el código Thumb proporciona una codificación más densa es eliminar el selector de cuatro bits de las instrucciones que no son de bifurcación.

Otras características

Otra característica del conjunto de instrucciones es la capacidad de incorporar cambios y rotaciones en las instrucciones de procesamiento de datos (aritméticas, lógicas y de movimiento registro-registro), de modo que, por ejemplo, la declaración en lenguaje C :

a += ( j << 2 );    

Podría representarse como una instrucción de una palabra y un ciclo: [114]

AGREGAR Ra , Ra , Rj , LSL #2     

Esto da como resultado que el programa ARM típico sea más denso de lo esperado con menos accesos a la memoria; por lo tanto, la canalización se utiliza de manera más eficiente.

El procesador ARM también tiene características que rara vez se ven en otras arquitecturas RISC, como el direccionamiento relativo a PC (de hecho, en el ARM de 32 bits [1] el PC es uno de sus 16 registros) y modos de direccionamiento pre y post incremento.

El conjunto de instrucciones ARM ha aumentado con el tiempo. Algunos de los primeros procesadores ARM (anteriores a ARM7TDMI), por ejemplo, no tienen instrucción para almacenar una cantidad de dos bytes.

Tuberías y otros problemas de implementación

El ARM7 y las implementaciones anteriores tienen un pipeline de tres etapas ; las etapas son la búsqueda, la decodificación y la ejecución. Los diseños de mayor rendimiento, como el ARM9, tienen pipelines más profundos: Cortex-A8 tiene trece etapas. Los cambios de implementación adicionales para un mayor rendimiento incluyen un sumador más rápido y una lógica de predicción de bifurcaciones más extensa . La diferencia entre los núcleos ARM7DI y ARM7DMI, por ejemplo, fue un multiplicador mejorado; de ahí la "M" agregada.

Coprocesadores

La arquitectura ARM (pre-Armv8) proporciona una forma no intrusiva de ampliar el conjunto de instrucciones mediante "coprocesadores" que pueden ser direccionados mediante MCR, MRC, MRRC, MCRR y otras instrucciones similares. El espacio de coprocesadores está dividido lógicamente en 16 coprocesadores con números del 0 al 15, y el coprocesador 15 (cp15) está reservado para algunas funciones de control típicas, como la gestión de las memorias caché y la operación de la MMU en los procesadores que tienen uno.

En las máquinas basadas en ARM, los dispositivos periféricos suelen conectarse al procesador mediante la asignación de sus registros físicos al espacio de memoria ARM, al espacio del coprocesador o mediante la conexión a otro dispositivo (un bus) que, a su vez, se conecta al procesador. Los accesos al coprocesador tienen una latencia menor, por lo que algunos periféricos (por ejemplo, un controlador de interrupciones XScale) son accesibles de ambas formas: a través de la memoria y a través de los coprocesadores.

En otros casos, los diseñadores de chips solo integran hardware mediante el mecanismo de coprocesador. Por ejemplo, un motor de procesamiento de imágenes podría ser un pequeño núcleo ARM7TDMI combinado con un coprocesador que tiene operaciones especializadas para admitir un conjunto específico de primitivas de transcodificación de HDTV.

Depuración

Todos los procesadores ARM modernos incluyen funciones de depuración de hardware, lo que permite a los depuradores de software realizar operaciones como detener, avanzar y crear puntos de interrupción del código a partir de un reinicio. Estas funciones se crean utilizando soporte JTAG , aunque algunos núcleos más nuevos admiten opcionalmente el protocolo "SWD" de dos cables propio de ARM. En los núcleos ARM7TDMI, la "D" representaba el soporte de depuración JTAG y la "I" representaba la presencia de un módulo de depuración "EmbeddedICE". Para las generaciones de núcleos ARM7 y ARM9, EmbeddedICE sobre JTAG era un estándar de depuración de facto, aunque no estaba garantizado arquitectónicamente.

La arquitectura ARMv7 define funciones de depuración básicas a nivel arquitectónico. Estas incluyen puntos de interrupción, puntos de vigilancia y ejecución de instrucciones en un "modo de depuración"; funciones similares también estaban disponibles con EmbeddedICE. Se admiten tanto la depuración en "modo de detención" como la de "monitorización". El mecanismo de transporte real utilizado para acceder a las funciones de depuración no está especificado arquitectónicamente, pero las implementaciones generalmente incluyen compatibilidad con JTAG.

Existe una arquitectura de depuración ARM "CoreSight" independiente, que los procesadores ARMv7 no requieren arquitectónicamente.

Puerto de acceso de depuración

El puerto de acceso de depuración (DAP) es una implementación de una interfaz de depuración ARM. [115] Hay dos implementaciones compatibles diferentes, el puerto de depuración JTAG de cable serie (SWJ-DP) y el puerto de depuración de cable serie (SW-DP). [116] CMSIS-DAP es una interfaz estándar que describe cómo varios programas de depuración en una PC host pueden comunicarse a través de USB con el firmware que se ejecuta en un depurador de hardware, que a su vez se comunica a través de SWD o JTAG con una CPU ARM Cortex habilitada para CoreSight. [117] [118] [119]

Instrucciones de mejora del DSP

Para mejorar la arquitectura ARM para el procesamiento de señales digitales y aplicaciones multimedia, se agregaron instrucciones DSP al conjunto de instrucciones. [120] Estas se indican con una "E" en el nombre de las arquitecturas ARMv5TE y ARMv5TEJ. Las variantes E también implican T, D, M e I.

Las nuevas instrucciones son comunes en las arquitecturas de procesadores de señales digitales (DSP). Incluyen variaciones de multiplicación-acumulación con signo , suma y resta saturadas y recuento de ceros iniciales .

Introducida por primera vez en 1999, esta extensión del conjunto de instrucciones del núcleo contrastaba con el coprocesador DSP anterior de ARM conocido como Piccolo, que empleaba un conjunto de instrucciones distinto e incompatible cuya ejecución implicaba un contador de programa separado. [121] Las instrucciones de Piccolo empleaban un archivo de registro distinto de dieciséis registros de 32 bits, con algunas instrucciones que combinaban registros para su uso como acumuladores de 48 bits y otras instrucciones que abordaban medios registros de 16 bits. Algunas instrucciones podían operar en dos de esos valores de 16 bits en paralelo. La comunicación con el archivo de registro de Piccolo implicaba la carga en Piccolo y el almacenamiento desde las instrucciones del coprocesador Piccolo a través de dos búferes de ocho entradas de 32 bits. Descrito como reminiscente de otros enfoques, en particular el SH-DSP de Hitachi y el 68356 de Motorola, Piccolo no empleaba memoria local dedicada y dependía del ancho de banda del núcleo ARM para la recuperación de operandos del DSP, lo que afectaba al rendimiento concurrente. [122] El conjunto de instrucciones diferenciadas de Piccolo también resultó no ser un "buen objetivo para el compilador". [121]

Extensiones SIMD para multimedia

Introducido en la arquitectura ARMv6, este fue un precursor de SIMD avanzado, también llamado Neon. [123]

Jazmín

Jazelle DBX (Direct Bytecode eXecution) es una técnica que permite ejecutar el bytecode de Java directamente en la arquitectura ARM como un tercer estado de ejecución (y conjunto de instrucciones) junto con el modo ARM y Thumb existentes. La compatibilidad con este estado se indica mediante la "J" en la arquitectura ARMv5TEJ y en los nombres de los núcleos ARM9EJ-S y ARM7EJ-S. La compatibilidad con este estado es necesaria a partir de ARMv6 (excepto para el perfil ARMv7-M), aunque los núcleos más nuevos solo incluyen una implementación trivial que no proporciona aceleración de hardware.

Pulgar

Para mejorar la densidad del código compilado, los procesadores desde el ARM7TDMI (lanzado en 1994 [124] ) han incorporado el conjunto de instrucciones comprimidas Thumb , que tienen su propio estado. (La "T" en "TDMI" indica la característica Thumb). Cuando está en este estado, el procesador ejecuta el conjunto de instrucciones Thumb, una codificación compacta de 16 bits para un subconjunto del conjunto de instrucciones ARM. [125] La mayoría de las instrucciones Thumb se asignan directamente a instrucciones ARM normales. El ahorro de espacio se produce al hacer implícitos algunos de los operandos de instrucción y limitar el número de posibilidades en comparación con las instrucciones ARM ejecutadas en el estado del conjunto de instrucciones ARM.

En Thumb, los códigos de operación de 16 bits tienen menos funcionalidad. Por ejemplo, solo las bifurcaciones pueden ser condicionales y muchos códigos de operación están restringidos a acceder solo a la mitad de todos los registros de propósito general de la CPU. Los códigos de operación más cortos brindan una densidad de código mejorada en general, aunque algunas operaciones requieren instrucciones adicionales. En situaciones en las que el puerto de memoria o el ancho del bus están restringidos a menos de 32 bits, los códigos de operación más cortos de Thumb permiten un mayor rendimiento en comparación con el código ARM de 32 bits, ya que es posible que se deba cargar menos código de programa en el procesador sobre el ancho de banda de memoria restringido.

A diferencia de las arquitecturas de procesador con instrucciones de longitud variable (16 o 32 bits), como Cray-1 y Hitachi SuperH , los conjuntos de instrucciones ARM y Thumb existen independientemente uno del otro. El hardware integrado, como Game Boy Advance , normalmente tiene una pequeña cantidad de RAM accesible con una ruta de datos completa de 32 bits; a la mayoría se accede a través de una ruta de datos secundaria de 16 bits o más estrecha. En esta situación, normalmente tiene sentido compilar el código Thumb y optimizar manualmente algunas de las secciones que consumen más CPU utilizando instrucciones ARM de 32 bits completas, colocando estas instrucciones más amplias en la memoria accesible por bus de 32 bits.

El primer procesador con un decodificador de instrucciones Thumb fue el ARM7TDMI. Todos los procesadores que admiten conjuntos de instrucciones de 32 bits, a partir de ARM9 e incluyendo XScale, han incluido un decodificador de instrucciones Thumb. Incluye instrucciones adoptadas de Hitachi SuperH (1992), que fue licenciado por ARM. [126] Las familias de procesadores más pequeñas de ARM (Cortex M0 y M1) implementan solo el conjunto de instrucciones Thumb de 16 bits para obtener el máximo rendimiento en aplicaciones de menor costo. Los procesadores ARM que no admiten el direccionamiento de 32 bits también omiten Thumb.

Pulgar-2

La tecnología Thumb-2 se introdujo en el núcleo ARM1156 , anunciado en 2003. Thumb-2 amplía el conjunto de instrucciones de 16 bits limitado de Thumb con instrucciones adicionales de 32 bits para darle más amplitud al conjunto de instrucciones, produciendo así un conjunto de instrucciones de longitud variable. Un objetivo declarado para Thumb-2 era lograr una densidad de código similar a Thumb con un rendimiento similar al conjunto de instrucciones ARM en una memoria de 32 bits.

Thumb-2 amplía el conjunto de instrucciones Thumb con manipulación de campos de bits, ramificaciones de tablas y ejecución condicional. Al mismo tiempo, el conjunto de instrucciones ARM se amplió para mantener una funcionalidad equivalente en ambos conjuntos de instrucciones. Un nuevo "lenguaje ensamblador unificado" (UAL) admite la generación de instrucciones Thumb o ARM a partir del mismo código fuente; las versiones de Thumb que se ven en procesadores ARMv7 son esencialmente tan capaces como el código ARM (incluida la capacidad de escribir controladores de interrupciones). Esto requiere un poco de cuidado y el uso de una nueva instrucción "IT" (si-entonces), que permite ejecutar hasta cuatro instrucciones sucesivas en función de una condición probada o de su inversa. Al compilar en código ARM, esto se ignora, pero al compilar en Thumb genera una instrucción real. Por ejemplo:

; si (r0 == r1) CMP r0 , r1 ITE EQ ; ARM: sin código... Thumb: instrucción IT ; entonces r0 = r2; MOVEQ r0 , r2 ; ARM: condicional; Thumb: condición a través de ITE 'T' (entonces) ; de lo contrario r0 = r3; MOVNE r0 , r3 ; ARM: condicional; Thumb: condición a través de ITE 'E' (de lo contrario) ; recuerde que la instrucción Thumb MOV no tiene bits para codificar "EQ" o "NE".          

Todos los chips ARMv7 admiten el conjunto de instrucciones Thumb. Todos los chips de la serie Cortex-A que admiten ARMv7, todos los chips de la serie Cortex-R y todos los chips de la serie ARM11 admiten tanto el "estado del conjunto de instrucciones ARM" como el "estado del conjunto de instrucciones Thumb", mientras que los chips de la serie Cortex-M admiten únicamente el conjunto de instrucciones Thumb. [127] [128] [129]

Entorno de ejecución Thumb (ThumbEE)

ThumbEE (erróneamente llamado Thumb-2EE en alguna documentación ARM), que se comercializó como Jazelle RCT [130] (Runtime Compilation Target), se anunció en 2005 y quedó obsoleto en 2011. Apareció por primera vez en el procesador Cortex-A8 . ThumbEE es un cuarto estado del conjunto de instrucciones, que realiza pequeños cambios en el conjunto de instrucciones extendido Thumb-2. Estos cambios hacen que el conjunto de instrucciones sea particularmente adecuado para el código generado en tiempo de ejecución (por ejemplo, mediante la compilación JIT ) en entornos de ejecución administrados . ThumbEE es un objetivo para lenguajes como Java , C# , Perl y Python , y permite que los compiladores JIT generen código compilado más pequeño sin reducir el rendimiento. [ cita requerida ]

Las nuevas características que ofrece ThumbEE incluyen comprobaciones automáticas de puntero nulo en cada instrucción de carga y almacenamiento, una instrucción para realizar una comprobación de límites de matriz e instrucciones especiales que llaman a un controlador. Además, debido a que utiliza la tecnología Thumb-2, ThumbEE proporciona acceso a los registros r8–r15 (donde se guarda el estado de la máquina virtual Java Jazelle/DBX). [131] Los controladores son pequeñas secciones de código a las que se llama con frecuencia, que se utilizan habitualmente para implementar lenguajes de alto nivel, como la asignación de memoria para un nuevo objeto. Estos cambios se deben a la reutilización de un puñado de códigos de operación y a saber que el núcleo está en el nuevo estado de ThumbEE.

El 23 de noviembre de 2011, Arm dejó de usar el conjunto de instrucciones ThumbEE, [132] y Armv8 eliminó el soporte para ThumbEE.

Punto flotante (VFP)

La tecnología VFP (Vector Floating Point) es una extensión del coprocesador de unidad de punto flotante (FPU) de la arquitectura ARM [133] (implementada de manera diferente en Armv8; los coprocesadores no están definidos allí). Proporciona computación de punto flotante de precisión simple y doble de bajo costo totalmente compatible con el estándar ANSI/IEEE Std 754-1985 para aritmética binaria de punto flotante . VFP proporciona computación de punto flotante adecuada para un amplio espectro de aplicaciones, como PDA, teléfonos inteligentes, compresión y descompresión de voz, gráficos tridimensionales y audio digital, impresoras, decodificadores y aplicaciones automotrices. La arquitectura VFP fue pensada para soportar la ejecución de instrucciones cortas de "modo vectorial", pero estas operaban en cada elemento vectorial de manera secuencial y, por lo tanto, no ofrecían el rendimiento del verdadero paralelismo vectorial de instrucción única y múltiples datos (SIMD). Por lo tanto, este modo vectorial se eliminó poco después de su introducción, [134] para ser reemplazado por el mucho más poderoso Advanced SIMD, también llamado Neon.

Algunos dispositivos como el ARM Cortex-A8 tienen un módulo VFPLite reducido en lugar de un módulo VFP completo, y requieren aproximadamente diez veces más ciclos de reloj por operación de coma flotante. [135] La arquitectura anterior a Armv8 implementaba coma flotante/SIMD con la interfaz de coprocesador. Otras unidades de coma flotante y/o SIMD que se encuentran en procesadores basados ​​en ARM que utilizan la interfaz de coprocesador incluyen FPA, FPE, iwMMXt , algunas de las cuales se implementaron en software mediante trampas, pero podrían haberse implementado en hardware. Proporcionan algunas de las mismas funciones que VFP, pero no son compatibles con él mediante códigos de operación . FPA10 también proporciona precisión extendida , pero implementa redondeo correcto (requerido por IEEE 754) solo en precisión simple. [136]

VFPv1
Obsoleto
VFPv2
Una extensión opcional del conjunto de instrucciones ARM en las arquitecturas ARMv5TE, ARMv5TEJ y ARMv6. VFPv2 tiene 16 registros FPU de 64 bits.
VFPv3 o VFPv3-D32
Implementado en la mayoría de los procesadores ARMv7 Cortex-A8 y A9. Es compatible con versiones anteriores de VFPv2, excepto que no puede capturar excepciones de punto flotante. VFPv3 tiene 32 registros FPU de 64 bits como estándar, agrega instrucciones VCVT para convertir entre escalar, float y double, agrega modo inmediato a VMOV para que las constantes se puedan cargar en registros FPU.
VFPv3-D16
Igual que el anterior, pero con solo 16 registros FPU de 64 bits. Implementado en procesadores Cortex-R4 y R5 y en el Tegra 2 (Cortex-A9).
VFPv3-F16
Poco común; admite el punto flotante de media precisión IEEE754-2008 (16 bits) como formato de almacenamiento.
VFPv4 o VFPv4-D32
Implementado en procesadores ARMv7 Cortex-A12 y A15, Cortex-A7 tiene opcionalmente VFPv4-D32 en el caso de una FPU con Neon. [137] VFPv4 tiene 32 registros FPU de 64 bits como estándar, agrega soporte de media precisión como formato de almacenamiento e instrucciones de multiplicación-acumulación fusionadas a las características de VFPv3.
VFPv4-D16
Igual que el anterior, pero con solo 16 registros FPU de 64 bits. Implementado en procesadores Cortex-A5 y A7 en el caso de una FPU sin Neon. [137]
VFPv5-D16-M
Implementado en Cortex-M7 cuando existe la opción de núcleo de punto flotante de precisión simple y doble.

En Debian Linux y derivados como Ubuntu y Linux Mint , armhf ( ARM hard float ) hace referencia a la arquitectura ARMv7, incluida la extensión de hardware de punto flotante adicional VFP3-D16 (y Thumb-2) mencionada anteriormente. Los paquetes de software y las herramientas de compilación cruzada utilizan los sufijos armhf vs. arm/armel para diferenciarlos. [138]

SIMD avanzado (Neón)

La extensión Advanced SIMD (también conocida como Neon o "MPE" Media Processing Engine) es un conjunto combinado de instrucciones SIMD de 64 y 128 bits que proporciona aceleración estandarizada para aplicaciones de procesamiento de medios y señales. Neon está incluido en todos los dispositivos Cortex-A8, pero es opcional en los dispositivos Cortex-A9. [139] Neon puede ejecutar la decodificación de audio MP3 en CPU que funcionen a 10 MHz, y puede ejecutar el códec de voz GSM de velocidad múltiple adaptativa (AMR) a 13 MHz. Cuenta con un conjunto de instrucciones completo, archivos de registro separados y hardware de ejecución independiente. [140] Neon admite datos de punto flotante de precisión simple (32 bits) y enteros de 8, 16, 32 y 64 bits y operaciones SIMD para manejar el procesamiento de audio y video, así como el procesamiento de gráficos y juegos. En Neon, SIMD admite hasta 16 operaciones al mismo tiempo. El hardware de Neon comparte los mismos registros de punto flotante que se utilizan en VFP. Dispositivos como ARM Cortex-A8 y Cortex-A9 admiten vectores de 128 bits, pero ejecutarán 64 bits a la vez, [135] mientras que los dispositivos Cortex-A15 más nuevos pueden ejecutar 128 bits a la vez. [141] [142]

Una peculiaridad de Neon en los dispositivos Armv7 es que limpia todos los números subnormales a cero y, como resultado, el compilador GCC no lo usará a menos que -funsafe-math-optimizations, que permite perder desnormalizaciones, esté activado. Neon "mejorado" definido desde que Armv8 no tiene esta peculiaridad, pero a partir de GCC 8.2 aún se requiere el mismo indicador para habilitar las instrucciones Neon. [143] Por otro lado, GCC considera que Neon es seguro en AArch64 para Armv8.

ProjectNe10 es el primer proyecto de código abierto de ARM (desde su inicio; mientras que adquirieron un proyecto más antiguo, ahora llamado Mbed TLS ). La biblioteca Ne10 es un conjunto de funciones comunes y útiles escritas tanto en Neon como en C (para compatibilidad). La biblioteca se creó para permitir a los desarrolladores utilizar optimizaciones de Neon sin aprender Neon, pero también sirve como un conjunto de ejemplos de código intrínseco y de ensamblaje de Neon altamente optimizados para rutinas comunes de procesamiento de imágenes, aritméticas y DSP. El código fuente está disponible en GitHub. [144]

Tecnología ARM Helium

Helium es la extensión vectorial de perfil M (MVE). Agrega más de 150 instrucciones escalares y vectoriales. [145]

Extensiones de seguridad

TrustZone (para el perfil Cortex-A)

Las extensiones de seguridad, comercializadas como tecnología TrustZone, se encuentran en arquitecturas de perfil de aplicación ARMv6KZ y posteriores. Proporcionan una alternativa de bajo costo para agregar otro núcleo de seguridad dedicado a un SoC, al proporcionar dos procesadores virtuales respaldados por control de acceso basado en hardware. Esto permite que el núcleo de la aplicación cambie entre dos estados, denominados mundos (para reducir la confusión con otros nombres para los dominios de capacidad), para evitar que la información se filtre del mundo más confiable al mundo menos confiable. Este cambio de mundo generalmente es ortogonal a todas las demás capacidades del procesador, por lo que cada mundo puede operar independientemente del otro mientras se usa el mismo núcleo. La memoria y los periféricos se enteran entonces del mundo operativo del núcleo y pueden usarlo para proporcionar control de acceso a secretos y códigos en el dispositivo. [146]

Por lo general, se ejecuta un sistema operativo completo en el mundo menos confiable, y un código especializado en seguridad más pequeño en el mundo más confiable, con el objetivo de reducir la superficie de ataque . Las aplicaciones típicas incluyen la funcionalidad DRM para controlar el uso de medios en dispositivos basados ​​en ARM [147] y evitar cualquier uso no autorizado del dispositivo.

En la práctica, dado que los detalles de implementación específicos de las implementaciones patentadas de TrustZone no se han revelado públicamente para su revisión, no está claro qué nivel de garantía se proporciona para un modelo de amenaza determinado , pero no son inmunes a los ataques. [148] [149]

Open Virtualization [150] es una implementación de código abierto de la arquitectura mundial confiable para TrustZone.

AMD ha licenciado e incorporado la tecnología TrustZone en su Tecnología de Procesador Seguro . [151] Las APU de AMD incluyen un procesador Cortex-A5 para manejar el procesamiento seguro, que está habilitado en algunos productos, pero no en todos. [152] [153] [154] De hecho, el núcleo TrustZone Cortex-A5 se había incluido en productos AMD anteriores, pero no se habilitó debido a limitaciones de tiempo. [153]

Samsung Knox utiliza TrustZone para fines tales como detectar modificaciones al kernel, almacenar certificados y atestiguar claves. [155]

TrustZone para Armv8-M (para el perfil Cortex-M)

La extensión de seguridad, comercializada como TrustZone para tecnología Armv8-M, se introdujo en la arquitectura Armv8-M. Si bien contiene conceptos similares a TrustZone para Armv8-A, tiene un diseño arquitectónico diferente, ya que el cambio de mundo se realiza mediante instrucciones de bifurcación en lugar de usar excepciones. También admite el manejo seguro de interrupciones intercaladas desde cualquiera de los mundos independientemente del estado de seguridad actual. En conjunto, estas características proporcionan llamadas de baja latencia al mundo seguro y un manejo de interrupciones receptivo. ARM proporciona una pila de referencia de código de mundo seguro en forma de Trusted Firmware for M y PSA Certified .

Protección de página sin ejecución

A partir de ARMv6, la arquitectura ARM admite la protección de página sin ejecución , conocida como XN , por eXecute Never . [156]

Ampliación de dirección física (LPAE)

La extensión de dirección física grande (LPAE), que extiende el tamaño de la dirección física de 32 bits a 40 bits, se agregó a la arquitectura Armv7-A en 2011. [157]

El tamaño de la dirección física puede ser incluso mayor en procesadores basados ​​en la arquitectura de 64 bits (Armv8-A). Por ejemplo, es de 44 bits en Cortex-A75 y Cortex-A65AE. [158]

Armv8-R y Armv8-M

Las arquitecturas Armv8-R y Armv8-M , anunciadas después de la arquitectura Armv8-A, comparten algunas características con Armv8-A. Sin embargo, Armv8-M no incluye ninguna instrucción AArch64 de 64 bits, y Armv8-R originalmente no incluía ninguna instrucción AArch64; esas instrucciones se agregaron a Armv8-R más tarde.

Armv8.1-M

La arquitectura Armv8.1-M, ​​anunciada en febrero de 2019, es una mejora de la arquitectura Armv8-M. Incluye nuevas funciones, entre las que se incluyen:

  • Una nueva extensión del conjunto de instrucciones vectoriales. La extensión vectorial de perfil M (MVE), o Helium, está destinada a aplicaciones de aprendizaje automático y procesamiento de señales.
  • Mejoras adicionales del conjunto de instrucciones para bucles y ramas (extensión de rama con baja sobrecarga).
  • Instrucciones para soporte de punto flotante de media precisión .
  • Mejora del conjunto de instrucciones para la gestión de TrustZone para la unidad de punto flotante (FPU).
  • Nuevo atributo de memoria en la Unidad de Protección de Memoria (MPU).
  • Las mejoras en la depuración, incluida la Unidad de monitoreo de rendimiento (PMU), la extensión de depuración sin privilegios y el soporte de depuración adicional, se centran en los desarrollos de aplicaciones de procesamiento de señales.
  • Extensión de confiabilidad, disponibilidad y capacidad de servicio (RAS).

Arquitectura de 64/32 bits

Plataforma Armv8-A con chip CPU Cortex A57/A53 MPCore big.LITTLE

Armv8

Armv8-A

Anunciado en octubre de 2011, [13] Armv8-A (a menudo llamado ARMv8 mientras que Armv8-R también está disponible) representa un cambio fundamental en la arquitectura ARM. Admite dos estados de ejecución : un estado de 64 bits llamado AArch64 y un estado de 32 bits llamado AArch32 . En el estado AArch64, se admite un nuevo conjunto de instrucciones A64 de 64 bits ; en el estado AArch32, se admiten dos conjuntos de instrucciones: el conjunto de instrucciones original de 32 bits, llamado A32 , y el conjunto de instrucciones Thumb-2 de 32 bits, llamado T32 . AArch32 proporciona compatibilidad de espacio de usuario con Armv7-A. El estado del procesador puede cambiar en un cambio de nivel de excepción; Esto permite que las aplicaciones de 32 bits se ejecuten en estado AArch32 bajo un sistema operativo de 64 bits cuyo núcleo se ejecuta en estado AArch64, y permite que un sistema operativo de 32 bits se ejecute en estado AArch32 bajo el control de un hipervisor de 64 bits que se ejecuta en estado AArch64. [1] ARM anunció sus núcleos Cortex-A53 y Cortex-A57 el 30 de octubre de 2012. [73] Apple fue el primero en lanzar un núcleo compatible con Armv8-A en un producto de consumo ( Apple A7 en iPhone 5S ). AppliedMicro , utilizando un FPGA , fue el primero en demostrar Armv8-A. [159] El primer SoC Armv8-A de Samsung es el Exynos 5433 utilizado en el Galaxy Note 4 , que presenta dos clústeres de cuatro núcleos Cortex-A57 y Cortex-A53 en una configuración big.LITTLE ; pero sólo se ejecutará en modo AArch32. [160]

Armv8-A incorpora VFPv3/v4 y SIMD avanzado (Neon) a AArch32 y AArch64. También añade instrucciones de criptografía que admiten AES , SHA-1 / SHA-256 y aritmética de campos finitos . [161] AArch64 se introdujo en Armv8-A y su revisión posterior. AArch64 no está incluido en las arquitecturas Armv8-R y Armv8-M de 32 bits.

Un procesador ARMv8-A puede soportar uno o ambos de AArch32 y AArch64; puede soportar AArch32 y AArch64 en niveles de excepción más bajos y solo AArch64 en niveles de excepción más altos. [162] Por ejemplo, el ARM Cortex-A32 soporta solo AArch32, [163] el ARM Cortex-A34 soporta solo AArch64, [164] y el ARM Cortex-A72 soporta tanto AArch64 como AArch32. [165] Un procesador ARMv9-A debe soportar AArch64 en todos los niveles de excepción, y puede soportar AArch32 en EL0. [162] Algunos procesadores ARMv8-A, como Apple M1 y Apple A11 , no soportan aplicaciones AArch32 en absoluto.

Armv8-R

Se agregó soporte AArch64 opcional al perfil Armv8-R, y el primer núcleo ARM que lo implementó fue el Cortex-R82. [166] Agrega el conjunto de instrucciones A64.

Armv9

Armv9-A

Anunciada en marzo de 2021, la arquitectura actualizada se centra en la ejecución segura y la compartimentación . [167] [168]

Sistema de brazo listo

Arm SystemReady, anteriormente llamado Arm ServerReady, es un programa de certificación que ayuda a incorporar sistemas operativos e hipervisores genéricos listos para usar en sistemas basados ​​en Arm, desde servidores de centros de datos hasta dispositivos industriales de IoT y de borde. Los elementos fundamentales del programa son las especificaciones de los requisitos mínimos de hardware y firmware en los que pueden confiar los sistemas operativos e hipervisores. Estas especificaciones son: [169]

  • Arquitectura del sistema base (BSA) [170] y suplementos específicos del segmento de mercado (por ejemplo, suplemento BSA del servidor) [171]
  • Requisitos de arranque base (BBR) [172] y requisitos de seguridad de arranque base (BBR) [173]

Estas especificaciones son desarrolladas conjuntamente por Arm y sus socios en el Comité Asesor de Arquitectura del Sistema (SystemArchAC).

Architecture Compliance Suite (ACS) es la herramienta de prueba que ayuda a comprobar el cumplimiento de estas especificaciones. La especificación de requisitos de Arm SystemReady documenta los requisitos de las certificaciones. [174]

Arm presentó este programa en 2020 en el primer evento DevSummit . Su predecesor, Arm ServerReady, se presentó en 2018 en el evento Arm TechCon. Actualmente, este programa incluye cuatro bandas:

  • SystemReady SR: esta banda es para servidores y estaciones de trabajo que admiten sistemas operativos e hipervisores que esperan interfaces UEFI , ACPI y SMBIOS . Windows, Red Hat Enterprise Linux y VMware ESXi-Arm requieren estas interfaces, mientras que otras distribuciones Linux y BSD también pueden admitirlas. [ Aclaración necesaria ]
  • SystemReady LS (LinuxBoot System): esta banda es para servidores que los hiperescaladores utilizan para soportar sistemas operativos Linux que esperan el firmware LinuxBoot junto con las interfaces ACPI y SMBIOS.
  • SystemReady ES (sistema integrado): esta banda es para dispositivos IoT y de borde industrial que admiten sistemas operativos e hipervisores que esperan interfaces UEFI, ACPI y SMBIOS. Windows IoT Enterprise, Red Hat Enterprise Linux y VMware ESXi-Arm requieren estas interfaces, mientras que otras distribuciones Linux y BSD también pueden admitirlas. [ Aclaración necesaria ]
  • SystemReady IR (IoT Ready): esta banda es para dispositivos IoT y de borde industrial que admiten sistemas operativos que esperan interfaces UEFI y devicetree . Linux integrado (por ejemplo, Yocto ) y algunas distribuciones Linux/BSD (por ejemplo, Fedora, Ubuntu, Debian y OpenSUSE) también pueden admitirlo. [ Aclaración necesaria ]

Certificado por PSA

PSA Certified , anteriormente denominada Platform Security Architecture, es un marco de seguridad y un esquema de evaluación independientes de la arquitectura. Su objetivo es ayudar a proteger los dispositivos de Internet de las cosas (IoT) integrados en procesadores de sistema en un chip (SoC). [175] Se introdujo para aumentar la seguridad en los casos en que un entorno de ejecución totalmente confiable es demasiado grande o complejo. [176]

La arquitectura fue presentada por Arm en 2017 en el evento anual TechCon . [176] [177] Aunque el esquema es independiente de la arquitectura, se implementó por primera vez en núcleos de procesador Arm Cortex-M destinados al uso de microcontroladores. PSA Certified incluye modelos de amenazas y análisis de seguridad disponibles de forma gratuita que demuestran el proceso para decidir sobre las características de seguridad en productos comunes de IoT. [178] También proporciona paquetes de interfaz de programación de aplicaciones (API) de descarga gratuita, especificaciones arquitectónicas, implementaciones de firmware de código abierto y suites de pruebas relacionadas. [179]

Tras el desarrollo del marco de seguridad de la arquitectura en 2017, el esquema de garantía PSA Certified se lanzó dos años después en Embedded World en 2019. [180] PSA Certified ofrece un esquema de evaluación de seguridad de múltiples niveles para proveedores de chips, proveedores de sistemas operativos y fabricantes de dispositivos IoT. [181] La presentación de Embedded World presentó a los proveedores de chips la Certificación de Nivel 1. Al mismo tiempo, se presentó un borrador de protección de Nivel 2. [182] La certificación de Nivel 2 se convirtió en un estándar utilizable en febrero de 2020. [183]

La certificación fue creada por PSA Joint Stakeholders para permitir un enfoque de seguridad por diseño para un conjunto diverso de productos de IoT. Las especificaciones de PSA Certified son independientes de la implementación y la arquitectura, por lo que se pueden aplicar a cualquier chip, software o dispositivo. [184] [182] La certificación también elimina la fragmentación de la industria para los fabricantes y desarrolladores de productos de IoT . [185]

Compatibilidad con sistemas operativos

Sistemas operativos de 32 bits

Sistemas operativos históricos

El primer ordenador personal basado en ARM de 32 bits, el Acorn Archimedes , fue pensado originalmente para ejecutar un ambicioso sistema operativo llamado ARX . Las máquinas se entregaban con RISC OS , que también se utilizó en sistemas posteriores basados ​​en ARM de Acorn y otros proveedores. Algunas de las primeras máquinas Acorn también podían ejecutar un puerto Unix llamado RISC iX . (No debe confundirse con RISC/os , una variante contemporánea de Unix para la arquitectura MIPS).

Sistemas operativos integrados

La arquitectura ARM de 32 bits es compatible con una gran cantidad de sistemas operativos integrados y en tiempo real , incluidos:

Sistemas operativos de dispositivos móviles

A partir de marzo de 2024, la arquitectura ARM de 32 bits solía ser el entorno de hardware principal para la mayoría de los sistemas operativos de dispositivos móviles, como los siguientes, pero muchas de estas plataformas, como Android y Apple iOS, han evolucionado a la arquitectura ARM de 64 bits:

Anteriormente, pero ahora descontinuado:

Sistemas operativos de escritorio y servidor

La arquitectura ARM de 32 bits es compatible con RISC OS y con varios sistemas operativos tipo Unix, incluidos:

Sistemas operativos de 64 bits

Sistemas operativos integrados

Sistemas operativos de dispositivos móviles

Sistemas operativos de escritorio y servidor

Portabilidad a sistemas operativos ARM de 32 o 64 bits

Las aplicaciones de Windows recompiladas para ARM y vinculadas con Winelib, del proyecto Wine , pueden ejecutarse en ARM de 32 bits o 64 bits en Linux, FreeBSD u otros sistemas operativos compatibles. [214] [215] Los binarios x86, por ejemplo, cuando no están compilados especialmente para ARM, se han demostrado en ARM usando QEMU con Wine (en Linux y más), [ cita requerida ] pero no funcionan a plena velocidad o con la misma capacidad que con Winelib.

Notas

  1. ^ Utilizando palabras de 32 bits, 4 Mbit/s corresponden a 1 MIPS .
  2. ^ Las referencias disponibles no mencionan qué equipo de diseño era, pero dado el tiempo y la historia conocida de los diseños de la época, es probable que este fuera el equipo de National Semiconductor cuyo NS32016 sufría una gran cantidad de errores.
  3. ^ Matt Evans señala que parece que las versiones más rápidas simplemente fueron ubicadas en posiciones más altas y no parecen tener cambios subyacentes. [35]

Véase también

Referencias

Citas

  1. ^ abcdef Grisenthwaite, Richard (2011). «ARMv8-A Technology Preview» (PDF) . Archivado desde el original (PDF) el 11 de noviembre de 2011. Consultado el 31 de octubre de 2011 .
  2. ^ "6.1.2.1 Convenciones de uso de registros de VFP". Estándar de llamada a procedimiento para la arquitectura ARM . Arm Holdings . 6 de octubre de 2023 . Consultado el 22 de agosto de 2024 .
  3. ^ ab Wilson, Roger (2 de noviembre de 1988). "Algunos datos sobre la máquina RISC de Acorn". Grupo de noticias : comp.arch . Consultado el 25 de mayo de 2007 .
  4. ^ ab Hachman, Mark (14 de octubre de 2002). "Los núcleos ARM alcanzan el territorio 3G". ExtremeTech . Consultado el 24 de mayo de 2018 .
  5. ^ Turley, Jim (18 de diciembre de 2002). "La solución del dos por ciento". Integrado . Consultado el 14 de febrero de 2023 .
  6. ^ Cutress, Ian (22 de junio de 2020). "Nueva supercomputadora número uno: Fugaku y A64FX de Fujitsu llevan a Arm a la cima con 415 petaflops". anandtech.com . Consultado el 25 de enero de 2021 .
  7. ^ "Los socios de Arm han enviado 200 mil millones de chips". Arm (Comunicado de prensa) . Consultado el 3 de noviembre de 2021 .
  8. ^ "Habilitación de la conectividad masiva de IoT a medida que los socios de ARM envían 100 mil millones de chips". community.arm.com . 27 de febrero de 2017 . Consultado el 8 de abril de 2020 . el despliegue acumulado de 100 mil millones de chips, la mitad de los cuales se enviaron en los últimos cuatro años. [..] ¿Por qué no un billón o más? Ese es nuestro objetivo, ver un billón de dispositivos conectados implementados en las próximas dos décadas.
  9. ^ "El mercado de MCU avanza hacia dispositivos de 32 bits y basados ​​en ARM: los de 32 bits lideran las ventas; los de 16 bits lideran los envíos de unidades". IC Insights. 25 de abril de 2013. Consultado el 1 de julio de 2014 .
  10. ^ Turley, Jim (2002). "La solución del dos por ciento". builtin.com.
  11. ^ "Arm Holdings está ansiosa por expandir su oferta de PC y servidores". The Register . 1 de febrero de 2011.
  12. ^ McGuire-Balanza, Kerry (11 de mayo de 2010). "ARM de cero a miles de millones en 25 cortos años". Arm Holdings . Consultado el 8 de noviembre de 2012 .
  13. ^ ab "ARM revela detalles técnicos de la próxima versión de la arquitectura ARM" (Nota de prensa). Arm Holdings . 27 de octubre de 2011. Archivado desde el original el 1 de enero de 2019 . Consultado el 20 de septiembre de 2013 .
  14. ^ "Anuncio de la plataforma ARM Neoverse N1". community.arm.com . 20 de febrero de 2019 . Consultado el 8 de abril de 2020 .
  15. ^ Fairbairn, Douglas (31 de enero de 2012). «Historia oral de Sophie Wilson» (PDF) . Archivado (PDF) del original el 3 de marzo de 2016. Consultado el 2 de febrero de 2016 .
  16. ^ Smith, Tony (30 de noviembre de 2011). «La BBC Micro cumple 30 años». The Register Hardware . Archivado desde el original el 12 de diciembre de 2011. Consultado el 12 de diciembre de 2011 .
  17. ^ Polsson, Ken. «Cronología de los microprocesadores». Processortimeline.info . Archivado desde el original el 9 de agosto de 2018. Consultado el 27 de septiembre de 2013 .
  18. ^ Leedy, Glenn (abril de 1983). «La familia de microprocesadores National Semiconductor NS16000». Byte . págs. 53–66 . Consultado el 22 de agosto de 2020 .
  19. ^ Evans 2019, 6:00.
  20. ^ Manners, David (29 de abril de 1998). «ARM's way». Electronics Weekly . Archivado desde el original el 29 de julio de 2012. Consultado el 26 de octubre de 2012 .
  21. ^ Evans 2019, 5:30.
  22. ^Por Evans 2019, 7:45.
  23. ^ Evans 2019, 8:30.
  24. ^ Sophie Wilson en Alt Party 2009 (Parte 3/8). Archivado desde el original el 11 de diciembre de 2021.
  25. ^ Chisnall, David (23 de agosto de 2010). Understanding ARM Architectures (Entender las arquitecturas ARM ). Consultado el 26 de mayo de 2013 .
  26. ^ Evans 2019, 9:00.
  27. ^ Furber, Stephen B. (2000). Arquitectura de sistema en chip ARM . Boston: Addison-Wesley. ISBN 0-201-67519-6.
  28. ^ Evans 2019, 9:50.
  29. ^ Evans 2019, 23:30.
  30. ^ Evans 2019, 26:00.
  31. ^ "Historia del diseño del conjunto de instrucciones ARM con Sophie Wilson (parte 3)". 10 de mayo de 2015. Archivado desde el original el 11 de diciembre de 2021. Consultado el 25 de mayo de 2020 en YouTube.
  32. ^ "Historia oral de Sophie Wilson, becaria del Computer History Museum 2012" (PDF) . Museo de Historia de la Computación . 31 de enero de 2012 . Consultado el 25 de mayo de 2020 .
  33. ^ Harker, T. (verano de 2009). "ARM se toma en serio la propiedad intelectual (segunda parte de una serie de dos partes [la opinión de los editores asociados]". Revista IEEE Solid-State Circuits . 1 (3): 8–69. doi :10.1109/MSSC.2009.933674. ISSN  1943-0590. S2CID  36567166.
  34. ^ Evans 2019, 20:30.
  35. ^ Evans 2019, 22:00.
  36. ^ Evans 2019, 21:30.
  37. ^ Evans 2019, 22:0030.
  38. ^Por Evans 2019, 14:00.
  39. ^ "De un Arm al siguiente! Procesadores y arquitecturas ARM" . Consultado el 31 de mayo de 2022 .
  40. ^ Levy, Markus. "La historia de la arquitectura ARM: desde su inicio hasta la salida a bolsa" (PDF) . Consultado el 18 de julio de 2022 .
  41. ^ Presentación del Commodore Amiga 3000 (PDF) . Commodore-Amiga, Inc. 1991.
  42. ^ "Reclamaciones de velocidad en MIPS y MFLOPS de computadoras de 1980 a 1996". www.roylongbottom.org.uk . Consultado el 17 de junio de 2023 .
  43. ^ Santanu Chattopadhyay (2010). Diseño de sistemas integrados. PHI Learning Pvt. Ltd. pág. 9. ISBN 978-81-203-4024-4.
  44. ^ Richard Murray. "Operación de 32 bits".
  45. ^ "ARM Company Milestones". ARM . Archivado desde el original el 20 de abril de 2015 . Consultado el 8 de abril de 2015 .
  46. ^ Andrews, Jason (2005). "3 temas de verificación de SoC para la arquitectura ARM". Co-verificación de hardware y software para el diseño de SoC ARM . Oxford, Reino Unido: Elsevier . pp. 69. ISBN. 0-7506-7730-9ARM comenzó como una sucursal de Acorn Computer en Cambridge, Inglaterra, con la formación de una empresa conjunta entre Acorn, Apple y VLSI Technology. Un equipo de doce empleados produjo el diseño del primer microprocesador ARM entre 1983 y 1985.
  47. ^ Weber, Jonathan (28 de noviembre de 1990). "Apple se une a Acorn y VLSI en una empresa de fabricación de chips". Los Angeles Times . Los Angeles . Consultado el 6 de febrero de 2012 . Apple ha invertido unos 3 millones de dólares (aproximadamente 1,5 millones de libras) en una participación del 30% en la empresa, denominada Advanced Risc Machines Ltd. (ARM) [...]
  48. ^ "ARM Corporate Backgrounder" (PDF) . ARM . Archivado desde el original (PDF) el 4 de octubre de 2006.
  49. ^ Montanaro, James; et al. (1997). "Un microprocesador RISC CMOS de 160 MHz, 32 bits y 0,5 W" (PDF) . Revista técnica digital . 9 (1): 49–62.
  50. ^ DeMone, Paul (9 de noviembre de 2000). "La carrera de ARM hacia la dominación mundial integrada". Real World Technologies . Consultado el 6 de octubre de 2015 .
  51. ^ "La marcha de las máquinas". technologyreview.com . MIT Technology Review . 20 de abril de 2010. Archivado desde el original el 16 de octubre de 2015 . Consultado el 6 de octubre de 2015 .
  52. ^ Krazit, Tom (3 de abril de 2006). "ARMed para la sala de estar". CNET.
  53. ^ Tracy Robinson (12 de febrero de 2014). "Celebramos los 50 mil millones de chips con tecnología ARM enviados".
  54. ^ Sarah Murry (3 de marzo de 2014). «ARM's Reach: 50 Billion Chip Milestone». Archivado desde el original el 16 de septiembre de 2015.
  55. ^ Brown, Eric (2009). «La netbook ARM se entrega con tableta desmontable». Archivado desde el original el 3 de enero de 2013. Consultado el 19 de agosto de 2009 .
  56. ^ Peter Clarke (7 de enero de 2016). "Amazon ahora vende sus propios chips ARM".
  57. ^ "MACOM completa con éxito la adquisición de AppliedMicro" (Comunicado de prensa). 26 de enero de 2017.
  58. ^ Frumusanu, Andrei. "Detalles de ARM basados ​​en licencia de tecnología ARM Cortex". AnandTech . Consultado el 26 de mayo de 2019 .
  59. ^ Cutress, Ian. "Acceso flexible ARM: diseñe el SoC antes de gastar dinero". AnandTech . Consultado el 9 de octubre de 2019 .
  60. ^ "Preguntas frecuentes sobre ARM Flexible Access". ARM . Consultado el 9 de octubre de 2019 .
  61. ^ Nolting, Stephan. "Sistema de procesador STORM CORE" (PDF) . OpenCores . Consultado el 1 de abril de 2014 .
  62. ^ ZAP en GitHub
  63. ^ "Procesador Cortex-M23". ARM . Consultado el 27 de octubre de 2016 .
  64. ^ "Procesador Cortex-M33". ARM . Consultado el 27 de octubre de 2016 .
  65. ^ "La arquitectura ARMv8-M simplifica la seguridad para los sistemas integrados inteligentes". ARM . Consultado el 10 de noviembre de 2015 .
  66. ^ Ltd, Arm. «Arquitecturas de perfil M». Arm | La arquitectura para el mundo digital . Consultado el 29 de agosto de 2023 .
  67. ^ "Arquitectura ARMv8-R" . Consultado el 10 de julio de 2015 .
  68. ^ Craske, Simon (octubre de 2013). «Arquitectura ARM Cortex-R» (PDF) . Arm Holdings. Archivado desde el original (PDF) el 6 de abril de 2014. Consultado el 1 de febrero de 2014 .
  69. ^ Smith, Ryan (20 de septiembre de 2016). «ARM anuncia la CPU Cortex-R52: determinista y segura, para ADAS y más». AnandTech . Consultado el 20 de septiembre de 2016 .
  70. ^ "Procesador Cortex-A32". ARM . Consultado el 10 de octubre de 2019 .
  71. ^ "Procesador Cortex-A35". ARM . Consultado el 10 de noviembre de 2015 .
  72. ^ ab "ARM lanza la serie Cortex-A50, los procesadores de 64 bits más eficientes energéticamente del mundo" (Nota de prensa). Arm Holdings . Consultado el 31 de octubre de 2012 .
  73. ^ "Procesador Cortex-A72". ARM . Consultado el 10 de julio de 2015 .
  74. ^ "Procesador Cortex-A73". ARM . Consultado el 2 de junio de 2016 .
  75. ^ "Arquitectura ARMv8-A" . Consultado el 10 de julio de 2015 .
  76. ^ "Cavium Thunder X aumenta el número de núcleos ARM a 48 en un solo chip". SemiAccurate . 3 de junio de 2014.
  77. ^ "Cavium en Supercomputing 2014". Yahoo Finance . 17 de noviembre de 2014. Archivado desde el original el 16 de octubre de 2015 . Consultado el 15 de enero de 2017 .
  78. ^ Burt, Jeff (17 de noviembre de 2014). "Cray evaluará chips ARM en sus supercomputadoras". eWeek .
  79. ^ "Samsung anuncia Exynos 8890 con módem Cat.12/13 y CPU personalizada". AnandTech .
  80. ^ "Procesador Cortex-A34". ARM . Consultado el 10 de octubre de 2019 .
  81. ^ "D21500 [AARCH64] Agregar soporte para Broadcom Vulcan". reviews.llvm.org .
  82. ^ "Procesador Cortex-A55". ARM . Consultado el 29 de mayo de 2017 .
  83. ^ "Procesador Cortex-A75". ARM . Consultado el 29 de mayo de 2017 .
  84. ^ "Procesador Cortex-A76". ARM . Consultado el 11 de octubre de 2018 .
  85. ^ Berenice Mann (abril de 2017). "Arquitectura ARM: evolución y entrega de ARMv8.2-A". community.ARM.com .
  86. ^ Frumusanu, Andrei. "Samsung anuncia el SoC Exynos 9825: el primer chip de silicio EUV de 7 nm". AnandTech . Consultado el 11 de octubre de 2019 .
  87. ^ "Fujitsu comenzó a producir miles de millones de supercálculos japoneses con el procesador ARM más potente, el A64FX". Noticias de TI de China . Archivado del original el 20 de junio de 2019. Consultado el 17 de agosto de 2019. Chip ARMv8 SVE (Scalable Vector Extension), que utiliza un punto flotante de 512 bits.
  88. ^ "Cortex-A65AE – ARM". ARM . Consultado el 8 de abril de 2020 . puede ejecutar dos subprocesos en paralelo en cada ciclo. Cada subproceso puede estar en diferentes niveles de excepción y ejecutar diferentes sistemas operativos.
  89. ^ Frumusanu, Andrei. "Marvell anuncia ThunderX3: procesador de servidor ARM de tercera generación con 96 núcleos y 384 subprocesos". AnandTech . Consultado el 26 de mayo de 2020 .
  90. ^ "AArch64: agrega compatibilidad con CPU Apple más nuevas · apple/llvm-project@677da09". GitHub . Consultado el 23 de septiembre de 2022 .
  91. ^ "Nuevas características para la arquitectura Armv8-A - Blog de arquitecturas y procesadores - Blogs de la comunidad Arm - Comunidad Arm". community.arm.com . 21 de septiembre de 2020 . Consultado el 28 de diciembre de 2021 .
  92. ^ "La solución de Arm a las necesidades futuras de IA, seguridad y computación especializada es v9". Arm . Consultado el 16 de agosto de 2021 .
  93. ^ "Primeras CPU Armv9 Cortex para computación de consumo". community.arm.com . 25 de mayo de 2021 . Consultado el 16 de agosto de 2021 .
  94. ^ "Documentación – Arm Developer". developer.arm.com . Consultado el 3 de octubre de 2024 .
  95. ^ "Documentación – Arm Developer". developer.arm.com . Consultado el 3 de octubre de 2024 .
  96. ^ "Compatibilidad con Apple M4 añadida al compilador LLVM, lo que confirma sus capacidades ISA". www.phoronix.com . Consultado el 15 de junio de 2024 .
  97. ^ "Desarrollos de la arquitectura Arm A-Profile 2021 - Blog de arquitecturas y procesadores - Blogs de la comunidad Arm - Comunidad Arm". community.arm.com . 8 de septiembre de 2021 . Consultado el 25 de septiembre de 2023 .
  98. ^ "Desarrollos de la arquitectura Arm A-Profile 2022 - Blog de arquitecturas y procesadores - Blogs de la comunidad Arm - Comunidad Arm". community.arm.com . 29 de septiembre de 2022 . Consultado el 25 de septiembre de 2023 .
  99. ^ "Arm A-Profile Architecture Developments 2023 - Blog de arquitecturas y procesadores - Blogs de la comunidad Arm - Comunidad Arm". community.arm.com . 29 de septiembre de 2022 . Consultado el 11 de octubre de 2024 .
  100. ^ "Arm A-Profile Architecture Developments 2024 - Blog de arquitecturas y procesadores - Blogs de la comunidad Arm - Comunidad Arm". community.arm.com . 29 de septiembre de 2022 . Consultado el 11 de octubre de 2024 .
  101. ^ "Line Card" (PDF) . 2003. Consultado el 1 de octubre de 2012 .
  102. ^ Parrish, Kevin (14 de julio de 2011). "Un millón de núcleos ARM vinculados para simular el cerebro". EE Times . Consultado el 2 de agosto de 2011 .
  103. ^ "Modo de procesador". Arm Holdings . Consultado el 26 de marzo de 2013 .
  104. ^ "KVM/ARM" (PDF) . Consultado el 14 de febrero de 2023 .
  105. ^ Brash, David (agosto de 2010). Extensiones a la arquitectura ARMv7-A . Simposio IEEE Hot Chips 22 (HCS) de 2010. págs. 1–21. doi :10.1109/HOTCHIPS.2010.7480070. ISBN 978-1-4673-8875-7.S2CID 46339775  .
  106. ^ "¿Cómo admite el compilador ARM los accesos no alineados?". 2011 . Consultado el 5 de octubre de 2013 .
  107. ^ "Acceso a datos no alineados" . Consultado el 5 de octubre de 2013 .
  108. ^ "Manual de referencia técnica de Cortex-M0 r0p0" (PDF) . Arm .
  109. ^ "Manual de referencia de la arquitectura ARMv7-M". Arm . Consultado el 18 de julio de 2022 .
  110. ^ ab "Manual de referencia de arquitectura ARMv7-A y ARMv7-R; Arm Holdings". arm.com . Consultado el 19 de enero de 2013 .
  111. ^ "Centro de información ARM" . Consultado el 10 de julio de 2015 .
  112. ^ "Códigos de condición 1: Indicadores y códigos de condición". Comunidad ARM . 11 de septiembre de 2013 . Consultado el 26 de septiembre de 2019 .
  113. ^ "9.1.2. Recuento de ciclos de instrucción".
  114. ^ "Componentes de CoreSight: acerca del puerto de acceso de depuración".
  115. ^ "El Cortex-M3: puerto de acceso de depuración (DAP)".
  116. ^ Anderson, Mike. "Comprensión de las opciones de depuración de hardware ARM" (PDF) .
  117. ^ "Guía del usuario del depurador CMSIS-DAP".
  118. ^ "CMSIS-DAP".
  119. ^ "Extensiones del conjunto de instrucciones ARM DSP". arm.com . Archivado desde el original el 14 de abril de 2009. Consultado el 18 de abril de 2009 .
  120. ^ ab Clarke, Peter (3 de mayo de 1999). "EPF: ARC y ARM añaden extensiones DSP a sus núcleos RISC". EE Times . Consultado el 15 de marzo de 2024 .
  121. ^ Turley, Jim (18 de noviembre de 1996). "ARM Tunes Piccolo for DSP Performance" (PDF) . Microprocessor Report . Consultado el 15 de marzo de 2024 .
  122. ^ "DSP & SIMD" . Consultado el 10 de julio de 2015 .
  123. ^ "Manual de referencia técnica ARM7TDMI" (PDF) . p. ii.
  124. ^ Jaggar, Dave (1996). Manual de referencia de arquitectura ARM . Prentice Hall. págs. 6-1. ISBN 978-0-13-736299-8.
  125. ^ Nathan Willis (10 de junio de 2015). "Resucitando la arquitectura SuperH". LWN.net .
  126. ^ "Arquitectura del conjunto de instrucciones del procesador ARM". ARM.com. Archivado desde el original el 15 de abril de 2009. Consultado el 18 de abril de 2009 .
  127. ^ "ARM apunta a un hijo de Thumb en uCs, ASSPs, SoCs". Linuxdevices.com. Archivado desde el original el 9 de diciembre de 2012. Consultado el 18 de abril de 2009 .
  128. ^ "Centro de información ARM". Infocenter.arm.com . Consultado el 18 de abril de 2009 .
  129. ^ "Jazelle". ARM Ltd. Archivado desde el original el 2 de junio de 2017.
  130. ^ Tom R. Halfhill (2005). "ARM fortalece los compiladores de Java: las nuevas instrucciones Thumb-2EE de 16 bits conservan la memoria del sistema" (PDF) . Archivado desde el original (PDF) el 5 de octubre de 2007.
  131. ^ Manual de referencia de la arquitectura ARM, edición Armv7-A y Armv7-R, número Cb, sección A2.10, 25 de julio de 2012.
  132. ^ "Cadena de herramientas del compilador ARM que utiliza el ensamblador: coprocesador VFP". ARM.com . Consultado el 20 de agosto de 2014 .
  133. ^ "Directivas VFP y notación vectorial". ARM.com . Consultado el 21 de noviembre de 2011 .
  134. ^ ab "Diferencias entre ARM Cortex-A8 y Cortex-A9". Shervin Emami . Consultado el 21 de noviembre de 2011 .
  135. ^ "Hoja de datos de FPA10" (PDF) . chrisacorns.computinghistory.org.uk . GEC Plessey Semiconductors. 11 de junio de 1993 . Consultado el 26 de noviembre de 2020 . En relación con IEEE 754-1985, el FPA logra conformidad en aritmética de precisión simple [...] Ocasionalmente, se pueden producir multiplicaciones de precisión doble y extendida con un error de 1 o 2 unidades en el lugar menos significativo de la mantisa.
  136. ^ ab "Manual de referencia técnica de Cortex-A7 MPCore – 1.3 Características". ARM . Consultado el 11 de julio de 2014 .
  137. ^ "ArmHardFloatPort – Wiki de Debian". Wiki.debian.org. 20 de agosto de 2012. Consultado el 8 de enero de 2014 .
  138. ^ "Procesador Cortex-A9". arm.com . Consultado el 21 de noviembre de 2011 .
  139. ^ "Acerca del Cortex-A9 NEON MPE". arm.com . Consultado el 21 de noviembre de 2011 .
  140. ^ "US20050125476A1".
  141. ^ "US20080141004A1".
  142. ^ "Opciones ARM". Manual de la colección de compiladores GNU . Consultado el 20 de septiembre de 2019 .
  143. ^ Ne10: Un proyecto de biblioteca de software optimizada y abierta para la arquitectura ARM en GitHub
  144. ^ Joseph Yiu. "Introducción a la arquitectura ARMv8.1-M" (PDF) . Consultado el 18 de julio de 2022 .
  145. ^ "Genode: una exploración de la tecnología ARM TrustZone" . Consultado el 10 de julio de 2015 .
  146. ^ "ARM anuncia la disponibilidad de soluciones de software DRM para consumidores móviles basadas en la tecnología ARM TrustZone" (nota de prensa). News.thomasnet.com . Consultado el 18 de abril de 2009 .
  147. ^ Laginimaineb (8 de octubre de 2015). "Bits, Please!: Full TrustZone exploit for MSM8974". Bits, Please! . Consultado el 3 de mayo de 2016 .
  148. ^ Di Shen. "Ataque a su 'núcleo de confianza' mediante la explotación de TrustZone en Android" (PDF) . Black Hat Briefings . Consultado el 3 de mayo de 2016 .
  149. ^ "Software de código abierto ARM TrustZone y ARM Hypervisor". Virtualización abierta. Archivado desde el original el 14 de junio de 2013. Consultado el 14 de junio de 2013 .
  150. ^ "Tecnología segura de AMD". AMD . Archivado desde el original el 23 de julio de 2016 . Consultado el 6 de julio de 2016 .
  151. ^ Smith, Ryan (13 de junio de 2012). "Las APU AMD 2013 incluirán el procesador ARM Cortex A5 para capacidades Trustzone". AnandTech . Consultado el 6 de julio de 2016 .
  152. ^ ab Shimpi, Anand Lal (29 de abril de 2014). "Vista previa del rendimiento del procesador AMD Beema Mullins Architecture A10 micro 6700T". AnandTech . Consultado el 6 de julio de 2016 .
  153. ^ Walton, Jarred (4 de junio de 2014). «AMD lanza las APU Kaveri para dispositivos móviles». AnandTech . Consultado el 6 de julio de 2016 .
  154. ^ "Root of Trust" (informe técnico). Samsung Electronics . Abril de 2016.
  155. ^ "Manual de referencia de la arquitectura ARM" (PDF) . p. B4-8. Archivado desde el original (PDF) el 6 de febrero de 2009. Se han añadido bits APX y XN (nunca ejecutar) en VMSAv6 [Arquitectura del sistema de memoria virtual]
  156. ^ Manual de referencia de la arquitectura ARM, edición ARMv7-A y ARMv7-R . ARM Limited.
  157. ^ "Cortex-A65AE". Desarrollador ARM . Consultado el 26 de abril de 2019 .
  158. ^ "AppliedMicro presenta el primer núcleo ARM v8 de 64 bits del mundo" (nota de prensa). AppliedMicro. 28 de octubre de 2011. Consultado el 11 de febrero de 2014 .
  159. ^ "El Exynos 5433 de Samsung es un SoC ARM A57/A53". AnandTech . Consultado el 17 de septiembre de 2014 .
  160. ^ "Manual de referencia técnica del procesador ARM Cortex-A53 MPCore: extensión de criptografía". ARM . Consultado el 11 de septiembre de 2016 .
  161. ^ ab "Impacto de los niveles de excepción implementados". Conozca la arquitectura: modelo de excepción AArch64 . Arm.
  162. ^ "Cortex-A32". Desarrollador de Arm .
  163. ^ "Cortex-A34". Desarrollador de Arm .
  164. ^ "Cortex-A72". Desarrollador de Arm .
  165. ^ Frumusanu, Andrei (3 de septiembre de 2020). "ARM anunció Cortex-R82: el primer procesador en tiempo real de 64 bits". AnandTech .
  166. ^ Frumusanu, Andrei (30 de marzo de 2021). "Arm anuncia la arquitectura Armv9: SVE2, seguridad y la próxima década". AnandTech .
  167. ^ Harrod, Alex (30 de marzo de 2021). "La solución de Arm para las necesidades futuras de inteligencia artificial, seguridad y computación especializada es v9" (nota de prensa). Arm Holdings .
  168. ^ "Programa de cumplimiento de SystemReady". Arm .
  169. ^ "Arquitectura del sistema base del brazo". Brazo .
  170. ^ "Arquitectura del sistema base del servidor Arm". Arm .
  171. ^ "Requisitos de arranque de la base del brazo". Brazo .
  172. ^ "Requisitos de seguridad de arranque base". Arm .
  173. ^ "Especificación de requisitos de Arm SystemReady". Arm .
  174. ^ Osborne, Charlie. "ARM anuncia la arquitectura de seguridad PSA para dispositivos IoT". ZDNet.
  175. ^ ab Wong, William (25 de octubre de 2017). «Arquitectura de seguridad de plataforma de ARM dirigida a Cortex-M». Diseño electrónico . Archivado desde el original el 8 de mayo de 2019.
  176. ^ Hoffenberg, Steve (31 de octubre de 2017). «ARM: la seguridad no es solo un imperativo tecnológico, es una responsabilidad social». VDC Research . Archivado desde el original el 28 de septiembre de 2023.
  177. ^ Armasu, Lucian (22 de febrero de 2018). "ARM revela más detalles sobre la arquitectura de seguridad de su plataforma IoT". Tom's Hardware .
  178. ^ Williams, Chris. "¿ARM PSA IoT API? Vuelvo pronto... La caja de herramientas tecnológica para proteger los equipos conectados a la red se abre un poco más". The Register .
  179. ^ Hayes, Caroline (25 de febrero de 2019). «Embedded World: Arm introduce un cuarto elemento de seguridad en PSA». Electronics Weekly .
  180. ^ "PSA Certified: generando confianza en IoT". PSA Certified .
  181. ^ ab "PSA Certified – building trust, building value" (Certificado PSA: generando confianza y generando valor). EE Times . 4 de marzo de 2019.
  182. ^ "La importancia de 6 billones de dólares de los estándares y la regulación de seguridad en la era del IoT". IoT Now. 16 de marzo de 2020.
  183. ^ McGregor, Jim (4 de marzo de 2019). "Arm presenta pruebas de certificación de seguridad para IoT". Forbes .
  184. ^ Speed, Richard (26 de febrero de 2019). "Azure IoT se dirige al espacio para mantener la conectividad en el borde, cortesía de Inmarsat". TheRegister .
  185. ^ "Especificaciones de OS-9". Microware .
  186. ^ ab "Pharos". SourceForge . Consultado el 24 de mayo de 2018 .
  187. ^ "Virtualización segura y protegida de PikeOS" . Consultado el 10 de julio de 2013 .
  188. ^ ab "Sistemas operativos en tiempo real con certificación de seguridad: CPU compatibles".
  189. ^ "Puerto de plataforma ARM". opensolaris.org. Archivado desde el original el 2 de diciembre de 2012. Consultado el 29 de diciembre de 2012 .
  190. ^ "El multivisor basado en INTEGRITY de Green Hills Software ofrece la primera solución de virtualización segura de 64 bits de la industria integrada". ghs.com . Consultado el 14 de marzo de 2018 .
  191. ^ "Sistema operativo en tiempo real Enea OSE para 5G y LTE-A | Enea". enea.com . Archivado desde el original el 1 de enero de 2019 . Consultado el 17 de abril de 2018 .
  192. ^ "Plataformas compatibles". docs.sel4.systems . Consultado el 23 de noviembre de 2018 .
  193. ^ "Plataforma de desarrollo de software QNX (SDP 7.0) | BlackBerry QNX". blackberry.qnx.com . Consultado el 27 de julio de 2020 .
  194. ^ "Wind River lanza el sistema operativo en tiempo real VxWorks de 64 bits" (nota de prensa). Wind River Systems . 28 de febrero de 2011 . Consultado el 24 de octubre de 2023 .
  195. ^ "Manjaro-ARM". Wiki de Manjaro . 20 de junio de 2022.
  196. ^ Linus Torvalds (1 de octubre de 2012). «Re: [GIT PULL] arm64: puerto del kernel de Linux». Lista de correo del kernel de Linux (Mailing list) . Consultado el 2 de mayo de 2019 .
  197. ^ Larabel, Michael (27 de febrero de 2013). "Se está iniciando la versión ARM de 64 bits de Ubuntu/Debian". Phoronix . Consultado el 17 de agosto de 2014 .
  198. ^ "Noticias del proyecto Debian – 14 de agosto de 2014". Debian . 14 de agosto de 2014 . Consultado el 17 de agosto de 2014 .
  199. ^ "Servidor Ubuntu para ARM". ubuntu.com .
  200. ^ "Arquitecturas/AArch64" . Consultado el 16 de enero de 2015 .
  201. ^ "Portal:ARM/AArch64" . Consultado el 16 de enero de 2015 .
  202. ^ "Notas de la versión de SUSE Linux Enterprise 12 SP2" . Consultado el 11 de noviembre de 2016 .
  203. ^ "Red Hat presenta compatibilidad con servidores ARM para Red Hat Enterprise Linux". redhat.com . Consultado el 18 de enero de 2019 .
  204. ^ "Actualización del proyecto de arquitectura ARM de 64 bits". The FreeBSD Foundation. 24 de noviembre de 2014.
  205. ^ "OpenBSD/arm64" . Consultado el 25 de septiembre de 2023 .
  206. ^ "NetBSD/arm64" . Consultado el 5 de agosto de 2018 .
  207. ^ "HP y Asus anuncian los primeros PC con Windows 10 ARM: duración de batería de 20 horas, gigabit LTE". Ars Technica . Consultado el 22 de enero de 2018 . Esta nueva versión de Windows 10 es el primer sistema operativo ARM de 64 bits de Microsoft. Ejecutará aplicaciones ARM x86 y de 32 bits desde la Tienda y, a su debido tiempo, aplicaciones ARM de 64 bits. Sin embargo, Microsoft aún no ha finalizado su SDK ARM de 64 bits. Muchas piezas están en su lugar (hay un compilador ARM de 64 bits, por ejemplo), pero la compañía aún no acepta aplicaciones ARM de 64 bits enviadas a la Tienda, y tampoco hay ninguna aplicación de escritorio ARM de 64 bits.
  208. ^ Hassan, Mehedi (10 de diciembre de 2016). "Windows 10 en ARM64 obtiene sus primeras aplicaciones compiladas". MSPoweruser .
  209. ^ Filippidis, Katrina (1 de junio de 2018). "VLC se convierte en una de las primeras aplicaciones ARM64 para Windows". Engadget .
  210. ^ Sweetgall, Marc (15 de noviembre de 2018). "Soporte oficial para Windows 10 en el desarrollo ARM". Windows Developer. Blogs de Windows . Microsoft . Consultado el 17 de diciembre de 2019 .
  211. ^ Gartenberg, Chaim (12 de noviembre de 2020). «macOS Big Sur ya está disponible para descargar». The Verge . Consultado el 13 de noviembre de 2020 .
  212. ^ Clover, Juli (23 de junio de 2020). "Rosetta no admitirá aplicaciones de virtualización x86 que ejecuten Windows". MacRumors . Consultado el 13 de noviembre de 2020 .
  213. ^ "ARM – La Wiki Oficial del Vino" . Consultado el 10 de julio de 2015 .
  214. ^ "ARM64 – La Wiki Oficial del Vino" . Consultado el 10 de julio de 2015 .
  215. ^ "Actualizaciones de seguridad de ARM". ARM Developer . Consultado el 24 de mayo de 2018 .

Bibliografía

  • Evans, Matt (27 de diciembre de 2019). Charla sobre Archimedes de The Ultimate Acorn. Programa del 36º Congreso de Comunicación del Caos. YouTube . Archivado del original el 11 de diciembre de 2021 – vía media.ccc.de.

Lectura adicional

  • Sitio web oficial , ARM Limitada.

Manuales de arquitectura

  • ARM Limited (1996–2005). "Manual de referencia de la arquitectura ARM". documentation-service.arm.com . Consultado el 16 de julio de 2021 .- cubre ARMv4, ARMv4T, ARMv5T, (ARMv5TExP), ARMv5TE, ARMv5TEJ y ARMv6
  • ARM Limited (2007–2018). «Manual de referencia de la arquitectura Armv6-M». Documentación de ARM . Consultado el 17 de julio de 2021 .
  • ARM Limited (2007–2018). «Manual de referencia de arquitectura ARM, edición ARMv7-A y ARMv7-R». Documentación de ARM . Consultado el 17 de julio de 2021 .
  • ARM Limited (2006–2021). «Manual de referencia de la arquitectura ARMv7-M». Documentación de ARM . Consultado el 24 de agosto de 2022 .
  • ARM Limited (2013–2022). «Manual de referencia de arquitectura ARM para arquitectura de perfil A». Documentación de ARM . Consultado el 24 de agosto de 2022 .
  • ARM Limited (2016–2020). «Suplemento del Manual de referencia de arquitectura ARM - ARMv8, para el perfil de arquitectura ARMv8-R AArch32». Documentación de ARM . Consultado el 17 de julio de 2021 .
  • ARM Limited (2020–2022). «Suplemento del manual de referencia de arquitectura de Arm: Armv8, para el perfil de arquitectura AArch64 de Armv8-R». Documentación de ARM . Consultado el 24 de agosto de 2022 .
  • ARM Limited (2015–2022). "Manual de referencia de la arquitectura Armv8-M". Documentación de ARM . Consultado el 24 de agosto de 2022 .
  • ARM Limited (2021). «Arquitectura del conjunto de instrucciones Armv9-A A64». Documentación de ARM . Consultado el 17 de julio de 2021 .
  • "Extensiones de virtualización ARM". Archivado desde el original el 18 de diciembre de 2013.

Tarjetas de referencia rápida

Instrucciones

Códigos de operación

  • Thumb Archivado el 30 de julio de 2022 en Wayback Machine . Archivos adicionales: 22 de agosto de 2022.
  • ARM Archivado el 7 de junio de 2022 en Wayback Machine . Archivos adicionales: 22 de agosto de 2022.
  • Directivas del ensamblador GNU Archivado el 30 de abril de 2022 en Wayback Machine . Archivos adicionales: 22 de agosto de 2022.
Retrieved from "https://en.wikipedia.org/w/index.php?title=ARM_architecture_family&oldid=1253531480#Security_extensions"