stringtranslate.com

ARM9

ARM9 es un grupo de núcleos de procesadores ARM RISC de 32 bits autorizados por ARM Holdings para su uso en microcontroladores . [1] La familia de núcleos ARM9 consta de ARM9TDMI, ARM940T, ARM9E-S, ARM966E-S, ARM920T, ARM922T, ARM946E-S, ARM9EJ-S, ARM926EJ-S, ARM968E-S, ARM996HS. Los núcleos ARM9 se lanzaron entre 1998 y 2006 y ya no se recomiendan para nuevos diseños de circuitos integrados; las alternativas recomendadas incluyen los núcleos ARM Cortex-A , ARM Cortex-M y ARM Cortex-R . [ cita requerida ]

Descripción general

Con esta generación de diseño, ARM pasó de una arquitectura von Neumann (arquitectura Princeton) a una arquitectura Harvard (modificada; es decir, con caché dividida) con buses de instrucciones y datos separados (y cachés), lo que aumentó significativamente su velocidad potencial. [2] La mayoría de los chips de silicio que integran estos núcleos los empaquetarán como chips de arquitectura Harvard modificados , combinando los dos buses de direcciones en el otro lado de cachés de CPU separados y memorias estrechamente acopladas.

Hay dos subfamilias que implementan diferentes versiones de la arquitectura ARM.

Diferencias con los núcleos ARM7

Las mejoras clave con respecto a los núcleos ARM7 , posibilitadas al utilizar más transistores, incluyen: [3]

Además, algunos núcleos ARM9 incorporan instrucciones "DSP mejorado", como multiplicar-acumular, para soportar implementaciones más eficientes de algoritmos de procesamiento de señales digitales .

El cambio desde una arquitectura von Neumann implicó el uso de una caché no unificada, de modo que la obtención de instrucciones no expulse datos (y viceversa). Los núcleos ARM9 tienen señales de bus de datos y direcciones separadas, que los diseñadores de chips utilizan de diversas maneras. En la mayoría de los casos, conectan al menos parte del espacio de direcciones al estilo von Neumann, utilizado tanto para instrucciones como para datos, normalmente a una interconexión AHB que se conecta a una interfaz DRAM y a una interfaz de bus externo utilizable con memoria flash NOR . Estos híbridos ya no son procesadores de arquitectura Harvard pura.

Licencia ARM

ARM Holdings no fabrica ni vende dispositivos de CPU basados ​​en sus propios diseños, sino que otorga licencias de la arquitectura del procesador a las partes interesadas. ARM ofrece una variedad de condiciones de licencia, que varían en costo y resultados. Para todos los licenciatarios, ARM proporciona una descripción de hardware integrable del núcleo ARM, así como un conjunto completo de herramientas de desarrollo de software y el derecho a vender silicio fabricado que contiene la CPU ARM.

Personalización de silicio

Los fabricantes de dispositivos integrados (IDM) reciben la propiedad intelectual del procesador ARM como RTL sintetizable (escrito en Verilog ). De esta forma, tienen la capacidad de realizar optimizaciones y extensiones a nivel de arquitectura. Esto permite al fabricante lograr objetivos de diseño personalizados, como mayor velocidad de reloj, consumo de energía muy bajo, extensiones del conjunto de instrucciones, optimizaciones de tamaño, soporte de depuración, etc. Para determinar qué componentes se han incluido en un chip de CPU ARM en particular, consulte la hoja de datos del fabricante y la documentación relacionada.

Núcleos

La familia de procesadores multinúcleo ARM MPCore admite software escrito utilizando los paradigmas de programación multiprocesador asimétrico ( AMP ) o simétrico ( SMP ) . Para el desarrollo de AMP, cada unidad central de procesamiento dentro del MPCore puede considerarse un procesador independiente y, como tal, puede seguir las estrategias tradicionales de desarrollo de un solo procesador. [4]

ARM9TDMI

ARM9TDMI es el sucesor del popular núcleo ARM7TDMI y también se basa en la arquitectura ARMv4T . Los núcleos basados ​​en él admiten conjuntos de instrucciones ARM de 32 bits y Thumb de 16 bits, e incluyen:

ARM9E-S y ARM9EJ-S

ARM9E y su hermano ARM9EJ implementan la línea básica ARM9TDMI , pero añaden compatibilidad con la arquitectura ARMv5TE, que incluye algunas extensiones de conjunto de instrucciones de tipo DSP. Además, se ha duplicado el ancho de la unidad multiplicadora, lo que reduce a la mitad el tiempo necesario para la mayoría de las operaciones de multiplicación. Admiten conjuntos de instrucciones de 32 bits, 16 bits y, a veces, 8 bits.

Las calculadoras gráficas TI-Nspire CX (2011) y CX II (2019) utilizan un procesador ARM926EJ-S, con una velocidad de reloj de 132 y 396 MHz respectivamente. [5]

Papas fritas

Nintendo DSi tiene un chip con un núcleo ARM9 y ARM7
El ladrillo Lego Mindstorms EV3 tiene un ARM9 TI Sitara AM1x
Procesador de banda base ARM946E-S en un teléfono Samsung SGH-D900
ARM920T
ARM922T
Samsung S3C2416XH-26
ARM925T
ARM926EJ-S
ARM940T
ARM946E-S
ARM966E-S
ARM968E-S
Núcleo ARM9 sin referencia

Documentación

La cantidad de documentación de todos los chips ARM es abrumadora, especialmente para los recién llegados. La documentación de los microcontroladores de décadas pasadas podría incluirse fácilmente en un solo documento, pero a medida que los chips han evolucionado, la documentación también ha crecido. La documentación total es especialmente difícil de comprender para todos los chips ARM, ya que consta de documentos del fabricante del CI y documentos del proveedor del núcleo de la CPU ( ARM Holdings ).

Un árbol de documentación de arriba hacia abajo típico es: diapositivas de marketing de alto nivel, hoja de datos para el chip físico exacto, un manual de referencia detallado que describe los periféricos comunes y otros aspectos de los chips físicos dentro de la misma serie, manual de referencia para el procesador central ARM exacto dentro del chip, manual de referencia para la arquitectura ARM del núcleo que incluye una descripción detallada de todos los conjuntos de instrucciones.

Árbol de documentación (de arriba a abajo)
  1. Diapositivas de marketing del fabricante de circuitos integrados.
  2. Hojas de datos del fabricante de IC.
  3. Manuales de referencia de fabricantes de circuitos integrados.
  4. Manuales de referencia del núcleo ARM.
  5. Manuales de referencia de arquitectura ARM.

El fabricante de circuitos integrados tiene documentos adicionales, que incluyen: manuales de usuario de la placa de evaluación, notas de aplicación, introducción al software de desarrollo, documentos de la biblioteca de software, erratas y más.

Véase también

Referencias

  1. ^ Página web de la familia ARM9; ARM Holdings.
  2. ^ Furber, Steve (2000). Arquitectura de sistema en chip ARM . pág. 344. ISBN 0201675196.
  3. ^ "Rendimiento de los núcleos ARM9TDMI y ARM9E-S en comparación con el núcleo ARM7TDMI", número 1.0, de fecha 9 de febrero de 2000, ARM Ltd.
  4. ^ "Código de muestra de MPCore". Archivado desde el original el 11 de abril de 2015.
  5. ^ "Teardown Tuesday: Calculadora gráfica - Noticias" www.allaboutcircuits.com . Consultado el 12 de julio de 2021 .
  6. ^ ab Soluciones Atmel basadas en ARM heredadas; Atmel.
  7. ^ Microcontroladores SAM9G ARM9; Atmel.
  8. ^ Microcontroladores SAM9M ARM9; Microchip.
  9. ^ Microcontroladores ARM9 SAM9N/CN; Atmel.
  10. ^ Microcontroladores SAM9R/RL ARM9; Atmel.
  11. ^ Microcontroladores SAM9X ARM9; Atmel.
  12. ^ Microcontroladores ARM9 SAM9XE; Atmel.
  13. ^ "Hardware/Starlet". Wiibrew . Archivado desde el original el 16 de mayo de 2020 . Consultado el 14 de junio de 2020 .
  14. ^ Procesadores de aplicaciones i.MX28; NXP.
  15. ^ "Serie LPC3100/200: microcontroladores basados ​​en Arm9 | NXP". www.nxp.com . Consultado el 27 de julio de 2018 .
  16. ^ "Política de seguridad no propietaria FIPS 140-2 del módulo criptográfico iLO 4" (PDF) . Hewlett Packard Enterprise. 10 de febrero de 2016.
  17. ^ "Microprocesadores SPEAr ARM 926 - STMicroelectronics".
  18. ^ GBATEK - Información técnica de GBA/NDS - Códigos de identificación ARM CP15; Martin Korth
  19. ^ Microcontroladores STR9 ARM9; STMicroelectronics.
  20. ^ "Familia de procesadores NET+ARM de 32 bits NS9210/NS9215" (PDF) . Digi International .

Enlaces externos

Documentos oficiales de ARM9
Tarjetas de referencia rápida