统详解Silabs MCU低功耗优势及经典案例

发布者:来来去去来来最新更新时间:2014-11-20 来源: 21ic关键字:C8051F  SilabsMCU  单片机功耗 手机看文章 扫描二维码
随时随地手机看文章

  引言

  现在的电子产品,对低功耗的要求越来越高。产品功耗的问题是经常让产品设计者头痛而又不得不面对的一个问题。以单片机为核心的系统,其功耗主要由单片机功耗和单片机外围电路功耗组成。

  要降低单片机系统的功耗,需要从硬件和软件两方面入手。美国SiliconLaboratories公司(Silabs)设计的高速C8051F系列单片机是一种高度集成的SoC型芯片,兼容传统的8051单片机内核和指令系统,但其各方面的性能都远远超越了传统的8051单片机。C8051F系列单片机中增加的外设或功能部件有:模拟多路选择器、可编程增益放大器、ADC、DAC、电压比较器、电压基准、温度传感器、SMBus(I2C)、增强型UART、SPI、可编程计数/定时器阵列(PCA)、电源监视器、看门狗定时器(WDT)和时钟振荡器等。另外还有片上的FLASH程序存储器和RAM。特别是在低功耗设计方面,提供了多种低功耗模式供用户选择,方便客户设计出不同低功耗要求的产品。

  本文将从以下三个方面来谈SilabsMCU低功耗优势及其实现方法:

  如何设计低功耗单片机系统;

  SilabsMCU在低功耗方面的优势;

  SilabsMCU低功耗实现方法。

  如何设计低功耗单片机系统

  功耗单片机系统设计,需要从硬件设计和应用软件设计两方面入手。

  硬件设计

  要满足单片机系统的低功耗要求,选用具有低功耗特性的单片机可以很容易实现。因为具有低功耗特性的单片机可以大大降低系统功耗,这可以从单片机的供电电压、内部结构、系统时钟和低功耗模式等几方面来考察一款单片机的低功耗特性。

  选择简单的CPU内核

  选择CPU内核时切忌一味追求性能,以“够用就好”为原则。8位机够用,就没有必要选用16位机、32位机;单片机的运行速度越快,往往其功耗也越大。一个CPU越复杂、集成度越高、功能越强,片内晶体管越多,总漏电流也越大,即使进入STOP状态,漏电流也会变得不可忽视;而简单的CPU内核不仅功耗低,成本也低。

  选择低电压供电的单片机系统

  单片机系统的供电电压低,可以有效的降低其系统功耗。由于半导体制造工艺的发展,现在单片机的供电电压从5V供电降低到3.3V、3V、2V乃至1.8V。供电电压低,不紧可以降低单片机的功耗,还可以降低单片机外围电路的功耗。

  选择带有低功耗模式的单片机系统

  低功耗模式指的是系统的Idle、Stop和Suspend等模式。处于这些模式下的功耗将远远小于正常运行下的功耗。

  Idle模式下,CPU停止工作,但内部系统时钟并不停止,单片机的外围I/O模块也不停止工作;系统功耗一般降低有限,相当于工作模式功耗的50%左右。

   Stop模式下,CPU和内部系统时钟停止工作,所有的数字外设也自动停止工作,内部RAM的信息以最小功耗被保持,CPU消耗电流可降到μA级,由外 部或内部的复位使系统退出Stop模式,进而唤醒CPU继续工作。如果在CPU进入Stop模式时,将各个模拟外设关掉,这时的功耗可以降低到nA级。但 是在Stop模式下,CPU被唤醒后要重新对系统作初始化,所有特殊功能寄存器的内容将被重新初始化。这在某些低功耗应用场合需要注意。

   Suspend模式下,CPU、内部系统时钟停止工作,I/O模块等被悬挂起来,片内RAM中存储的数据将被保持,CPU的功耗可以降低到nA级,由唤 醒事件唤醒。当CPU被唤醒后,系统不会被CPU复位,继续从进入Suspend模式的地方开始执行程序。这是一种非常理想的低功耗模式。

  选择合适的时钟方案

  时钟的选择对于系统的功耗相当敏感,需要注意三方面的问题:

  A)系统总线频率应当尽量低

  单片机内部的总电流消耗可分为运行电流和漏电流两部份。单片机集成度越高,环境温度越高,漏电流也越大。在单片机运行时,开关电 路不断地由“1”变“0”、由“0”变“1”,内部电容不停地充放电,这些都是单片机运行时电流的主要来源。要实现开关电路快速关断和电容的快速充放电, 需要比较大的电流。运行电流几乎是和单片机的时钟频率成正比的,因此尽量降低系统时钟的运行频率可以有效地降低系统功耗。

  B)选择适合低功耗的单时钟方案

  单片机时钟是使用锁相环、外部振荡器,还是内部振荡器,这与单片机的功耗有很大关系。现代单片机普遍采用锁相环技术,允许用户在片外使用频率较低的振荡器,通过程序控制,系统时钟可以在一个很宽的范围内调整,总线频率往往能升得很高,但是会带来额外的功率消耗。仅仅就时钟方案来讲,使用外部振荡器且不使用锁相环是功率消耗最小的一种。

  C)选择适合低功耗的双时钟方案

  有些场合的应用比较复杂,对MCU的速度要求也很高。尽管采用新的半导体工艺,但MCU速度越高,一般来说功耗也越大。因此很多高速MCU提供了双时钟系统,并允许MCU在运行中实时快速的进行时钟切换,以达到降低功耗的目的。

  SilabsMCU带有内部高速振荡器,又可以使用外部振荡器,并且可以在CPU运行中实时高速地进行内、外振荡器切换。这对于间歇工作的系统是一种非常好的低功耗方式。当要处理数据时,使用内部高速振荡器;当CPU空闲时,切换到外部低速振荡器,以降低功耗。

  使用每MIPS功耗来衡量MCU的低功耗性能是相对比较准确

  尽管我们强调要降低单片机系统的功耗,必须尽量降低单片机的系统时钟。但使用每MIPS功耗来衡量MCU的功耗与之并不矛盾。这是相对的,要具体问题具体分析。

  例如,执行一个需要10K条指令的任务,甲MCU的工作电流为3mA,速度为10MIPS,则甲MCU需要工作1mS完成该任务,消耗3mA×1ms×Vcc,然后甲MCU就可以进入低功耗模式了。

  而乙MCU的工作电流为1mA,速度为2MIPS,则乙MCU需要工作5ms完成,这样乙MCU完成该任务的消耗为1mA×5ms×Vcc。

  从上面的例子我们可以得出结论:电流大但速度快的MCU可能更省电。

  应用软件设计

  应用软件设计对于一个低功耗系统的重要性常常被人们忽略。一个重要的原因是,软件设计上的缺陷并不像硬件那样容易发现,同时也没有一个严格的标准来判断一个软件的低功耗特性。但是设计者如果能尽量将应用的低功耗特性反映在软件中,就可以避免那些“看不见”的功耗损失。[page]

  用“中断”代替“查询”

  在没有要求低功耗的场合,程序使用中断方式还是查询方式并不重要。但在要求低功耗场合,这两种方式相差甚远。使用中断方式,CPU可以什么都不做,甚至可以进入等待模式或停止模式;而查询方式下,CPU必须不停地访问I/O寄存器,这会带来很多额外的功耗。

  用“宏”代替“子程序”

  子程序调用的入栈出栈操作,要对RAM进行两次操作,会带来更大的功耗。宏在编译时展开,CPU按顺序执行指令。使用宏,会增加程序的代码量,但对不在乎程序代码量大的应用,使用宏无疑会降低系统的功耗。

  尽量减少CPU的运算量

  减少CPU的运算工作量,可以有效地降低CPU的功耗。减少CPU运算的工作可以从很多方面入手:

  A)用查表的方法替代实时的计算;

  B)不可避免的实时计算,算到精度够了就结束,避免“过度”的计算;

  C)尽量使用短的数据类型,例如,尽量使用字符型的8位数据替代16位的整型数据,尽量使用分数运算而避免浮点数运算等。

  让I/O模块间歇运行

  A)不用的I/O模块要关掉,间歇使用的I/O模块要及时关掉,以节省电能。

  B)不用的I/O引脚要设置成输出或设置成输入,用上拉电阻拉高。

  总之,在单片机系统设计过程中,深入理解单片机低功耗的特性,并在硬件和应用软件的设计过程中充分利用单片机的低功耗特性,来设计出符合低功耗要求的产品。

  SilabsMCU在低功耗方面的优势

   Silabs的C8051F系列单片机是从传统的8051单片机衍生出来的一种新型高速单片机。它属于CISC指令系统,但由于采用“流水线”结构方式 处理指令,70%的指令的执行时间为1个或2个系统时钟,指令执行的峰值速度为MIPS级别。虽然它的运行速度很高,但是在低功耗设计方面具有独特的优 势。这主要体现在:

  供电电压范围宽

  SilabsMCU的供电电压范围为2~5.25V。

  宽的供电电压范围不仅为单片机系统设计带来方便,而且低的供电电压可以有效地降低整个单片机系统的功耗。

  有多种低功耗模式

   SilabsMCU有Idle、Stop和Suspend三种低功耗模式。各种模式下片上资源状态、功耗及唤醒的情况如表1所示。在Stop和 Suspend模式下,MCU的功耗可以降低到nA级。在Suspend模式下,有多种唤醒源,当被唤醒时(非复位源唤醒),CPU不会对系统复位。在 Stop模式下,SilabsMCU有丰富的复位源使CPU被唤醒,如图1所示。

  有多种时钟方案供选择

  SilabsMCU都设计有两套时钟方案供选择。用户可以根据实际需要选择内部振荡器或外部振荡器,或者同时选择内、外振荡器。内部振荡器可以通过相关 寄存器设置来选择不同的频率。其频率范围为:80KHz~100MHz。更为重要的是在MCU运行中,可以实时高速地进行内、外时钟切换。时钟切换速度 快,切换产生的功耗小。这种特性,对于间歇工作的单片机系统低功耗设计,特别有帮助。

  灵活的I/O设计

  SilabsMCU的I/O口资源丰富,配置灵活。有三种配置方式:漏极开路、推挽输出和弱上拉方式。用户可以根据实际需要通过相关寄存器的设置来禁止或使能这些方式。其中将端口配置成漏极开路方式是最省电的方式。

  高速实时的中断响应

  SilabsMCU响应中断的时间非常快,一般只需要5个系统时钟周期。中断响应速度快,CPU花费在等待方面的时间少,这可以节省不少的等待功耗。

  运算速度快,处理数据能力强

   虽然Silabs的C8051F系列单片机属于CISC指令系统,但由于它采用了“流水线”结构方式处理指令,70%的指令的执行时间为1个或2个系统 时钟,突破了传统的8051单片机运行效率低的弱点,特别是它执行乘法指令只要4个系统时钟,执行除法指令只要8个系统时钟。与那些RISC指令系统的单 片机和那些速度低的CISC单片机相比,这不仅仅带来了数据运算的高效率,同时也极大地降低了系统的功耗。因此,使用每MIPS功耗来衡量Silabs的 C8051F系列单片机的功耗,无论是处理一般事件,还是做数据运算,它都是非常低的,具有明显的优势。图2是和其他MCU做除法运算的速度对比。从对比 中我们可以看出SilabsMCU具有高速处理数据能力的同时也带来了更低的功耗。

  总之,深入理解SilabsMCU低功耗的特性,根据实际情况,灵活运用,就可以设计出满足要求的低功耗产品。

  SilabsMCU低功耗实现方法

   这里举一个运动装置的应用,采用3V电池供电,间歇工作,要求平均功耗不大于200mA。使用SilabsMCUC8051F333成功地实现了低功耗 的应用。选择双时钟系统,即处理数据时使用内部高速振荡器25MHz,空闲时使用外部晶振32.768KHz(如图3所示),并进入Idle模式。

  没有使用到的片上模拟和数字外设全部关闭,没有用到的I/O全部设置成漏极开路方式。

  下面我们分析一下在不同情况下,CPU的功耗情况。

  在温度-40℃~85℃范围内,工作电压3V,系统时钟25MHz的情况下,CPU的功耗典型值是7.8mA。其电气特性参数表如表2所示。

  我们还可以大概估算出在不同频率下CPU的功耗。当F>15MHz时,可以用下面的公式来估算:

  IDD=IDD1-(F1-F)×IDD2(1)

  其中IDD1是在不同电压、最高频率下正常工作时的最小功耗,F1是最高工作频率,IDD2是F>15MHz,不同电压下的IDD频率敏感度。例如,VDD=3.0V;F=20MHz时,根据图2可以算出:

  IDD=7.8mA-(25MHz-20MHz)×0.21mA/MHz=6.75mA

  当F≤15MHz时,CPU的功耗可以用下面的公式来估算:

  IDD=F÷1MHz×IDD2(2)

  例如,VDD=3.0V;F=32.768KHz时,根据图2可以算出:

  IDD=32.768KHz÷1MHz×0.38mA/MHz=12.45184mA

  在温度-40℃~85℃范围内,工作电压3V,系统时钟32.768KHz的情况下,CPU的功耗可以通过Idle模式下的电气特性参数来计算。Idle模式下的电气特性参数表如表3所示。

  根据公式(2),Idle模式下的功耗为:

  IDD=32.768KHz÷1MHz×0.20mA/MHz=6.5536mA

  从上面的分析我们可以看出,使用外部低频振荡器,并进入Idle模式,CPU的功耗可以降的很低。如果能用上Stop模式,功耗可以降低到0.1mA以下。在模拟该运动装置真实使用环境的条件下,经过使用仪器测试,平均功耗降低到了150mA以下。该产品目前已经批量上市了。

  结语

  C8051F系列单片机封装小,高集成度,低功耗特性好。只要根据项目的实际情况,认真细致地分析产品的低功耗要求,灵活应用SilabsMCU的低功耗特性,从硬件和应用软件两方面入手,就可以设计出满足不同要求的低功耗产品。

关键字:C8051F  SilabsMCU  单片机功耗 引用地址:统详解Silabs MCU低功耗优势及经典案例

上一篇:基于低成本MCU MC9S08QE的肌电假手解决方案
下一篇:基于dsPIC30F的脉冲氙灯驱动系统

推荐阅读最新更新时间:2024-03-16 13:46

为何使用C而不使用汇编进行开发C8051F
好些年之前,我为自己写了几万行汇编代码而骄傲。 然而,做过多年软件开发的我,看到以前写的汇编代码也是很多不懂的,这可是自己亲手写的呀。汇编代码由于其可读性比较差,给后期的维护造成很大的困难。因此建议单片机的学习者们一定要学习C。 这句话要是我在读书的时候听到,只是会嗤之以鼻。“用汇编就足够了,为什么用C呢?如果您用汇编做不了,说明水平还不够”,这是我的典型想法,当时我的汇编水平甚至成为我的骄傲。然而几年之后的今天,我要劝说后来学习者一定要舍弃汇编而学习C语言,是否很好笑。 首先说说C的优点。 1、直观,可读性强:这点很重要。对于一个产品,周期是很长的,即使出第一台产品之后,还有很长的维护时间。这中间维护人员可能经常变动,
[单片机]
C8051F00x与智能点阵HCMS2964显示屏的串行接口
引言 HCMS2964是AGILENT TECHNOLOGIES公司生产的新一代点阵显示屏。该产品内部自带CMOS集成电路,可驱动LED,并可直接与处理器串行连接实现数据传输。由于其亮度调节方便快捷,故可广泛地应用在嵌入式系统和单片机控制的仪表、仪器和飞行模拟设备领域中,本文介绍了HCMS2964的显示原理和显示屏的驱动方式、亮度调节以及基层软件的设计方案。 1 HCMS 2964显示屏 HCMS2964模块为双列直插封装,每一个HCMS2964都有12个引脚以及内部晶阵和寄存器。HCMS2964它通过CMOS刷新电路来驱动四个发光的字符块,每个字符的尺寸是1.8 cm×1 cm,这些字符是由5column×8row共
[单片机]
<font color='red'>C8051F</font>00x与智能点阵HCMS2964显示屏的串行接口
c8051f005_DA测试程序
//----------------------------------------------------------------------------- // Includes //----------------------------------------------------------------------------- #include c8051f000.h // SFR declarations #include stdio.h //-----------------------------------------------------------------------------
[单片机]
NEC电子新款32位闪存微控制器产品,功耗降低50%
           ~低功耗的全闪存微控制器全新问世~ NEC电子日前完成了8款低功耗版32位闪存微控制器的开发,并将其作为全闪存微控制器的第一阶段产品,于即日起开始供应样品。此次推出的系列产品共包括4款V850ES/JG3-L产品和4款V850ES/JF3-L产品,它们均使用了低功耗技术,因此功耗仅为现有产品的一半左右。 新系列产品以32位全闪存微控制器“V850ES/JG3”为基础,大幅度降低了功耗。该系列产品的最大优势在于功耗由以往的1.7mW/MIPS降低至0.9 mW/MIPS,该功耗值不仅约为NEC电子以往同类产品的一半,而且低于普通16位微控制器的1MIPS的平均功耗值的一半。 通过使用新产品,用户不仅可以用更小
[新品]
基于Atmega48单片机的低功耗系统设计
随着微电子技术和计算机技术的发展,尤其是微机在各个领域的普遍应用,功耗、成本、体积以及可靠性等指标均成为设计者所关注的重要问题。尤其是在由电池供电的设备中,如何降低设备功耗成为设计的首要任务。本文中以ATMEL公司的Atmega48单片机为例,介绍了单片机低功耗设计的一般方法。 Atmega48单片机 低功耗系统设计首要是选择合适的单片机。Atmega48单片机是一款8位微控制器,具有高性能、低功耗的显著特点。由于采用RISC精简指令集结构,其指令集大多为单周期指令,具有高速运行的特点。3V供电时,未使能内部看门狗的情况下,Atmega48的典型掉电电流小于1uA。具体工作电流见图1。而且该单片机在1.8V~5.5V的电压范围内
[应用]
非对称双核心MCU助阵 Sensor Hub功耗锐减
以非对称双核心架构打造的微控制器(MCU)将使感测器中枢(Sensor Hub)功耗锐减。部分MCU业者正积极开发以非对称核心为架构的产品形式,以让Sensor Hub可基于各种任务配置不同核心的工作模式;其中,恩智浦(NXP)已于日前正式发布新一代Cortex-M0+/Cortex-M4F双核心MCU,使Sensor Hub可透过不同的运算核心完成感测器资讯接收、读取、处理等任务,进而提高运算效率及降低功耗。 恩智浦微控制器产品线多重市场经理Ross Bannatyne表示,非对称双核心架构能降低MCU功耗,使Sensor Hub耗能骤降。 恩智浦微控制器产品线多重市场经理Ross Bannatyne表示,现今行
[传感器]
单片机功耗设计杂谈
  现在,有许多单片机应用领域,都是用电池供电,节能成为设计工程师普遍关心的问题。希望大家就这方面展开讨论。以下提供一些讨论的方向:   1、如何降低系统功耗?(软件?硬件?)   2、各位在这方面有何经验教训?(可以拿出来与大家分享)   3、各种芯片的功耗比较?   4、SLEEP模式应用的注意事项?   5、一些新型的节能器件的介绍?   6、其它与低功耗设计相关的话题?   进入掉电模式   现在有很多的低功耗的片子,特别是在进入掉电模式之后,只有1uA的电流。也可以使用电源管理的方法,在不工作的时候,把系统电源关断,这样更省电我用了很久51芯片,本来对它的功耗非常不满,但是因为其价格越来越便宜,本身的性
[电源管理]
基于C8051F040的CAN总线智能节点设计
引言 “X型火控系统”根据实际需要采用了CAN总线方式来实现其内部单体间的通信。CAN总线是一种用于各种设备检测及控制的现场总线,它是一种多主总线,在高速网络和低成本的节点系统中应用都很广泛。CAN总线与一般的通信总线相比,它的数据通信具有突出的可靠性、实时性和灵活性。其特点如下: *可以多主方式工作。 *CAN节点只需对报文的标识符滤波即可实现点对点、一点对多点及全局广播方式发送和接收数据。 *CAN总线通信格式采用短帧格式。 *采用非破坏性总线仲裁技术。 *直接通信距离最大可达10km (速率5kb/s以下),最高通信速率可达1Mb/s (此时距离最长为40m),节点数可达110个,通信介质可以是双绞线、同轴电缆或光导纤维。
[工业控制]
基于<font color='red'>C8051F</font>040的CAN总线智能节点设计
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
随便看看
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved