发布时间:2022-05-16 阅读量:1203 来源: 我爱方案网整理 发布人: Aurora
较长的电池续航时间,对提高消费类设备的用户满意度至关重要。对于电池供电的物联网 (IoT) 端点,延长电池续航时间可降低维护成本,提高可靠性。由于这些设备所使用的微控制器功耗相对较大,因此设计人员需要选择并应用合适的架构以满足这些应用的需求。事实证明,多数情况下 16 位微控制器正是最佳选择。
虽然 8 位微控制器的功能逐渐强大,但是鉴于处理能力和可寻址存储器有限,性能上存在固有限制,以致于高性能应用通常不会选用 8 位微控制器。另一方面,基于 32 位内核的系统对于这些应用往往又稍显过火,尤其是导致不必要的功耗过大时。
解决方案恰恰位于 8 位和 32 位内核中间的平衡点——16 位微控制器。这类器件既像简单的单电源 8 位微控制器一样功耗较低,又 具有 32 位内核的部分性能和存储器优势。如果应用不要求很多线程同时处理,存储器要求也不太高,那么 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 内核状态的工作状态位,包括上次执行汇编指令所产生的结果状态。
晶振的启动时间,通常是指其通电后进入稳定振荡状态所需的时间。若启动时间过长,可从以下五个常见的影响因素方面进行优化。
RTC(Real-Time Clock,实时时钟)芯片作为一种独立的专用计时器件,其核心功能包括提供稳定的日历时钟、在主电源断电后持续运行、支持定时中断以及输出高精度时间戳,为各类嵌入式系统提供可靠的时间基准。
时钟系统是保障微控制器(MCU)稳定运行的核心,而晶振作为关键时钟源,主要分为无源晶振与有源晶振两种类型。下面将围绕工作原理、硬件接口、电气特性及其在MCU中的适配场景等维度,系统解析这两类晶振与MCU之间的关联逻辑。
恒温晶振(Oven Controlled Crystal Oscillator,简称OCXO)是高精度频率源的核心组件,选用切型更优(如SC切、AT切高精度型)、封装应力极小的高Q值晶片,通过恒温槽的超精密控温,让晶振始终工作在零温度系数点,几乎消除温度引发的频率漂移。
晶振倍频干扰(即高次谐波辐射)是电磁兼容(EMC)设计中非常棘手的问题,通常表现为基频25MHz的5次、7次谐波(如125MHz、175MHz等)处辐射超标。该问题源于晶振输出方波信号包含丰富的高次谐波成分,若PCB布局不当,晶振及其走线极易构成高效辐射天线,导致电磁干扰增强。