instGroup/constraint/Gcell/busguide/netgroup/Bump
1.
instGroup
Instance group。中文名例化单元组。Instance group可以用来group一些instances, 在做placement时,如果你希望一些instance可以尽量摆放在一起,可以创建一个instance group,并且把这些instance都添加到这个group中。如下图所示:


instance group本身并不会改变netlist. 但是我们可以通过runRcNetlistRestruct来改变netlist的层次结构本身,使它成为一个module。
使用方法:
createInstGroup
addInstToInstGroup
createInstGroup group1 -fence {300 300 600 600}
addInstToInstGroup group1 instA
2.
constraint
并不是timing里面的sdc文件,而是Floorplan中的module约束作用。
主要分为四种:按照约束由强到弱,可以分为是Fence,Region,Guide,SoftGuide
Fence(限制约束):强约束,“不可进不可出”的约束,属于该模块的单元只能放置在该区域内,且不允许放置其他单元
Region(区域约束):“可进不可出”的约束,属于该模块的单元只能放置在指定区域内,该区域内还可以放置其他单元
Guide(向导约束):为模块指定向导范围,“可进可出”的约束,属于该模块的单元可以放置在该向导范围内,也可以放置在该向导范围之外,不属于该模块的单元也可以放置在该向导范围内。
SoftGuide(软向导约束):上面三种约束大家一定很熟悉吧,其实Encounter还隐藏了一种约束。softGuide. 它和Guide约束较相似,区别只是在于没有具体的location. 在softGuide中的std cell. place时会尽量摆近一点
使用方法:
createFence, createRegion, createGuide, createSoftGuide
3.G cell
G cell,全称global routing cells。 同样的它也是我们定义的一种grid, G cell grid对routing过程中起着相当重要的作用。
我们知道绕线过程可分为global route(全局绕线)和detail route(详细绕线)。globalroute以gcell cell作为绕线参考网格,工具在绕线时会试图寻找gcell中的最短path, gcell还有很大的一个用处是产生congestion map(拥堵图表)。
我们可以在DEF或者floorplan文件中看到GCell Grid的定义.
[GCELLGRID
{X start DO numColumns+1 STEP space}...
{Y startDO numRows+1 STEP space ;} ...]
X Y 分别代表水平和垂直方向
start 代表第一根grid的位置
DO numColumns+1,DO numRows+1 代表grid横竖的数量
STEP space 代表grid之间的间距

产生的grid效果如下图所示:

那么gcell是如何对guide global routing的呢?通常一个gcell中会占有10几个track(根据design的不同有所变化),global routing的目标是使得每个gcell的容量占有率在85%左右。
当gell中的track需求量高于容量时,该处地方的route就会产生congestion(拥塞)的问题。通过global route的report我们可以清楚地看见每层layer上的congestion描述:

也可以产生 congestion map,在GUI上更形象地看到设计中出现拥塞的地方。颜色的定义方式如下图所示:

产生congestiong map以后,在图形界面上可以看到:

3.
busGuide
constraint,它可以guide bus net的走线。如图所示:粉红色部分形成bus guide后,在这个bus guide中,Inst A和Inst B的bus net必须按照粉红色的走线方式走线。

Bus Guide可以有效地降低design中routing resource. 如下图所示,没有bus guide时,两个hard macro之间的bus net走线非常乱,极大地浪费了走线空间;相反,当两者之间添加bus guide以后,相关的bus net都在对应的channel里走线,合理地利用了空间。

使用方法
createBusGuide
BusGuide与net group相关联。因此,创建Bus Guide前,我们首先需要创建对应的net group
<CMD> createNetGroup test-spacing 2
<CMD> addNetToNetGroup test –net {mc[0] mc[1] mc[2] mc[3]}
<CMD> createBusGuide -netGroup test -layer {1:4} -rect {464 1240 528 1260}

这里需要指出的是,所画的Bus Guide必须要把两端的instance bus pin给完全覆盖住,这样,bus guide才会有效果

4.
Net Group。
这也是一种net或者pin的约束,经常与bus guide或者pin guide关联使用,它可以将几条net,或者bus net加到一个group中,然后与bus guide或者pin guide关联。这样,做pin assign或者 bus routing时,net group中的net具有较高的权重,会尽可能地走在一起。
使用方法
createNetGroup
addNetToNetGroup
createNetGroup bundle1
addNetToNetGroup bundle1 -net cpua[2:10]
创建net group bundle1,将bus net cpua[2:10]加到net group bundle1中

6.Bump
这是用于FlipChip技术的一种object,可以理解为“焊球”。用于倒置过来扣在封装板上的焊球。如下图所示


Bump通过RDL routing(Redistributed layer,通常是铝层)连接着IO pad cell。


通常bump是呈正六边形的,但这不是必须的,我们也可以定义rectangle的形状。我们在LEF中定义bump属性,记住的是它的class是coverbump
MACRO BUMPCELL
CLASS COVERBUMP ;
ORIGIN 0 0 ;
SIZE60.0 BY 60.0 ;
SYMMETRY X Y ;
PIN PAD
DIRECTION INPUT ;
USE SIGNAL ;
PORT
LAYER M9 ;
POLYGON 17.25 0.0 42.75 0.0 60.0 17.25 60.0 42.75 42.75 60.0 17.25 60.0 0.0 42.75 0.017.25 ;
END
END PAD
OBS
LAYER via89 ;
POLYGON 17.25 0.0 42.75 0.0 60.0 17.2560.0 42.75 42.75 60.0 17.25 60.0 0.0 42.75 0.0 17.25;
END
END BUMPCELL
使用方法
create_bump_array
create_bump_array -lib_cell BUMP -delta {140 140} \
-bbox {{410 450} {1175 3278}} -name left
create_bump_array -lib_cell BUMP -delta {140 140} \
-bbox {{2620 450} {3325 3278}} -name right
create_bump_array -lib_cell BUMP -delta {140 140} \
-bbox {{1100 450} {2650 1125}} -name bottom
create_bump_array -lib_cell BUMP -delta {140 140} \
-bbox {{1100 2555} {2650 3250}} -name top
create_bump_array -bbox {{1100 1150} {2650 2550}} \
-pattern staggered_1 -lib_cell {BUMP} -delta {140 140} -name pg_bump

instGroup/constraint/Gcell/busguide/netgroup/Bump的更多相关文章
- 异常:java.lang.LinkageError: loader constraint violation: when resolving interface method
异常:java.lang.LinkageError: loader constraint violation: when resolving interface method "javax. ...
- Constraint6:更新外键约束(Foreign Key Constraint)的引用列
在SQL Server中,表之间存在引用关系,引用关系通过创建外键约束(Foreign Key Constraint)实现.如果一个Table中的column被其他Table引用,那么该表是参考表,或 ...
- Constraint2:constraint
一,Constraint 是表定义的一部分,用于实现数据完整性. Data Integrity 由三种类型的constraint实现: Entity Integrity:数据是唯一的.约束: prim ...
- MySQL主从复制中断,报“Error on master: message (format)='Cannot delete or update a parent row: a foreign key constraint fails' error code=1217” 错误
前几天,发现从库挂了,具体报错信息如下: 分析思路 1. 因为我采用的是选择性复制,只针对以下几个库进行复制: card,upay,deal,monitor,collect.所以,不太可能出现对于sa ...
- SQL SERVER 2005删除维护作业报错:The DELETE statement conflicted with the REFERENCE constraint "FK_subplan_job_id"
案例环境: 数据库版本: Microsoft SQL Server 2005 (Microsoft SQL Server 2005 - 9.00.5000.00 (X64) ) 案例介绍: 对一个数据 ...
- ORA-02292: integrity constraint (xxxx) violated - child record found
在更新表的主键字段或DELETE数据时,如果遇到ORA-02292: integrity constraint (xxxx) violated - child record found 这个是因为主外 ...
- Oracle约束(Constraint)详解
概述 约束是数据库用来确保数据满足业务规则的手段,不过在真正的企业开发中,除了主键约束这类具有强需求的约束,像外键约束,检查约束更多时候仅仅出现在数据库设计阶段,真实环境却很少应用,更多是放到程序逻辑 ...
- ZK textbox Constraint验证
test.zul: <?page title="" contentType="text/html;charset=UTF-8"?> <zk x ...
- 修复Magento SQLSTATE[23000]: Integrity constraint
magneto在意外情况下报错Magento SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry,出现这个问题最 ...
随机推荐
- Oracle 中关于 Group By 子句与多行函数嵌套搭配使用的注意事项
目录 你需要知道的 啥叫单行函数 啥叫多行函数 如何理解这个概念 Group by 子句使用规则 看一道 071 考题 你需要知道的 提到 Group by 子句,你需要先理解一个东西:函数的分类.提 ...
- 牛客CSP-S提高组赛前集训营3 赛后总结
货物收集 二分答案.复杂度\(O(n\log n)\). 货物分组 用费用提前计算的思想,考虑用一个新的箱子来装货物会发生什么. 显然费用会加上后面的所有货物的总重. \(60\)分的\(O(n^2) ...
- K3/Cloud 执行计划任务错误排查
计划任务的不执行原因可能有: 1.K3CloudJobProcess服务处于停止状态. 2.数据中心未勾选“允许执行计划任务”. 这种情况此数据中心下的所有计划任务都不会执行到. 3.第一次加进计划任 ...
- [CF269B] Greenhouse Effect - dp
给出 N 个植物,每个植物都属于一个品种,共计 m 个品种,分落在不同的位置上(在一个数轴上,而且数轴是无限长度的),保证读入的位置是按照升序读入的. 现在我们可以进行一个操作:取任意一个位置上的植物 ...
- js获取URL里的参数
第一种 通过正则获取URL中指定的参数 /** * 获取指定的URL参数值 * URL:http://www.xxx.com/index?name=123 * 参数:param URL参数 * 调用方 ...
- vue formatter element表格处理数据
formatter 指定一个vue methods 方法 作用:对从数据库中取出的数据进行处理后展示. <el-table-column prop="partner1" // ...
- 安卓开发中遇到java.net.SocketException: Permission denied
仅需在AndroidManifest.xml添加 <uses-permission android:name="android.permission.INTERNET" /& ...
- Docker学习笔记三
4.Docker数据管理 4.1.数据卷 数据卷是一个可供容器使用的特殊目录,它将主机操作系统目录直接映射进容器,类似与Linux的mount行为. 特性: 数据卷可以在容器之间共事和重用,容器间传递 ...
- ECMAScript基本语法——④变量
简介 变量:一小块存储数据的内存空间先申请了一块内存空间,规定空间的存储类型,给空间赋值3, 想找到这个3可以通过内存空间的地址值,但是通过地址值太麻烦了,给这个空间起了一个名字a 通过这个a可以找到 ...
- 详解C/C++中的的:#pragma pack(push) 、#pragma pack(pop) 和#pragma pack()
前言 我们知道结构体内存对齐字节可以通过#pragma pack(n) 的方式来指定. 但是,有没有想过一个问题,某些时候我想4字节对齐,有些时候我又想1字节或者8字节对齐,那么怎么解决这个问题呢? ...