当前位置:首页 > 公众号精选 > wenzi嵌入式软件
[导读]引言笔者接触嵌入式领域软件开发已近五年,几乎用的都是ARMCortexM内核系列的微控制器。在这五年期间,感谢C语言编译器的存在,让我不用接触汇编即可进行开发,但是彷佛也错过了一些风景,没有领域到编译器之美和CPU之美,所以决定周末无聊的休息时间通过寻找资料、动手实验、得出结论的...

引言

笔者接触嵌入式领域软件开发已近五年,几乎用的都是 ARM Cortex M 内核系列的微控制器。在这五年期间,感谢C语言编译器的存在,让我不用接触汇编即可进行开发,但是彷佛也错过了一些风景,没有领域到编译器之美和CPU之美,所以决定周末无聊的休息时间通过寻找资料、动手实验、得出结论的方法来探索 ARM CPU 架构的美妙,以及C语言编译器的奥秘。(因为我个人实在是不赞同学校中微机原理类课程的教学方法)。
  • ARM探索之旅 | 一、带你认识ARM Cortex-M阵营

一、Arm指令集架构

ARM指令集架构简称为ISA,支持三种指令集:A64、A32、T32。
  • A64指令集在 Armv8-A 中,用于支持64位架构
  • A32指令集在 Armv6 和 Armv7架构中,称为ARM指令集
  • T32指令集在 Armv6 和 Armv7架构中,称为Thumb指令集

A32 Instruction Set

A32指令集,在 armv8 之前的架构中也被称为 「ARM 指令集,指令长度固定32位,4字节对齐」

T32 Instruction Set

T32指令集,在 armv8 之前的架构中被称为 Thumb 指令集。
最初,ARM 指令集的长度固定为 32 位,为了改善用户代码的代码密度,「Thumb 指令集被设计为 16 位指令集」,开发者可以同时使用ARM指令集和Thumb指令集来降低代码大小。但这是两套指令集,两个运行状态,需要在ARM状态和Thumb状态之间来回切换,非常麻烦。
随着时间的推移和Thumb-2技术的引入,「作为Thumb指令集的补充,ARM指令集的大部分功能都被纳入到了Thumb指令,Thumb指令集演化为16位和32位混合长度指令集,称为Thumb-2指令集」
Thumb-2指令集的诞生,使得编译器可以在单个指令集中平衡性能和代码的大小,提供了极好的代码密度,最小化系统内存大小和成本。

二、Arm架构扩展

ARM还提供了一系列的架构扩展用于满足下一代处理器的需求,这些扩展为ARM处理器提供了一些新的功能。

DSP扩展

DSP for Cortex-M 为 ARM Cortex-M 处理器提供了高性能的「信号处理能力」,用于声音、音频、传感器中枢、机器学习等场景, 不需要额外的 DSP 设备即可完成信号处理的工作。
带有 DSP 扩展的处理器包括Cortex-M4、Cortex-M7、Cortex-M33、Cortex-M35P、Cortex-M55处理器。
DSP扩展指令在 Thumb 指令集和可选的浮点运算单元的基础上添加,使得在为Cortex-M处理器添加数字信号处理的同时,保持了原有Cortex-M编程模型的易用性。

SIMD指令

这些带有DSP扩展的 Cortex-M 处理器,还提供了 「SIMD 指令」来操作8位或者16位的整数。
SIMD表示单指令多数据,在所有寄存器仍是32位的基础上,「SIMD指令可以同时操作2个16 bit 的值或者4个8 bit 的值」

工作于8位或16位数据的指令对于处理诸如视频数据或者音频数据的时候非常有用,因为这些数据不需要32位的宽度,SIMD指令提供了并行处理这些数据的能力。

浮点单元

ARM浮点单元技术为「半精度、单精度和双精度的浮点运算」提供了高性能和高效率的硬件支持。
Arm浮点单元使用完整的软件库支持,完全兼容IEEE-754标准,特别适用于对浮点计算精度要求比较高的应用场景。
浮点数据类型的应用场景如下:
  • 汽车控制程序
  • 3D图形
  • 工业控制系统
  • 运动控制系统

Helium

ARM Helium 技术是ARM Cortex-M处理器系列的 M配置向量扩展,简称MVE,该技术是Armv8.1-M架构的扩展,为小型嵌入式设备的机器学习应用提供给了显著的性能提升。
Cortex-M55是首款具有该扩展的处理器。
Helium技术添加了150多个新的标量和向量指令,其中整数Helium技术使8位、16位、32位固定点数据的高效计算成为可能,16位和32位固定点格式在传统的信号处理中广泛应用,比如音频处理,而8位固定点格式在机器学习处理中很重要,比如神经网络计算,图像处理等。
同样,Helium也支持浮点数据类型,包括单精度浮点数(32位)和半精度浮点数(16位)。

三、Cortex-M用什么指令集

讲述了ARM的基本指令集和扩展指令集,是时候来回答我们提出的问题:ARM Cortex-M用什么指令集?
「ARM Cortex-M 全部系列只支持唯一的指令集:Thumb指令集或Thumb-2指令集。确切的来说,是支持T32指令集。」
在Cortex-M阵营众多的成员中,每个处理器对 Thumb/Thumb-2 指令集的支持情况不同,「大部分处理器都是支持 Thumb/Thumb-2 指令集的子集」
Cortex-M0、Cortex M3、Cortex M4、Cortex M7系列支持的Thumb指令集如图所示。Cortex-M23和Cortex-M33内核支持的Thumb指令如下图所示,图中黄色部分表示ArmV8-M系列新增的指令:

至此,ARM探索之旅第二站就结束啦!下一站再会!

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

2024年4月26日,中国 – 服务多重电子应用领域、全球排名前列的半导体公司意法半导体 (STMicroelectronics,简称ST;纽约证券交易所代码:STM) 公布了按照美国通用会计准则 (U.S. GAAP)...

关键字: 微控制器 模拟器件

利用LogiCoA™微控制器,以更低功耗实现与全数字控制电源同等的功能

关键字: 微控制器 电源 CPU

Arm CPU正在从根本上推动AI变革,并造福地球。Arm架构是未来AI计算的基石。​

关键字: ARM AI

台湾新竹 – 2024年4月23日 – 著名的微控制器供货商新唐科技公司,与全软件开发生命周期提供跨平台解决方案的全球软件公司Qt Group宣布深化合作,扩展新唐科技人机界面(HMI)平台支持「Qt for MCUs」...

关键字: 微控制器 嵌入式系统 MCU

近日,Arm推出了Arm® Ethos™-U85神经网络处理器(NPU)和Arm Corstone™-320物联网参考设计平台,旨在满足海量的数据处理和大规模计算,加速推进边缘AI的发展进程。

关键字: ARM

全新Balletto™系列无线MCU基于Alif Semiconductor先进的MCU架构,该架构具有DSP加速和专用NPU,可快速且低功耗地执行AI/ML工作负载

关键字: 处理器 微控制器 AI

为了赶超云计算市场上的竞争对手,谷歌正试图通过定制的Arm服务器芯片降低云计算服务成本。

关键字: 谷歌 ARM 定制芯片

2024年4月10日 –提供超丰富半导体和电子元器件™的业界知名新品引入 (NPI) 代理商贸泽电子 (Mouser Electronics) 即日起开售NXP Semiconductors的MCX工业和物联网微控制器...

关键字: 微控制器 电机控制 机器学习

中国上海–2024年4月9日–在追求创新的道路上,英飞凌(Infineon)再次领导行业,推出突破性的PSoC™ 4000T 微控制器。全球知名的电子元器件授权代理商富昌电子(Future Electronics)现为各...

关键字: 微控制器 电容式传感板

开放计算项目(OCP)是一个非营利组织,专注于推动各企业在数据中心产品设计及最佳实践方面加强交流。近日,该组织发布了开放机架第三版(ORV3)规范。规范中比较显著的变化在于设计架构从12 V迁移到了48 V。本系列文章重...

关键字: 微控制器 电池 开放计算
关闭
关闭