0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

详解低功耗设计

CHANBAEK 来源:数字IC与好好生活的两居室 作者:除夕之夜啊 2023-03-26 15:57 次阅读

功耗影响

便携性

功耗越低,同等电量下电子产品工作时间越长,便携性设备的电池容量和体积设计的困难度也会降低。例如,手机越做越薄,性能还不受影响,就是因为低功耗设计发挥了至关重要的作用。

性能

功耗越大,耗能越多,产生的热量越多,各器件的工作性能就会受到影响。例如,手机使用时间较长时,会感觉手机发热,而且各应用软件也会出现卡顿的现象。

成本

不考虑低功耗设计时,一个功能的实现方法可能较为繁琐,实现的器件增多,产品面积增大;同时,功耗过大时,就要考虑散热装置,这又增加了组装成本。

总之,低功耗设计有很多的优点,也是以后数字设计的发展趋势。

功耗类型

功耗类型一般可分为动态功耗、静态功耗和浪涌功耗。

动态功耗

动态功耗主要包括开关功耗(又称为翻转功耗)和短路功耗(又称为内部功耗)。

1> 开关功耗

在数字 CMOS 电路中,对负载电容进行充放电时消耗的功耗为开关功耗。如下 CMOS 非门:

截图20230301181746.png

当 Vin = 0 时,上面的 PMOS 导通,下面的 NMOS 截止;VDD 对负载电容 Cload 进行充电。充电完成后,Vout 的电平为高。

当 Vin = 1 时,上面的 PMOS 截止,下面的 NMOS 导通,负载电容通过 NMOS 进行放电。放电完成后,Vout 的电平为低。

这样一开一闭的变化,即电源的充放电,就形成了开关功耗。开关功耗的计算公式如下所示:

图片

其中,VDD 为供电电压,Cload 为后级电路等效的负载电容大小,Tr 为输入信号的翻转率。

2>短路功耗

信号的翻转不是在瞬时完成的。因此,在输入信号进行翻转时,PMOS 和 NMOS 总有一段时间是同时导通的,那么从电源 VDD 到地 VSS 之间就有了通路,形成短路电流,产生短路功耗。如下反相器电路图所示:

图片

短路功耗的计算公式如下:

图片

其中,Vdd 为供电电压,Tr 为翻转率,Q 为一次翻转过程中从电源流到地的电荷量。

静态功耗

在 CMOS 电路中,静态功耗主要是漏电流引起的功耗,往往与工艺有关。

图片

漏电流的组成主要为:PN 结反向电流 I1、源极和漏极之间的亚阈值漏电流 I2、栅极漏电流(包括及栅极和漏极之间的感应漏电流 I3)、栅极和衬底之间的隧道漏电流 I4。

一般情况下,漏电流主要是指栅极泄漏电流和亚阈值电流。对于超深亚微米工艺的,隧道漏电流成为主要电流之一。

1>在 PN 结两端加反向电压时,P 区空穴和 N 区电子的运动相反,没有电流通过,二极管处于截止状态,部分能量较大的空穴和电子会挣脱反向电场的束缚而形成微弱的漂移电流。

2> 栅极泄漏功耗:在栅极上加信号后(即栅压),从栅到衬底之间存在电容,因此在栅衬之间就会存在有电流,由此就会存在功耗。

3> 亚阈值电流:使栅极电压低于导通阈值,仍会产生从漏极到源极的泄漏电流。此电流称为亚阈值泄漏电流。在较狭窄的晶体管中,漏极和源极距离较近的情况下会产生亚阈值泄漏电流。晶体管越窄,泄漏电流越大。要降低亚阈值电流,可以使用高阈值的器件,还可以通过衬底偏置增加阈值电压,这些也属于低功耗设计的考虑范畴。

4>隧道漏电流:属于量子力学范畴,感兴趣的同学可自行查阅。

静态功耗的计算公式如下:

图片

浪涌功耗

浪涌功耗是浪涌电流引起的功耗。浪涌电流是指开机或者唤醒时,器件流过的最大电流,因此浪涌电流也称为启动电流。一般情况下,浪涌功耗不是本次所讨论的内容。

功耗模型

library 信息

下面是一种 library 工艺的前几行代码描述,包含功耗有关的参数,具体含义在注释中说明。

library (xxx) {
    /*  library head: xxx */
    technology (cmos) ;
    simulation  : true ;
    nom_process : 1 ;
    nom_temperature : -40;         //默认温度
    nom_voltage : 0.81;            //默认电压
    voltage_map(VDD, 0.81);        //定义lib中多个电压,包括以下几行
    voltage_map(TVDD, 0.81);
    voltage_map(VDDDST, 0.81);
    voltage_map(VDDGR, 0.81);
    voltage_map(VDDSRC, 0.81);
    voltage_map(VSS, 0);
    operating_conditions("ssg0p81vm40c"){    //一种corner定义
        process : 1; /* SSGlobalCorner_LocalMC_MOS_MOSCAP-SSGlobalCorner_LocalMC_RES_BIP_DIO_DISRES */
        temperature : -40;
        voltage : 0.81;
        tree_type : "balanced_tree";
    }
    default_operating_conditions : ssg0p81vm40c ;
    capacitive_load_unit (1,pf) ;      //定义电容单位
    voltage_unit : "1V" ;              //定义电压单位
    current_unit : "1mA" ;             //定义电流单位
    time_unit : "1ns" ;                //定义时间单位
    pulling_resistance_unit : "1kohm"; 
    define_cell_area (pad_drivers,pad_driver_sites) ;
    ……

cell 信息

一个 library 中会有多个基本功能单元,用关键字 cell 声明,也包含了多种的功耗信息。

cell (AN2D0BWP7T40P140) {
    area : 0.392;
    cell_footprint : "an2d1";
    pg_pin (VDD) {                //电源引脚
        pg_type : primary_power;
        voltage_name : VDD;
    }
    ……

    pin(A1) {                     //输入信号引脚
    driver_waveform_fall : "tcbn22ullbwp7t40p140ssg0p81vm40c:fall";
    driver_waveform_rise : "tcbn22ullbwp7t40p140ssg0p81vm40c:rise";
    direction : input;
    related_ground_pin : VSS;     //输入引脚地端
    related_power_pin : VDD;      //输入引脚电压
    capacitance : 0.000418924 ;   //输入引脚电容
    …… 
    }


  pin(Z) {
    direction : output;
    power_down_function : "!VDD + VSS";
    function : "(A1 A2)";
    related_ground_pin : VSS;     //输出引脚地端
    related_power_pin : VDD;      //输出引脚电压
    max_capacitance : 0.04182;    //输出引脚最大电容
    min_capacitance : 0.00013;    //输出引脚最小电容
    ……  
  }

此时,如果再知道翻转率,就可以计算出动态功耗。

翻转率(Toggle rate,Tr),指单位时间内信号(包括时钟、数据等信号)的翻转次数。如下所示,信号在 40ns 时间内跳转了 4 次,则翻转率为 Tr = 4/4ns = 0.1GHz。

图片

内部功耗信息

cell 定义中,内部功耗会有如下定义。

internal_power() { 
    related_pin : "A1" ; 
    related_pg_pin : VDD ; 
    rise_power(power_template_8x8) {   //内部功耗查找表
        index_1("0.0026, 0.0101, 0.0252, 0.0553, 0.1155, 0.236, 0.4769, 0.9587");
        index_2("0.00013, 0.00046, 0.00112, 0.00243, 0.00506, 0.01031, 0.02081, 0.04182");
        values (           "0.000249215, 0.000254481, 0.000262354, 0.000261007, 0.00026381, 0.000277799, 0.000304295, 0.000345046",           "0.000239751, 0.000248667, 0.000255454, 0.0002551, 0.000268563, 0.000275995, 0.000294669, 0.000336529",           ……   
        );
      }


    fall_power(power_template_8x8) { //内部功耗查找表
        index_1("0.0026, 0.0101, 0.0252, 0.0553, 0.1155, 0.236, 0.4769, 0.9587");
        index_2("0.00013, 0.00046, 0.00112, 0.00243, 0.00506, 0.01031, 0.02081, 0.04182");
        values (           "0.000577367, 0.000584652, 0.000589472, 0.000591623, 0.000592223, 0.000591943, 0.00059185, 0.000592132",           "0.000563896, 0.000570743, 0.000576589, 0.000579818, 0.000580794, 0.00057962, 0.000579997, 0.000579136",           "0.000550059, 0.000555794, 0.00056188, 0.000565568, 0.000567663, 0.000567231, 0.000567712, 0.00056745",           ……   
        );
      }
}

cell 的内部功耗与其转换时间和输出电容负载有关。根据输入转换时间和输出电容的大小,在工艺库中进行查表,得到上升功耗和下降功耗,再根据下面公式进行计算,可得到总的内部功耗:

图片

静态功耗信息

cell 定义中,静态功耗(漏电功耗)会有如下定义。

leakage_power () {
    value : 0.059561;
    related_pg_pin : VDD;
  }
  leakage_power () {
    value : 0.048082;
    when : "!A1 !A2 !Z";
    related_pg_pin : VDD;
  }
  leakage_power () {
    value : 0.053318;
    when : "!A1 A2 !Z";
    related_pg_pin : VDD;
  }
  ……

静态功耗跟 cell 的状态有关,也就是输入输出信号在不同的状态下,功耗也会有所差异。通过状态进行查表,就可以得到相应的静态功耗了。

实际分析功耗时,不会手动的去查找相关参数来计算功耗,因为工作量将大到难以估量。往往是借助一些功耗分析工具,提取这些标准单元库的功耗信息进行整合计算。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • CMOS
    +关注

    关注

    58

    文章

    5387

    浏览量

    233893
  • NMOS
    +关注

    关注

    3

    文章

    275

    浏览量

    33877
  • 低功耗
    +关注

    关注

    10

    文章

    2249

    浏览量

    103009
  • PMOS
    +关注

    关注

    4

    文章

    231

    浏览量

    28959
  • 负载电容
    +关注

    关注

    0

    文章

    132

    浏览量

    10322
收藏 人收藏

    评论

    相关推荐

    详解低功耗温度补偿式电桥信号调理器和驱动器电路

    带温度补偿的差分电桥型传感器监控电路是一款适用于电桥型传感器的完整低功耗信号调理器,包括一个温度补偿通道。
    发表于 11-05 03:38 4466次阅读
    <b class='flag-5'>详解</b><b class='flag-5'>低功耗</b>温度补偿式电桥信号调理器和驱动器电路

    详解STM32低功耗模式

    本文讨论下STM32低功耗模式,先看如下手册。
    的头像 发表于 11-08 12:18 1554次阅读

    基于ESP32的低功耗蓝牙触摸键盘

    触摸低功耗蓝牙行业芯事经验分享
    迪文智能屏
    发布于 :2022年04月07日 16:05:53

    超小蓝牙模组,远距离,低功耗#蓝牙芯片 #低功耗蓝牙 #物联网 #硬声创作季

    物联网蓝牙芯片模组低功耗蓝牙
    fly
    发布于 :2022年08月23日 20:52:27

    #硬声创作季 #STM32 手把手教你学STM32-044 待机唤醒实验-低功耗-M4-1

    功耗低功耗
    水管工
    发布于 :2022年10月29日 14:06:05

    #硬声创作季 #STM32 手把手教你学STM32-044 待机唤醒实验-低功耗-M4-2

    功耗低功耗
    水管工
    发布于 :2022年10月29日 14:06:37

    #硬声创作季 #STM32 手把手教你学STM32-044 待机唤醒实验-低功耗-M4-3

    功耗低功耗
    水管工
    发布于 :2022年10月29日 14:07:05

    低功耗蓝牙怎么低功耗?如何界定

    ``什么是低功耗?如何界定* 平均工作电流为 uA 级* 峰值电流不超过 15mA* 采用纽扣电池供电,电池寿命可达数年 在很多低功耗应用场景中,是采用纽扣电池来供电的,采用纽扣电池来供电是低功耗
    发表于 02-06 15:32

    基于STM8S的Atomthreads低功耗详解

    基于STM8S的Atomthreads低功耗的深度思考
    发表于 02-01 06:42

    STM32的低功耗模式

    STM32的低功耗模式1.睡眠模式2.停止模式3.待机模式各种模式的特点这三种低功耗模式层层递进,运行的时钟越来越少和芯片的功能也越来越少,所以功耗越来越低。1.睡眠模式详解进入睡眠的
    发表于 08-11 07:35

    低功耗、远距离传输、性能稳定的无线模块技术详解

    低功耗、远距离传输,性能稳定的无线模块技术详解帮助朋友寻找到自己需要的无线模块类型
    发表于 01-11 16:37 16次下载

    基于MSP430单片机低功耗控制与系统工作模式详解

    基于MSP430单片机低功耗控制与系统工作模式详解
    发表于 10-12 15:29 11次下载
    基于MSP430单片机<b class='flag-5'>低功耗</b>控制与系统工作模式<b class='flag-5'>详解</b>

    还在了解什么是低功耗?FPGA低功耗设计详解

    功耗是各大设计不可绕过的话题,在各大设计中,我们应当追求低功耗。为增进大家对低功耗的认识,本文将对FPGA低功耗设计予以介绍。如果你对FPGA低功耗
    的头像 发表于 10-26 18:51 2715次阅读

    低功耗设计详解(UPF编码篇)

    想必各位ICer们在招聘JD上专门看到低功耗设计经验的要求,什么是低功耗设计呢?对于后端工程 师来讲,在物理实现方面就是引入多条电源线
    的头像 发表于 05-23 16:59 3017次阅读
    <b class='flag-5'>低功耗</b>设计<b class='flag-5'>详解</b>(UPF编码篇)

    一文详解低功耗双运算放大器LM358,超全

    LM358低功耗双运算放大器算是电子元器件中的明星元件,在很多经典电子电路中,都能看到LM358的身影。LM358是由两个独立的高增益电压比较器组成,可在单电源下或双电源下工作,并且其电流大小不受
    的头像 发表于 07-13 17:36 7371次阅读
    一文<b class='flag-5'>详解</b>:<b class='flag-5'>低功耗</b>双运算放大器LM358,超全