怎样充分利用 16 位微控制器的高性能和低功耗?
扫描二维码
随时随地手机看文章
本文介绍了 16 位微控制器的架构及其如何成为许多电池供电的消费类设备和物联网端点应用的最佳选择。此外,还介绍了 Microchip Technology 和 Texas Instruments 推出的几款 16 位微控制器,并说明如何使用 16 位内核着手设计。
微控制器选型
在设计过程中,定义项目要求后的第一步就是为应用选择合适的微控制器。三种主流选项分别是 8 位、16 位和 32 位微控制器。
不夸张地说,8 位微控制器应用极为普遍,堪称设计人员的主力器件。低成本、低功耗的 8 位微控制器几乎适用于任何小功率应用:主流微控制器中功耗最低的器件,某些器件待机电流低于 100 nA。
使用也相对简单,8 位微控制器大多基于累加器,尽管一些较新的架构具有寄存器组,因而编程模型简单且有限:累加器或带单个状态寄存器的小寄存器组、堆栈指针,以及一个或多个变址寄存器。堆栈往往都是硬件堆栈,并且固件无法访问程序计数器 (PC)。
尽管 8 位架构广受青睐,可一旦涉及网络和通信就遇到了瓶颈。几乎所有通信堆栈和网络协议都采用 16 位或 32 位,因此不必考虑 8 位架构。此外,即便是高端 8 位微控制器也往往局限于 16 位寻址,不具备分页机制,限制了固件的大小和复杂性。
另一方面,32 位微控制器在所有高性能应用中广泛应用。基于寄存器的架构可轻松支持网络和通信;通常使用 32 位寻址,支持浮点运算和高等代数运算,并且时钟速率可达千兆赫级。32 位内核具有更复杂的编程模型,包括多个状态寄存器、固件可访问的 PC、复杂的中断管理以及两层或多层固件执行权限。
16 位微控制器虽都基于寄存器,但架构同 8 位内核一样简单。因此,16 位内核往往都具有良好的低功耗性能,电流消耗明显低于 32 位架构,功耗则几乎与 8 位内核一样低。如果应用需要进行高等数学运算,一些 16 位微控制器具有数学协处理器,在相同的内部时钟速度下其数学性能可与 32 位内核媲美。
此外,许多通信协议栈都支持 16 位微控制器联网。对于以太网、CAN、USB 和 Zigbee 等协议栈,只要应用程序代码的性能足以支持堆栈,那么使用 16 位微控制器的运行速度可与 32 位微控制器一样快。
使用 16 位微控制器进行大型闪存阵列寻址
32 位与 16 位架构的一大差异在于存储器寻址范围。32 位微控制器具有 32 位地址总线,可以访问高达 4 GB 的存储器。传统 16 位 微控制器使用 16 位寻址,只能访问 64 KB 的存储器。不过,如今许多 16 位架构都使用高达 24 位的扩展寻址,相当于扩充了 16 MB 的地址空间。
Microchip Technology 的低功耗 PIC24F 微控制器系列是扩展寻址方式的典型范例。其中一款微控制器 PIC24FJ1024GA,32 MHz 的 16 位微控制器具有 1 MB 的板载闪存和 32 KB 的板载 SRAM,使用类似于许多 8 位微控制器的简单编程模型(图 1)。
Microchip 的 PIC24F 编程模型示意图
图 1:Microchip 的 PIC24F 编程模型类似于高端 8 位微控制器,采用基于寄存器的架构,具有 16 个通用 16 位寄存器、堆栈指针、PC 和 5 个辅助寄存器。(图片来源:Microchip Technology)
PIC24 具有 23 位程序计数器,可以访问高达 8 MB 的程序闪存。16 个 16 位寄存器,称为工作寄存器 (WREG),记作 W0 至 W15:W0 至 W13 寄存器是通用寄存器 (GP),可在固件控制下用于存储数据;W15 是专用堆栈指针 (SP),除了可以通过函数和子例程调用、编程异常处理和调用返回使其自动递增和递减外,SP 也可如 W0 至 W13 寄存器一样通过固件修改。
使用 LINK 和 UNLINK 汇编指令可将 W14 用作堆栈帧指针 (FP)。堆栈指针限制寄存器 (SPLIM) 是一个独立寄存器,可与 SP 配合使用以防止堆栈溢出。
PIC24 采用具有独立地址和数据空间的哈佛架构。与特殊指令配合使用,数据表页地址 (TBLPAG) 寄存器和程序空间可视性页地址 (PSVPAG) 寄存器可用于访问并在地址和数据空间之间传输数据。这是 32 位架构的常用功能,但 8 位内核却鲜少具备。
16 位重复循环计数器 (RCOUNT) 寄存器包含循环计数器,可用于 REPEAT 汇编指令。
16 位 CPU 内核控制 (CORCON) 寄存器用于配置 PIC24 内核的内部操作模式。
最后,16 位状态寄存器包含 PIC24 内核状态的工作状态位,包括上次执行汇编指令所产生的结果状态。
根据 Microchip Technology 对 PIC24FJ1024GA606T 的性能评定,工作频率为 32 MHz 时可达 16 MIPS。对于 16 位内核而言,这一指标着实令人印象深刻。该内核具有 32 位微控制器的许多功能,例如同时支持分数运算的 17 位 × 17 位硬件乘法器以及 32 位/16 位硬件除法器。对于需要对传感器数据进行计算的物联网端点而言,这些功能相当管用。此外,该架构还可以同时读写数据存储器,却丝毫不影响性能。
虽然 PIC24FJ1024GA606T 具有 USB OTG 等多种标准外设,但在电池供电应用中其功耗相当低。所需的供电电压仅为 2.0 V 至 3.6 V,微控制器以 32 MHz 的工作频率全速运行时电流消耗最大值为 7.7 mA,换作是 32 位内核则极难实现这一指标。通过固件可以控制核心和外设时钟。目前有两种使器件进入低功耗模式的汇编指令:IDLE 指令使 PIC24 内核停止运行,但外设可以继续工作;SLEEP 指令将停止除看门狗(可选)和外部中断检测外所有器件的操作。空闲模式下,最大电流仅为 2.8 mA,而休眠模式下,最大电流范围为 10 至 45 ?A,具体取决于外设配置。在最低功耗模式,即休眠模式下,仍保存随机存取存储器 (RAM) 中的内容,PIC24F 的消耗电流低至 190 nA。
为了获得更高的性能,Microchip Technology 在 dsPIC? 系列中推出高端 16 位微控制器。Microchip 的 dsPIC33EP512GP506T 是其中一款 16 位 70 MIPS 微处理器,具有 512 KB 的闪存。dsPIC 的内核寄存器与 PIC24 大致相同,只是增加了支持数字信号处理 (DSP) 指令的寄存器,包括两个 40 位累加器且支持 32 位乘法。如需对 PIC24 进行系统内升级,PIC24 微控制器大多可以进行引脚兼容的 dsPIC 升级,因而使用同一块印刷电路板亦可提高性能。
当然,性能越高,功率也就越大。这款 dsPIC33 的供电电压为 3.0 至 3.6 V,运行速度达 70 MIPS 时,最大电流为 60 mA。
降低功耗,提高性能
Texas Instruments 的 MSP430FR599x 微控制器系列采用该公司的铁电随机存取存储器 (FRAM) 程序存储器,实现更高的读/写性能,而 功耗较之闪存微控制器更低。MSP430FR5994IPNR 16 位微控制器是该系列产品之一,时钟频率达 16 MHz,具有 256 KB 的 FRAM。
MSP430FR 微控制器内核的性能增强功能包括双向关联缓存(由四个行宽为 64 字节的缓存块组成),从而实现更高的 FRAM 性能;32 位硬件乘法器可提高数学密集型操作的性能;以及独立于 MSP430 主内核的低能耗加速器 (LEA) 协处理器。该 LEA 可执行 256 点复数快速傅立叶变换 (FFT)、有限冲激响应 (FIR) 滤波器和矩阵乘法。根据 TI 的介绍,矩阵乘法的运算速度比 Arm? Cortex?-M0+ 最多快 40 倍。该 LEA 可提高传感器融合操作、图像增强和超声波传感器数据处理的性能。面对这些应用时,开发人员通常都优先考虑 32 位内核,而非超低功耗的 16 位微控制器。
MSP430R 的编程模型非常简单(图 2),共有 16 个 16 位寄存器 R0 至 R15:R0 是程序计数器,R1 是堆栈指针,R2 是状态寄存器,R3 是常数发生器(用于立即操作数),R4 至 R15 是通用寄存器。其他寄存器配置则采用内存映射方式,与多数 32 位内核类似。
Texas Instruments 的 MSP430 微控制器寄存器组示意图
图 2:MSP430 微控制器寄存器组配置与其他基于寄存器的 16 位内核类似。其他寄存器配置则采用内存映射方式。(图片来源:Texas Instruments)
提高了性能,却丝毫没有增加功耗。待机模式下,TI 的 MSP430FR5994 以实时时钟 (RTC) 运行,电流消耗仅为 350 nA。关断模式下,电流消耗仅为 45 nA。这一指标低于目前市面上任何一款 32 位微控制器,甚至低于多数 8 位微控制器。
MSP430FR5994IPNR 的工作电压范围为 1.8 至 3.6 V。固件以 FRAM 运行而缓存命中率为零时,MSP430FR 的电流消耗仅为 3 mA。若从缓存运行代码,则电流消耗仅为 790 ?A。结合 LEA,这款 16 位微控制器可提供极高的处理性能和极低的功耗。
通过 TI 的 MSP-EXP430FR5994 LaunchPad? 可轻松开发 MSP430FR5994 系列的低功耗应用。该 LaunchPad 开发套件包含了开发人员着手 MSP-EXP430FR5994 微控制器编码和固件调试所需的一切(图 3)。
该 LaunchPad 具有两个按钮、两个 LED 和一个 microSD 卡插槽。为了证明 MSP430FR5994 微控制器的低功耗性能,该 LaunchPad 具有 0.22 F 的超大电容为 LaunchPad 供电。将 LaunchPad 接入外部电源并将跳线 J8 设置为“充电”,即可为电容充电。只需 2 至 3 分 钟就可将电容完全充满。三分钟后,将跳线 J8 设置为“使用”,移除外部电源,MSP430 即可运行数分钟,具体视应用而定。
此外,该 LaunchPad 还可用于测量 MSP430 及其应用的电流消耗。J101 隔离块具有包括 3 V 电源跳线 3V3 在内的七根跳线。移除跳线 3V3,即可通过这两个引脚测量应用的电流。
该 LaunchPad 还支持 TI 的 EnergyTrace? 技术,可以连接计算机使用 Texas Instruments 的 EnergyTrace 图形用户界面 (GUI),使开发 人员能够实时观测 MSP430 微控制器和应用的功耗数据,从而微调应用以实现最低功耗。
例如,实时电流监控和记录可以显示 MSP430 微控制器的电流消耗偶尔出现激增。电流激增会降低电池质量,缩短电池寿命。电流激增可能缘于片上外设的错误配置、外部电感或电容负载,甚至是由于固件试图同时启动所有功能。通过电流监控和记录,开发人员可以明确应该如何调整固件,从而控制尖峰电流。