stringtranslate.com

ARM Cortex-M

Circuitos integrados de microcontroladores ARM Cortex-M0 y Cortex-M3 de NXP y Silicon Labs ( Energy Micro )
Matriz de un circuito integrado STM32F100C4T6B. Microcontrolador ARM Cortex-M3
de 24  MHz con  memoria flash de 16 KB y RAM de 4 KB. Fabricado por STMicroelectronics .

ARM Cortex-M es un grupo de núcleos de procesadores ARM RISC de 32 bits con licencia de ARM Limited . Estos núcleos están optimizados para circuitos integrados de bajo coste y eficiencia energética, que se han integrado en decenas de miles de millones de dispositivos de consumo. [1] Aunque suelen ser el componente principal de los chips de microcontroladores , a veces también se integran en otros tipos de chips. La familia Cortex-M consta de Cortex-M0, [2] Cortex-M0+, [3] Cortex-M1, [4] Cortex-M3, [5] Cortex-M4, [6] Cortex-M7, [7] Cortex-M23, [8] Cortex-M33, [9] Cortex-M35P, [10] Cortex-M52, [11] Cortex-M55, [12] Cortex-M85. [13] Hay una opción de unidad de punto flotante (FPU) disponible para los núcleos Cortex-M4 / M7 / M33 / M35P / M52 / M55 / M85, y cuando se incluyen en el silicio, estos núcleos a veces se conocen como "Cortex-MxF", donde "x" es la variante del núcleo.

Descripción general

La familia ARM Cortex-M son núcleos de microprocesadores ARM diseñados para su uso en microcontroladores , ASIC , ASSP , FPGA y SoC . Los núcleos Cortex-M se utilizan comúnmente como chips de microcontroladores dedicados, pero también están "ocultos" dentro de chips SoC como controladores de administración de energía, controladores de E/S, controladores de sistema, controladores de pantalla táctil, controladores de batería inteligente y controladores de sensores.

La principal diferencia con los núcleos Cortex-A es que los núcleos Cortex-M no tienen una unidad de gestión de memoria (MMU) para la memoria virtual , considerada esencial para los sistemas operativos "completos" . En cambio, los programas Cortex-M se ejecutan en hardware físico o en uno de los muchos sistemas operativos en tiempo real que admiten un Cortex-M .

Aunque los microcontroladores de 8 bits fueron muy populares en el pasado, Cortex-M ha ido ganando terreno lentamente en el mercado de 8 bits a medida que los precios de los chips Cortex-M de gama baja han ido bajando. Los Cortex-M se han convertido en un reemplazo popular de los chips de 8 bits en aplicaciones que se benefician de las operaciones matemáticas de 32 bits y reemplazan a los núcleos ARM heredados más antiguos, como ARM7 y ARM9 .

Licencia

ARM Limited no fabrica ni vende dispositivos de CPU basados ​​en sus propios diseños, sino que otorga licencias sobre la arquitectura del procesador a las partes interesadas. Arm ofrece una variedad de condiciones de licencia, que varían en costo y resultados. A todos los licenciatarios, Arm les 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 contenga 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 arquitectónico. 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 (incluido el punto flotante), 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.

Algunas de las opciones de silicio para los núcleos Cortex-M son:

Opciones adicionales de silicio: [14] [15]

Conjuntos de instrucciones

Los Cortex-M0 / M0+ / M1 implementan la arquitectura ARMv6-M , [14] el Cortex-M3 implementa la arquitectura ARMv7-M , [15] el Cortex-M4 / Cortex-M7 implementa la arquitectura ARMv7E-M , [15] el Cortex-M23 / M33 / M35P implementa la arquitectura ARMv8-M , [30] y el Cortex-M52 / M55 / M85 implementa la arquitectura ARMv8.1-M . [30] Las arquitecturas son compatibles con instrucciones binarias desde ARMv6-M a ARMv7-M a ARMv7E-M. Las instrucciones binarias disponibles para el Cortex-M0 / Cortex-M0+ / Cortex-M1 pueden ejecutarse sin modificaciones en el Cortex-M3 / Cortex-M4 / Cortex-M7. Las instrucciones binarias disponibles para Cortex-M3 se pueden ejecutar sin modificaciones en Cortex-M4 / Cortex-M7 / Cortex-M33 / Cortex-M35P. [14] [15] Solo los conjuntos de instrucciones Thumb-1 y Thumb-2 son compatibles con las arquitecturas Cortex-M; el conjunto de instrucciones ARM heredado de 32 bits no es compatible.

Todos los núcleos Cortex-M implementan un subconjunto común de instrucciones que consta principalmente de Thumb-1, algunas Thumb-2, incluida una multiplicación de resultados de 32 bits. Los Cortex-M0 / Cortex-M0+ / Cortex-M1 / Cortex-M23 se diseñaron para crear la matriz de silicio más pequeña, por lo que tienen la menor cantidad de instrucciones de la familia Cortex-M.

Los Cortex-M0 / M0+ / M1 incluyen instrucciones Thumb-1, excepto las nuevas instrucciones (CBZ, CBNZ, IT) que se agregaron en la arquitectura ARMv7-M. Los Cortex-M0 / M0+ / M1 incluyen un subconjunto menor de instrucciones Thumb-2 (BL, DMB, DSB, ISB, MRS, MSR). [14] Los Cortex-M3 / M4 / M7 / M33 / M35P tienen todas las instrucciones Thumb-1 y Thumb-2 base. El Cortex-M3 agrega tres instrucciones Thumb-1, todas las instrucciones Thumb-2, división de enteros de hardware e instrucciones aritméticas de saturación . El Cortex-M4 agrega instrucciones DSP y una unidad de punto flotante de precisión simple opcional (VFPv4-SP). El Cortex-M7 agrega una FPU de doble precisión opcional (VFPv5). [22] [15] Los Cortex-M23 / M33 / M35P / M52 / M55 / M85 agregan instrucciones TrustZone .

Desusos

La arquitectura ARM para la serie ARM Cortex-M eliminó algunas características de los núcleos heredados más antiguos: [14] [15]

Las capacidades del conjunto de instrucciones ARM de 32 bits se duplican de muchas maneras en los conjuntos de instrucciones Thumb-1 y Thumb-2, pero algunas características ARM no tienen una característica similar:

El conjunto de instrucciones Thumb-1 de 16 bits ha evolucionado con el tiempo desde que se lanzó por primera vez en los núcleos ARM7T heredados con la arquitectura ARMv4T. Se agregaron nuevas instrucciones Thumb-1 a medida que se lanzaban las arquitecturas ARMv5 / ARMv6 / ARMv6T2 heredadas. Algunas instrucciones Thumb-1 de 16 bits se eliminaron de los núcleos Cortex-M:

Corteza-M0

El núcleo Cortex-M0 está optimizado para chips de silicio de tamaño pequeño y para su uso en los chips de menor precio. [2]

Las características clave del núcleo Cortex-M0 son: [17]

Opciones de silicio:

Papas fritas

nRF51822

Los siguientes microcontroladores se basan en el núcleo Cortex-M0:

Los siguientes chips tienen un Cortex-M0 como núcleo secundario:

Corteza-M0+

Placa FRDM-KL25Z de NXP ( Freescale ) con KL25Z128VLK (Kinetis L)

El Cortex-M0+ es un superconjunto optimizado del Cortex-M0. El Cortex-M0+ tiene una compatibilidad total con el conjunto de instrucciones del Cortex-M0, lo que permite el uso del mismo compilador y las mismas herramientas de depuración. La secuencia de comandos del Cortex-M0+ se redujo de 3 a 2 etapas, lo que reduce el consumo de energía y aumenta el rendimiento (mayor IPC promedio debido a que las ramas toman un ciclo menos). Además de las características de depuración del Cortex-M0 existente, se puede agregar una opción de silicio al Cortex-M0+ llamada Micro Trace Buffer (MTB) que proporciona un búfer de seguimiento de instrucciones simple. El Cortex-M0+ también recibió características de Cortex-M3 y Cortex-M4, que se pueden agregar como opciones de silicio, como la unidad de protección de memoria (MPU) y la reubicación de la tabla de vectores. [18]

Las características clave del núcleo Cortex-M0+ son: [18]

Opciones de silicio:

Papas fritas

Los siguientes microcontroladores se basan en el núcleo Cortex-M0+:

Los siguientes chips tienen un Cortex-M0+ como núcleo secundario:

Los microcontroladores ARM más pequeños son del tipo Cortex-M0+ (a partir de 2014, el más pequeño, con 1,6 mm por 2 mm en un paquete a escala de chip, es Kinetis KL03). [32]

El 21 de junio de 2018, investigadores de la Universidad de Michigan anunciaron el « ordenador más pequeño del mundo» o dispositivo informático, basado en el ARM Cortex-M0+ (e incluyendo RAM y transmisores y receptores inalámbricos basados ​​en energía fotovoltaica ), en el Simposio de 2018 sobre tecnología y circuitos VLSI con el artículo «Un sistema de sensor inalámbrico y sin batería de 0,04 mm 3 16 nW con procesador Cortex-M0+ integrado y comunicación óptica para medición de temperatura celular». El dispositivo tiene una décima parte del tamaño del ordenador récord mundial que IBM afirmó haber alcanzado en marzo de 2018, que es más pequeño que un grano de sal.

Corteza-M1

El Cortex-M1 es un núcleo optimizado especialmente diseñado para ser cargado en chips FPGA . [4]

Las características clave del núcleo Cortex-M1 son: [19]

Opciones de silicio:

Papas fritas

Los siguientes proveedores admiten el Cortex-M1 como núcleo blando en sus chips FPGA:

Corteza-M3

Placa Arduino Due con microcontrolador Atmel ATSAM3X8E ( núcleo ARM Cortex-M3 )
Placa de desarrollo NXP LPCXpresso con LPC1343

Las características clave del núcleo Cortex-M3 son: [20] [35]

Opciones de silicio:

Papas fritas

Los siguientes microcontroladores se basan en el núcleo Cortex-M3:

Los siguientes chips tienen un Cortex-M3 como núcleo secundario:

Los siguientes FPGA incluyen un núcleo Cortex-M3:

Los siguientes proveedores admiten el Cortex-M3 como núcleo blando en sus chips FPGA:

Corteza-M4

Placa Wonder Gecko STK de Silicon Labs ( Energy Micro ) con EFM32 WG990
Placa de lanzamiento TI Stellaris con LM4F120

En teoría, el Cortex-M4 es un Cortex-M3 más instrucciones DSP y una unidad de punto flotante (FPU) opcional. Un núcleo con una FPU se conoce como Cortex-M4F.

Las características clave del núcleo Cortex-M4 son: [21]

Opciones de silicio:

Papas fritas

nRF52833 en un micro bit v2
STM32F407IGH6

Los siguientes microcontroladores se basan en el núcleo Cortex-M4:

Los siguientes microcontroladores se basan en el núcleo Cortex-M4F (M4 + FPU ):

Los siguientes chips tienen un Cortex-M4 o M4F como núcleo secundario:

Corteza-M7

Placa Arduino GIGA R1 WiFi con microcontrolador STM32H747XIH6 (ARM Cortex-M7 de doble núcleo + ARM Cortex-M4)

El Cortex-M7 es un núcleo de alto rendimiento con casi el doble de eficiencia energética que el antiguo Cortex-M4. [7] Cuenta con una tubería superescalar de 6 etapas con predicción de ramificaciones y una unidad de punto flotante opcional capaz de realizar operaciones de precisión simple y, opcionalmente, de precisión doble . [7] [38] Los buses de instrucciones y datos se han ampliado a 64 bits de ancho en comparación con los buses de 32 bits anteriores. Si un núcleo contiene una FPU, se lo conoce como Cortex-M7F; de lo contrario, es un Cortex-M7.

Las características clave del núcleo Cortex-M7 son: [22]

Opciones de silicio:

Papas fritas

Los siguientes microcontroladores se basan en el núcleo Cortex-M7:

Corteza-M23

El núcleo Cortex-M23 se anunció en octubre de 2016 [39] y se basa en la arquitectura ARMv8-M que se anunció previamente en noviembre de 2015. [40] Conceptualmente, el Cortex-M23 es similar a un Cortex-M0+ más instrucciones de división de enteros y características de seguridad TrustZone, y también tiene una secuencia de instrucciones de 2 etapas . [8]

Las características clave del núcleo Cortex-M23 son: [23] [39]

Opciones de silicio:

Papas fritas

Los siguientes microcontroladores se basan en el núcleo Cortex-M23:

Corteza-M33

El núcleo Cortex-M33 se anunció en octubre de 2016 [39] y se basa en la arquitectura ARMv8-M que se anunció previamente en noviembre de 2015. [40] Conceptualmente, el Cortex-M33 es similar a un cruce de Cortex-M4 y Cortex-M23, y también tiene un flujo de instrucciones de 3 etapas . [9]

Las características clave del núcleo Cortex-M33 son: [24] [39]

Opciones de silicio:

Papas fritas

Los siguientes microcontroladores se basan en el núcleo Cortex-M33:

Los siguientes chips tienen un Cortex-M33 o M33F como núcleo secundario:

Corteza-M35P

El núcleo Cortex-M35P se anunció en mayo de 2018 y se basa en la arquitectura Armv8-M . Es conceptualmente un núcleo Cortex-M33 con un nuevo caché de instrucciones, además de nuevos conceptos de hardware a prueba de manipulaciones tomados de la familia ARM SecurCore y funciones de paridad y ECC configurables. [10]

Actualmente, la información sobre el Cortex-M35P es limitada, porque su Manual de referencia técnica y su Guía de usuario genérica aún no se han publicado.

Papas fritas

Los siguientes microcontroladores se basan en el núcleo Cortex-M35P:

Corteza-M52

El núcleo Cortex-M52 se anunció en noviembre de 2023 y se basa en la arquitectura Armv8.1-M . Tiene un flujo de instrucciones de 4 etapas. [11]

Las características clave del núcleo Cortex-M52 incluyen:

Opciones de silicio:

Papas fritas

Corteza-M55

El núcleo Cortex-M55 se anunció en febrero de 2020 y se basa en la arquitectura Armv8.1-M . Tiene un flujo de instrucciones de 4 o 5 etapas. [12]

Las características clave del núcleo Cortex-M55 incluyen:

Opciones de silicio:

Papas fritas

Corteza-M85

El núcleo Cortex-M85 se anunció en abril de 2022 y se basa en la arquitectura Armv8.1-M . Tiene un flujo de instrucciones de 7 etapas. [13]

Opciones de silicio:

Papas fritas

Herramientas de desarrollo

Documentación

La documentación de los chips ARM es extensa. En el pasado, la documentación de los microcontroladores de 8 bits cabía normalmente en un único documento, pero a medida que los microcontroladores han evolucionado, también lo ha hecho todo lo necesario para respaldarlos. Un paquete de documentación para chips ARM suele estar compuesto por una colección de documentos del fabricante del CI y del proveedor del núcleo de la CPU ( ARM Limited ).

Un árbol de documentación de arriba hacia abajo típico es:

Árbol de documentación (de arriba a abajo)
  1. Sitio web del fabricante de IC.
  2. Diapositivas de marketing del fabricante de circuitos integrados.
  3. Hoja de datos del fabricante del circuito integrado para el chip físico exacto.
  4. Manual de referencia del fabricante de circuitos integrados que describe periféricos comunes y aspectos de una familia de chips físicos.
  5. Sitio web principal de ARM.
  6. Guía de usuario genérica del núcleo ARM.
  7. Manual de referencia técnica del núcleo ARM.
  8. Manual de referencia de la arquitectura ARM.

Los fabricantes de circuitos integrados tienen documentos adicionales, como manuales de usuario de placas de evaluación, notas de aplicación, guías de inicio, documentos de bibliotecas de software, erratas y más. Consulte la sección Enlaces externos para obtener enlaces a documentos oficiales de Arm.

Véase también

Referencias

  1. ^ Sitio web de ARM Cortex-M; ARM Limited.
  2. ^ ab "Cortex-M0 Home". ARM Limited .
  3. ^ "Cortex-M0+ Home". ARM Limited .
  4. ^ ab "Cortex-M1 Home". ARM Limited .
  5. ^ "Cortex-M3 Home". ARM Limited .
  6. ^ "Cortex-M4 Home". ARM Limited .
  7. ^ abc "Cortex-M7 Home". ARM Limited .
  8. ^ ab "Cortex-M23 Home". ARM Limited .
  9. ^ ab "Cortex-M33 Home". ARM Limited .
  10. ^ abc "Cortex-M35P Home". ARM Limited .
  11. ^ ab "Cortex-M52 Home". ARM Limited .
  12. ^ ab "Cortex-M55 Home". ARM Limited .
  13. ^ ab "Cortex-M85 Home". ARM Limited .
  14. ^ abcdefghijklmnopqr "Manual de referencia de la arquitectura ARMv6-M". ARM Limited .
  15. ^ abcdefghijklmnopqr "Manual de referencia de la arquitectura ARMv7-M". ARM Limited .
  16. ^ abcd Desarrollo de software integrado Cortex-M3; Nota de aplicación 179; ARM Limited.
  17. ^ abc "Manual de referencia técnica de Cortex-M0". ARM Limited .
  18. ^ abcd "Manual de referencia técnica de Cortex-M0+". ARM Limited .
  19. ^ abc "Manual de referencia técnica de Cortex-M1". ARM Limited .
  20. ^ abc "Manual de referencia técnica de Cortex-M3". ARM Limited .
  21. ^ abc "Manual de referencia técnica de Cortex-M4". ARM Limited .
  22. ^ abcd "Manual de referencia técnica de Cortex-M7". ARM Limited .
  23. ^ abc "Manual de referencia técnica de Cortex-M23". ARM Limited .
  24. ^ abc "Manual de referencia técnica de Cortex-M33". ARM Limited .
  25. ^ ab "Manual de referencia técnica de Cortex-M52". ARM Limited .
  26. ^ ab "Manual de referencia técnica de Cortex-M55". ARM Limited .
  27. ^ ab "Manual de referencia técnica de Cortex-M85". ARM Limited .
  28. ^ abc "Kit de diseño de sistemas Cortex-M (CMSDK)". Arm Holdings . Archivado desde el original el 4 de marzo de 2016.
  29. ^ abcdefghij Guía de programación de instrucciones de barrera de memoria ARM Cortex-M; Sección 3.6 Requisitos de implementación del sistema; AppNote 321; ARM Limited.
  30. ^ abcdefghijkl "Manual de referencia de la arquitectura ARMv8-M". ARM Limited .
  31. ^ Microcontroladores PIC y SAM de 32 bits; Microchip.
  32. ^ Fingas, Jon (25 de febrero de 2014). "Freescale hace que el chip controlador ARM más pequeño del mundo sea aún más pequeño" . Consultado el 2 de octubre de 2014 .
  33. ^ GOWIN Semiconductor se une a ARM DesignStart y ofrece procesadores ARM Cortex-M1 gratuitos para sus familias de productos FPGA
  34. ^ FPGA Cortex-M1 DesignStart XilinxEdition; ARM Limited.
  35. ^ Sadasivan, Shyam. "Introducción al procesador ARM Cortex-M3" (PDF) . ARM Limited. Archivado desde el original (PDF) el 26 de julio de 2014.
  36. ^ "Análisis en profundidad del Samsung Exynos 7420: el interior de un SoC moderno de 14 nm". AnandTech . Consultado el 15 de junio de 2015 .
  37. ^ Diseño Cortex-M3Start FPGA Edición Xilinx
  38. ^ "ARM potencia el mercado de microcontroladores con el procesador Cortex-M7 de alto rendimiento". ARM Limited (nota de prensa). 24 de septiembre de 2014.
  39. ^ abcd Los nuevos procesadores ARM Cortex-M ofrecen el próximo estándar industrial para IoT seguro; ARM Limited; 25 de octubre de 2016.
  40. ^ ab La arquitectura ARMv8-M simplifica la seguridad de los dispositivos integrados inteligentes; ARM Limited; 10 de noviembre de 2015.

Lectura adicional

Enlaces externos

Documentos oficiales de ARM Cortex-M
Tarjetas de referencia rápida
Migrando
Otro