Power Gating的设计(模块)

Switching Fabric的设计:

三种架构:P沟道的switch vdd(header switch),N沟道的switch vss(footer switch),两个switch。

但是如果加入两个switch,与门电路结合,可能会产生较大的IR-drop,增大delay,所以这种方式很少用。

P沟道的switch vdd,广泛应用在volatge scaling设计中。

N沟道的switch vss,很少用,有switch的电路,一般都需要level shifter。

但是一般level shifter都是一个共地,两个voltage。

Switch Fabric的控制:

主要考虑是为了减少in-rush current,voltage spike。

两种方法:

1)对switch的菊花链的控制信号(daisy-chain),control signal连接到第一级的switch,

进行buffer之后,在传递给到第二级的switch。

需要引入ack信号,来保证有效的power up。

2)对control signal进行分级,第一级开启一个weak/trickle的switch,

第二级开启main switch,

switch signal必须在always on的power内,会增加power routing的复杂性。

而且在DFT设计中,必须保证Power Gating signal是可控的。

Signal isolation的必要性:

1)保证power down的region不会对power up的region的input端口产生弧电流,

2)保证power down region的浮空输出不会对power up的region产生影响,

Isolation的cell,一般采用AND门电路或OR门电路进行,但这样会引入门电路的延时。

lib中的cell一般会针对leakage和timing,对这样的门电路进行优化。

还有一种方式是直接通过isolation信号将output钳位在某一电平。

但是这样会引起multi-drive的问题,isolation必须在掉电之后才能有效,无法实现。而且DFT的设计也很困难。

这样做的好处是节省area,而且timing较好。

目前的isolation cell一般都加在output端,对于reuse-ip,可以直接在内部包含isolation cell。

为了避免不必要的leakage 泄漏(sneak path),一般对于header-switched design,选择高电平的isolation控制信号,

低电平的reset有效信号和clamp到"0"。

提供retention操作的几种方式:

1)软件的方式读写register;

2)利用scan-chain的方式,将信息存储起来;

3)使用retention的register。

第一种方式,要求软件工程师了解很多的硬件操作,不介绍。后俩种对系统几乎透明,主要介绍。

使用scan-chain的方式:

1)由于scan-chain的数目和长度都是在综合过后,才能确定的,而Power Gating在前端必须验证;

2)从数据位宽角度,scan-chain的数目必须和存储器的位宽一致;

3)由于scan-enable的信号是由所有的chain共享的,所以需要做balance;所有的san-chain等长;

4)在scan操作过程中,信号toggle的频率比正常工作大很多,DFT工具会分析IR-drop,并调整,但是retention中需注意;

retention的register:由一个regular的register和一个shadow register组成,shadow register是always power on的。

有的由两个信号save,restore组成,有的只有一个retention信号。

save操作多在clock已经关掉,但是power还在的情况下有效,restore在power有效,clock还没开始的情况下有效。

相较于一般的register,带retention功能的,面积增加20%左右,而且shadow register多采用highVt的cell

来避免leakage过大,但是对于reset和clock tree一般选择lowVt的cell来保证timing。

partial retention:保留shallow state(control register),复位deep state(register contain large amount data);

在power up之后,电路中不会有X存在即传递,这样需要分别的reset信号来控制retention和non-retention部分。

在进行DFT测试时,需要保证可以force retention的寄存器,来检查save和restore都是deassert。

同样可以去除这个force,来检查save和restore可以assert。

Power Gating Controller:

有一个handshake来保证power down和power up的完备性。

由switch产生的ack信号,多是异步的,power controller需要做sync处理。

时间: 2024-10-11 00:58:10

Power Gating的设计(模块)的相关文章

Power Gating的设计(模块二)

针对lower power的验证,由cpf/upf来建模,包括: 1)power gating的功能模型(在power gate之后将output force为零) 2)isolation功能模型: 3)save和restore的功能模型: 4)power gating/retention/reset的sequence功能模型: Power Gating对DFT设计的要求: 1)test power switching network的行为正确: 2)test shutdown,isolatio

Power Gating的设计(概述)

Leakage power随着CMOS电路工艺进程,功耗越来越大. Power Domain的开关一般通过硬件中的timer和系统层次的功耗管理软件来进行控制,需要在一下几方面做trade-off: 1)可能节省的leakage power, 2)entry和exit的power和time消耗, 3)Power sleep和active的频率, power gating可以完全关掉dynamic的power消耗,但是leakage只会减少,不会消失,因为power gating技术仍需要加入一些

Multi-voltage和power gating的实现

power domain:一个逻辑的集合体,包含power supply的一些信息.建立在FE. voltage area:chip上的一块物理区域.可以看作power domain的物理实现. Level shift,isolate cell,retention register的插入,越早越好,这样他们对timing和physical design的 影响,能更早的可见,CTS和DFT应该是对power已知的. Power Intent描述设计中的power domain,level shi

Java-单机版的书店管理系统(练习设计模块和思想_系列 四(2) )

说明: 本博客为补全上篇-Java-单机版的书店管理系统(练习设计模块和思想_系列 四(1) )的,所以如果不懂,请先看上一篇. 本系列都是我一步一步学习来的, 所以,可能比较适合初学设计模块的人来学. 现在补全我目前写的所以代码: 公共类: 用户类型枚举:UserTypeEnum类 package cn.hncu.bookStore.common; /** * 功能:用户类型的枚举!<br/> * 定义在公共模块.<br/> * 变量:<br/> * ADMIN(1,

ZYNQ原理图中添加RTL设计模块

前言 已有的RTL模块怎么添加到原理图中? 流程 (1)添加文件到设计中. (2)右键文件添加到block design中. (3)连线即可. 以上. 原文地址:https://www.cnblogs.com/kingstacker/p/10768138.html

python网络设计模块

1.Socket模块 Socket模块中的socket()方法用于创建套接字,套接字主要是两个程序之间的信息通道,程序可能分布在不同的计算机上,通过套接字相互发送信息 语法格式:socket(socket_family,socket_type,protocol = 0) socket_family    该参数的值可以为AF_UNIX或AF_INET socket_type   该参数的值可以为SOCK_STREAM或SOCK_DGRAM protocol   该参数一般不赋值,默认值为0 2)

单片机中17种常见常用的设计模块

以下分享17种单片机常用电路设计模块,包括:双路232通信电路3线连接方式,三极管串口通信,单路232通信电路,USB转232电路等. 1.双路232通信电路3线连接方式,对应的是母头,工作电压5V,可以使用MAX202或MAX232. 2.三极管串口通信 本电路是用三极管搭的,电路简单,成本低,但是问题,一般在低波特率下是非常好的. 3.单路232通信电路 三线方式,与上面的三级管搭的完全等效. 4.USB转232电路 采用的是PL2303HX,价格便宜,稳定性还不错. 5.SP706S复位电

自研模块加载器(三) module模块构造器设计-模块数据初始化

依赖加载策略 模块数据初始化 status状态生命周期 代码展示 demo包括4个文件, index.html , a.js , b.js , startUp.js index.html <!DOCTYPE html> <html> <head> <title>自研模块加载器</title> </head> <body> <script src="./startUp.js"></scr

模块设计与实现经验总结(三)

3  模块详细设计指南与规范 模块详细设计要完成两个方面工作:一是明确模块的功能需求和非功能需求.二是设计如何完成和实现模块的功能需求,包括类结构.线程结构设计等.本节根据后台模块特点,描述了两部分工作需要考虑和设计的关键点. 3.1确定模块的功能规格 1) 本模块概述 概述主要描述了本模块所属子系统,以及在子系统中所承当职责的简单描述. 2) 本模块在系统中与周围模块关系和交互情况 很多模块一般要依赖周围的模块或者数据库,为此建议以图形方式描述本模块与本模块依赖的其他模块或者数据库之间交互情况