CPF文件可以有两种组织方式:Flat CPF file or Hierarchical CPF file。

由于在大型的SoC设计中,一般都采用Hierarchical的形式,所以本文主要按这个方式来讲。

Hierarchical CPF file:一般定义多个CPF file,通过include来组织起来,

可以分为Top_file:定义一个CPF_MODE变量来选择各个子CPF file,从而适用在FE-BE的flow中。

xxx_domain.cpf:定义各个power domain,如pad,analog,SOC,CPU等。

xxx_mode.cpf:定义各种用到的nominal_condition + mode,来定义各个mode。

xxx_power.cpf:定义power and ground nets

xxx_rule.cpf:定义level_shifter,isolate_cells,state_retention_cells,power_switch_cells等,可以再细分各个block的rule。

xxx_macro.cpf:定义一些macro来建模,如analog, CPU,MEM等。

CPF的顶层一般规定:

set_cpf_version 2.0

set_hierarchy_separator /(default .)

set_register_naming_style  "_reg%s"   (netlist与RTL的FF或latches对应,a-->a_reg)

set_array_naming_style "_%d"   (netlist与RTL的FF或latches对应,[3:2]b--->b_reg_2, b_reg_3)

set_power_unit [mw] (default mw)

set_time_unit ns (default ns)

set_design xxx

end_design

set_macro_model   xxx

end_macro_model  xxx

set_power_target -leakage xx -dynamic xxx

Library-related definitions:一般都用define_xxx commands

Design_related definitions:一般都用create_xxx commands

Implementation-related definitions:一般采用updated_xxx commands

hierarchy的设计中,top和sys的cpf是分别写的,在top上通过set_instance来将sys上的power domain映射到top上。

set_instance  proj_top/u_sys_1\

-domain_mapping { {domain_in_sys1 domain_in_top1} {domain_in_sys2 domain_in_top2} {domain_in_sys3 domain_in_top3}}

include ./u_sys_1.cpf

create_power_nets -nets net_name -voltage 1.5 -internal/-external_shutoff_condition{}

-internal表示该power net是内部经过power switch的secondary power

-external_shutoff_condition表示该net是外部power switch的secondary power

都不加表示该net是内部power switch之前的primary power

create_ground_nets -nets VSS

create_power_domain -name PD_name1  -default/-shutoff_condition/external_controlled_shutoff/base_domains

-default表示没有定义到的其他的port/pin都属于该domain

-shutoff_condition表示power switch动作的条件

-external_controlled_shutoff表示该power domain是由外部的power switch控制的

-base_domains表示在该module为该domain中提供primary power的domain

-boundary_ports表示该domain中包含的一些pin

update_power_domain -name PD_name  -primary_power_net VDD_name  -primary_groud_net VSS_name

-name中的PD_name必须与create语句中的name一致

-primary_power_net表示该domain中的输入power,经过top的power switch之后的power

该net的名字必须与create_power_net中的名字相同

-primary_ground_net表示该domain中的gnd

-equivalent_power_nets {}如果该domain中在physical实现中有多个区域,power不同时,指定。

像很多phy中的power和controller和IO的power就是这种情况。

create_isolation_rule  -name iso_name  -pins "$iso_low_list" -isolation_condition ""  -isolation_output low/high

其中的变量$iso_low_list可以事先定义。

set iso_low_list/iso_high_list   "...."(使用tcl命令,为了在create iso时方便)

针对两个交互domain的约束:

create_isolation_rule  -name iso_name  -from PD_domain1  -to {PD_domain2 }  -exclude/-pins "" -isolation_condition ""  -isolation_output low/high

-from指定起始的power domain

-to指定去的domain,可以是多个

-exclude除去之后的pin,其余都是clamp到low/high

-pin指定clamp的pin

-isolation_condition指定进行iso的条件

-isolation_output指定输出的clamp的值

create_nominal_condition -name vdd_name -voltage

create_power_mode -name PD_mode_name -domain_conditions {power_domain@nominal1 power_domain@nominal2}

-default用来指定一个default的power mode

两个规则用来创建power mode,指定power domain和对应的nominal。

create_power_switch_rule  -name PSW_name -domain PD_name -external_power_net VDD_name

-domain来用指定PSW输出的secondary power去向的power domain

-external_power_net只用在header类型的PSW中。

-external_groud_net只用在footer类型的PSW中。

update_power_switch_rule  -name PSW_name  -enable_condition_1 net1  -enable_condition_2 net2

-acknowledge_receiver_1 net1  -acknowledge_receiver_2 net2

-name与create中创建的power switch的名字相同。

-enable_condition_1/2 PSW的enable信号,两级表示一个weak/一个strong,分两级开启

-acknowledge_condition_1/2 PSW的反馈信号。

针对lower power的一些library cell的定义:

define_isolation_cell  -cells {}  -power  VDD_name -ground  VSS_name -enable pin -valid_location from/to/off

-power_switchable  net 只有在使用header类型的PSW时,指定那个可以switch的power

-power  net 总是有电的power

-ground  net  总是有电的ground

-valid_location to表示只在输出口进行iso,from表示总是在input口进行iso,off表示总是在power off的那个口进行iso

define_level_shifter_cell  -cells  {}  -input_voltage_range num1:num2 -output_voltage_range num1:num2 -direction down/up

-input_power_pin pin_num  -output_power_pin  pin_num -input_ground_pin  pin_num -output_ground_pin  pin_num

-enable  pin_name -valid_location to/from

-valid_location:to指定输出的信号进行level_shifter(default) from指定输入的信号进行level_shifter,either表示都可以

-enable pin_name:只有在该cell具有iso的功能时才有用

-direction down表示只能高电平到低电平,up表示只能低电平到高电平

-input_voltage_range 表示voltage的范围

define_always_on_cell  -cells {} -power_switchable VDD_name -power VDDR -ground VSS_name

-power_switchable表示可以switch的power

-power表示实电

-ground表示虚电

define_power_switch_cell  -cells {} -stage_1_enable  net_name  -stage_1_output  net_name

-stage_2_enable  net_name  -stage_2_output  net_name

-type header/footer -power_switchable VDD_name -power VDD

-type_1_enable:表示PSW的enable信号,一般分为两级

-type_1_output:表示经过buf/inv之后,输出到下一级PSW的信号。

-type:PSW的结构header/footer

转载于:https://www.cnblogs.com/-9-8/p/4409701.html

Lower Power with CPF(二)相关推荐

  1. Lower Power with CPF(四)

    CPF从Front-end到Back-end(RTL--GDSII)的整个流程: 1)Creating a CPF file:来在前端就建立lower power的规范. 2)检查CPF文件的正确性, ...

  2. Lower Power with CPF(三)

    常用的一些Lower Power的策略: 1)Clock tree optimization and clock gating:在正常情况下clock信号会一直toggle at the maximu ...

  3. Lower Power with CPF(一)

    CPF(Common Power Format):cadence推出的一种在设计中描述低功耗设计的文件.完全按Tcl的语言格式来定义. CPF文件在整个前端后端的过程中,需要的部分不一样,所以CPF文 ...

  4. Power BI(二十四)power pivot之产品/客户分类分析(ABC分析)

    Power BI(二十四)power pivot之产品/客户分类分析(ABC分析) 之前我们介绍过帕累托分析,现在我们使用power pivot进行产品/客户分类分析(ABC分析) 我们就以产品ABC ...

  5. Power BI(二十)power pivot之Earlier函数 - DAX进阶的里程碑

    Power BI(二十)power pivot之Earlier函数 - DAX进阶的里程碑 Earlier函数之累计求和.累计百分比 帕累托法则往往称为二八原理,即百分之八十的问题是百分之二十的原因所 ...

  6. Power BI(二十三)power pivot之使用多对多关系

    Power BI(二十三)power pivot之使用多对多关系 我们想统计图书分类对应的销售数量 原始数据:两张表(销售记录和图书分类) 为了解决多对多关系,我们创建一个辅助表,使之变为多对一.一对 ...

  7. Power BI(二十一)power pivot之筛选上下文和行上下文

    Power BI(二十一)power pivot之筛选上下文和行上下文 其实上下文概念并不深奥,但是对于习惯使用Excel计算函数的亲们来说在学习这块知识时感觉会比较别扭,这主要是因为在Excel中, ...

  8. Power BI(二十七)power pivot之排名分析

    Power BI(二十七)power pivot之排名分析 按照销售金额排名 新建度量值 销售总额:=SUM([金额]) 排名1:=RANKX('产品分类','销售记录'[销售总额]) 排名2:=RA ...

  9. 详解MySQL字符串函数CONCAT()、CONCAT_WS()、INSERT()、REPLACE()、LOWER()、UPPER()用法(二)

    文章目录 一.合并字符串函数CONCAT()和CONCAT_WS() 1.CONCAT() 2.CONCAT_WS() 二.替换字符串INSERT()和REPLACE 1.INSERT() 2.REP ...

最新文章

  1. apache +mod_jk URL中文乱码
  2. n元n次方程求解c 语言,解n元一次方程
  3. 看不见的战斗——阿里云护航世界杯直播容灾实践
  4. Moss/Sharepoint 为特定用户组设置特定视图以及可见视图,自定义列表新建页,修改页和显示页(无代码法)...
  5. java x1价格_java I/O总结
  6. 算数or算卦,和业务人谈“预测”到底在谈啥?
  7. 双系统重装Ubuntu经验分享
  8. Java实战项目,附带源码+视频教程。
  9. 阿里面试官最新分享的Java面试宝典,含8大核心内容讲解
  10. Spark入门程序(idea,scala)
  11. APISpace 银行卡二要素API
  12. 骁龙435/MSM8940处理器详细规格(补充说明)
  13. 芯片程序保护-常规芯片加密方式
  14. 达文教育2022年John Locke主题讲座再度来袭
  15. python中用turtle画爱心表白
  16. Android 使用ADB命令向上滑动解锁
  17. 智能计算数学基础——分类问题
  18. 时间序列分析(1)-移动平均法
  19. 发布产品并了解用户行为(1)
  20. Fly.Box 2.0.2 企业网盘,企业云盘解决方案

热门文章

  1. 行列式相关定理《线性代数》学习笔记)
  2. 买股票的最佳时机--dp问题
  3. 怎么用计算机打出逆战,逆战手游怎么在电脑上玩 逆战手游电脑版安装教程
  4. 无人值守,智能变电站可视化管控系统
  5. 百度电商“另谋出路”
  6. 提高matlab图片质量,由Matlab输出高质量论文图片方法
  7. GJK算法求凸多边形之间的距离
  8. 开通微信支付,银行账户和主体名称不一致时,如果处理
  9. 找不到gpedit.msc 的解决方法
  10. Service id not legal hostname (pin_user)