dbGet是Innovus/Encounter DBTCL命令的一种。除了dbGet,DBTCL的命令还包括以下几种:

1. dbSet

2. setDbGetMode/getDbGetMode

3. dbSchema

4. dbTransform

5. dbQuery

这其中,最常用的就是dbGetdbSchema

当我们在Innovus中敲击dbGet以后,然后按<Tab>键,出现的是下面3个初始的object.

[DEV]innovus 2> dbGet

head  selected  top

其实,dbGet是基于一种树状的结构图,如下图所示。head是最原始的parent,然后我们需要寻找的object就藏在这每一个一级一级的分支下。selected和top其实也属于head的一个分支,只不过它们比较常用,所以就单独列出作为一个原始分支。我数了下,现在各种object一共加起来有64个,我们需要做的就是找准路线,一击必中,把“指针”找出来。

我们首先来看最简单的selected分支,当你选中一个object,然后敲击下面命令:

[DEV]innovus 4> dbGet selected

0x2b3753cae120

ox开头的是选中objectt的指针 不是乱码

如果你没选中任何东西,敲击这个命令:

[DEV]innovus 5> dbGet selected

0x0

这个0x0代表返回0,也就是工具找不到结果

那如何知道选中的这个object有什么属性呢?Innovus/Encounter中通过"."来trace下一级。敲上“.”以后,按<Tab>键

[DEV]innovus 6> dbGet selected.

(太长了,我不一一列出来了)

或者使用下面“.”加一个问号,这两者应该是相同功能,但前者排列的更清楚

[DEV]innovus 7> dbGet selected.?

大家可以看到,选中的object下面有很多属性可以得到,每个属性下面又有很多子属性。比如,我们想知道选中的object的名字,可以使用下面命令

[DEV]innovus 8> dbGet selected.name

SUB_Sh4Lmi_PH/f4h22Tc3000a_0

如果我们想知道一次每个属性的值,可以使用下面命令:两个问号

[DEV]innovus 9> dbGet selected.??

它会把这个object下面的所有属性值都列出来,但有时候你可能不知道一些属性值代表的意思,比如说box_sizex和box_llx有什么区别呢?我们的Innovus/Encounter提供了解释这些属性的功能,敲击下面命令:问号后面跟一个h

[DEV]innovus 11> dbGet selected.?h

当然dbGet也支持同时对多个object操作

[DEV]innovus 12> dbGet selected.

0x2b37527dd230 0x2b37575c02d0 0x2b3753cae120

那我们如何trace到当前object的下层属性呢?

其实很简单,只要敲“.”加上它的下一层属性即可

[DEV]innovus 14> dbGet selected.cell.name

sf230 sf240 f4h22Tc

那selected是最简单的属性,适合刚开始使用dbGet的新人学习,它的不方便之处在于你必须去选中这个object。而我们很多时候用dbGet,是为了搜索某样东西,我们并不知道怎么去选中它。这时候你就要用到另外两个object——tophead

 

top指的是当前design中object

head指的是整个design database中的object

这两个object很好地展现了树状结构的描绘。我们来看一个最简单的例子:

[DEV]innovus 15> dbGet top.insts.cell.name

AND2 OR2 INV1 AND2 …

上诉dbGet命令会返回design中所有cell的name。其中,

top代表top cell的指针

insts代表top cell下面所有insts的指针

cell代表每个inst对应的master cell的指针

name代表master cell的名字

那前面提到的如何在design中去搜索某个object呢?在后面跟你想要的cell名字就行,简单吧,经常用来过滤筛选结果

[DEV]innovus 16> dbget top.insts.cell.name BFHVTX4

BFHVTX4 BFHVTX4 BFHVTX4...

最基本的用法就是如此,一级一级trace下去,关键的难点在于熟悉理解64个object属性的意思.

dbGet的用法就像Tcl一样,是很灵活多变的,体现在它这个命令本身具有很多option

dbGet 
[-p num ] 
[-u] 
[-regexp] 
[-d] 
{ obj | objList | head | top | selected} 
[. objType ]…[. attrName | .? | .?? | .?h]   
[ pattern ] 
[expression] 
[-v] 
[-e] 
[-i] 

-p是我们经常用到的option。p指point,有时我们使用dbGet筛选得到我们所想要的结果。但更多时候,这些结果会被用来做另一个层级的dbGet指令。这时候就要用到-p,来返回指针。

[DEV]innovus 42> dbget top.insts.cell.name BFHVTX4 -p

0x2afa58513390

-p还可以跟不同的数字-p2,-p3...分别代表着倒数多少个object的属性。

如下图所示,该命令返回了design中所有在M1上的insts pin layer。

如果用-p, 返回的就是所有M3 layer的指针:

[DEV]innovus 56> dbGet -p top.insts.instTerms.layer.name M3

0x2afa583dc000 0x2afa583dc000 ...

-p2的话,返回的就是所有在M3上的insts pin的指针;

[DEV]innovus 57> dbGet -p2 top.nets.instTerms.layer.name M3

0x2afacc5fa118 0x2afacc48ee38 ...

-p3的话,返回的就是所有在M3上的insts pin上接的insts的指针;

[DEV]innovus 58> dbGet -p3 top.nets.instTerms.layer.name M3

0x2afacc3e6be8 0x2afacc3e6be8...

如果我们想要知道所有在M3上的insts pin的名字:

[DEV]innovus 59> dbGet [dbGet -p2 top.insts.instTerms.layer.name M3].name

SUB_PH/buf_input_datax2x/A REPEATER_datax2x/Z...

 

-u

这个option比较简单,就是对结果进行排序,只取不重复的值,比如:

[DEV]innovus 60> dbGet top.nets.instTerms.layer.name M1

M1 M1 M1 M1 M1 M1...

[DEV]innovus 60> dbGet top.nets.instTerms.layer.name M1 -u

M1

-regexp

dbGet也支持正则表达式匹配,类似tcl那样,

比如:找到design中所有以d结尾的net名字

[DEV]innovus 65> dbGet -regexp top.nets.name {d$} 

SUB_Sh/output_crypto_sh4_valid SUB_PH/inst_0/clk_gated

找到design中所有以数字结尾的net名字

[DEV]innovus 65> dbGet -regexp top.nets.name {\d$}

FE_OFN166_tst_all_92 FE_OFN155_bscnet_192

-d

dbGet的结果采用db的单位,而不是我们正常的location单位。这个option没什么大用,大概是用来和DEF文件单位匹配吧

[DEV]innovus 67> dbGet top.nets.box

{5409.615 8429.245 5409.615 8429.245}

[DEV]innovus 68> dbGet top.nets.box -d

{5409615 8429245 5409615 8429245}

pattern

dbGet支持通配符的匹配,这会非常方便。比如说我们想在design中寻找中间有clk字样的net,采用如下命令:

[DEV]innovus 69> dbget top.nets.name *clk*

FE_OFN5372_rng_clk_mon FE_OFN49_pad_muclk_en...

expression

我们也可以通过判断条件来筛选结果,使用{条件}

比如:找到design library中所有input < 10, PGTerm > 2的cell

[DEV]innovus 85> dbGet [dbGet head.allCells {.numInputs < 10 && .numPGTerms > 2 }].name

BD4_2V5_LIN BD2S_2V5_STAG BD2S_2V5_LIN

-v 取反

v就是大家常见的取反

[DEV]innovus 85>dbGet top.nets.instTerms.layer.name M1 -v

M2 M3 M4...

-e

这个option就是当design中找不到结果时,返回空字符,而不是0x0

[DEV]innovus 90> dbGet top.nets.instTerms.layer.name M9 -e

[DEV]innovus 91> dbGet top.nets.instTerms.layer.name M9

0x0

-i num

这个option可以只列出第num个结果,第一个结果以0开头
[DEV]innovus 97> dbGet [dbGet head.allCells {.numInputs < 10 && .numPGTerms > 2 }].name

BD4_2V5_LIN BD2S_2V5_STAG BD2S_2V5_LIN

[DEV]innovus 97> dbGet [dbGet head.allCells {.numInputs < 10 && .numPGTerms > 2 }].name -i 0

BD4_2V5_LIN


dbGet的更多相关文章

  1. dbGet (二)

    dbGet是由它基本的语法加上各种object的attribute的组合构成的.大家在熟悉基本语法之后,就应该去学习各个object的attribute了.说实话,这很难,因为attribute很多, ...

  2. dbGet net trace instant pin

    proc rn { net_name } {puts " "puts "Net name : $net_name : "set name_rule [dbget ...

  3. dbGet(三)

    inst flat design下的instance Parent Object group, hInst, instTerm, io, pBlkg, ptn, rBlkg, sdp, topCell ...

  4. dbGet(二.一)hinst

    hinst hierarchical insts Parent Object bndry,group,hInstTerm,hTerm, inst,ptn,topCell,vCell Child Obj ...

  5. Asterisk manager API(AMI)文档(中文版)

    Asterisk控制接口(AMI)允许管理客户端程序连接到一个asterisk实例并且可以通过TCP/IP流发送命令或读取事件.这在试图跟踪asterisk的状态或其中的电话客户端状态时很有用,AMI ...

  6. TP框架常用(一)

    25.显示最后一条查询的sql语句:主要用于在连贯操作时,检测拼接的sql语句是否正确 echo $this->db->last_query();//如:select * from pt_ ...

  7. 用Qt Creator 对 leveldb 进行简单的读写

    #include <iostream> #include <string> #include <leveldb/db.h> #include <boost/l ...

  8. PHP数据库操作:使用ORM

    之前我发了一篇博文PHP数据库操作:从MySQL原生API到PDO,向大家展示PHP是如何使用MySQL原生API.MySQLi面向过程.MySQLi面向对象.PDO操作MySQL数据库的.本文介绍如 ...

  9. LevelDB库简介

    LevelDB库简介 一.LevelDB入门 LevelDB是Google开源的持久化KV单机数据库,具有很高的随机写,顺序读/写性能,但是随机读的性能很一般,也就是说,LevelDB很适合应用在查询 ...

随机推荐

  1. 关于华为高斯数据库 GaussDB 版本及认证体系介绍

    目录 你需要知道的 技术有国界 从它的名称说起 你听到过的版本 你听到过的流言蜚语 各个版本的区别 版本未来名称 华为 GaussDB 认证体系介绍 GaussDB 其他资料相关链接 你需要知道的 任 ...

  2. Codeforces 1304D. Shortest and Longest LIS 代码(构造 贪心)

    https://codeforces.com/contest/1304/problem/D #include<bits/stdc++.h> using namespace std; voi ...

  3. 小白月赛22 E : 方格涂色

    E:方格涂色 考察点 : 思维,模拟 坑点 : long long 其他的好像没什么,读懂题意就可以 AC 不要被样例画的图所迷惑 Code: #include <vector> #inc ...

  4. springboot中返回值json中null转换空字符串

    在实际项目中,我们难免会遇到一些无值.当我们转JSON时,不希望这些null出现,比如我们期望所有的null在转JSON时都变成“”“”这种空字符串,那怎么做呢? Jackson中对null的处理 @ ...

  5. 安装配置oracle11gR2、client、plsql developer及学习

    本文是一个目录,以后会持续更新 1,安装oracle11gR2 https://www.cnblogs.com/suterfo/p/10659208.html 2,安装oracle client及配置 ...

  6. IOU 选框和真实框重叠部分占两个总框并集的比例

    IOU 选框和真实框重叠部分占两个总框并集的比例 IOU 召回率:表示在预测为的正类中,有多少正类被预测为正类 https://blog.csdn.net/qq_36653505/article/de ...

  7. eclipse中创建了web项目,src下创建子目录是平级的情况

    1.在以下可设置不同的视图 windows->show view菜单 ->点Other......    然后在搜索框里输入你想要的视图 2.在Project Explorer下创建的包看 ...

  8. 1080 Graduate Admission

    大致题意就是有N个学生,有M个学校,每个学校的名额都是正整数.每个学生可以填K个学校志愿,N个学生一起排名以后,排名高的学生先挑学校,不保护一志愿. 题目要求: 首先,把所有学生按总成绩SUM(GE+ ...

  9. java基础之 java注释

    JAVA里有2中注释风格. 一种以 "/*" 开始以 "*/" 结尾,另一种是以 "//" 起头的. 被注释的内容不会被java虚拟机编译, ...

  10. unity中添加音量控制的一些步骤

    1.先确认要控制的音源(Audio Source)所使用的输出(Output),例如我这里BGM使用的是MainMixer: 2.暴露音量(Volume)参数,让脚本可以控制.这里如果不暴露出来,脚本 ...