P & R 11-程序员宅基地

技术标签: ViewUI  前端  人工智能  runtime  

要做好floorplan需要掌握哪些知识跟技能?

首先熟悉data flow对摆floorplan 有好处,对于减少chip的congestion 是有帮助的,但是也不是必需的,尤其是EDA工具快速发展的当今,比如Innovus 最新的MP特性,可以自动对cell和macro 一起做place,结果相当不错,省了很多事情。

其次,需要了解 design的 power mesh,工艺的DRC rule ,IP 的base layer的spacing rule,memory能否abut ,IP channel 里摆放的cell 供电够不够,最小的spacing 可以到多少, channel里的resource 够不够, analog IP 摆放的位置跟pad 的关系, customer routing 好不好出,这些都是做 top floorplan 时需要预先考虑的。

 

通常,遇到floorplan问题,大致的debug步骤跟方法有哪些?

Floorplan 的问题主要会导致overflow 偏高,或者timing 较差。timing较差的话可以通过看timing path 分析DFF和IP的关系,来得出IP摆放是否合理。如果用的是Innovus, 可以用ameba view 来查看 module 的分布,看看什么module 被扯的很散来得出IP没有摆放合理。

 

如果是overflow 比较差,可以通过查看overflow 的hotspot 来观察hotspot的分布,还有 hotspot所在的module。现在innovus 对于hot spot的module都可以很好地通过降低module local density的方法处理得很好。一般的 hotspot 基本上都是由穿过该区域的routing 引起的,这样就需要考虑到IP的摆放是不是有违dataflow。

如何衡量floorplanQA?

Floorplan的QA 主要是在不影响timing 和congestion的前提下合理布局使得芯片面积可以尽量小。net length, timing result 都是衡量floorplan的标准

 

  • innovus 提供了很多方便的button来摆放memory 比如等距离alignIP ,对齐IP,非常灵活。 

  • 另外有很多IP之间的customer routing 需要在floorplan阶段就考虑进去, innovus 在customer routing 上也有很方便的各种button ,比如从选中的线取名字autofill the net name. 可以指定想用的via type,指定宽度或者NDRrule 自动加 shielding, 在画线的时候还可以show 出 target pin与当前所画shape 之间的飞线,还可以auto snap shape 到pin上,这些都可以省去很多手工操作。

  • 另外通过预先画好region,再planDesign的方式控制同一个hierarchy的memory 摆在一起。

  • 更简单的方法就是通过mix_place 设好 memory的spacing rule,还有加soft blocakge和 hard blockage的range,就可以直接把memory和 standard cell 摆好,完全不需要手工操作。 

Placement


 

要做好placement需要掌握哪些知识跟技能?

place基本分两步来做: coase placement 跟 opt. 这些东西在innovus 只要设好了process相关的default setting,如果不是特别critical 的design, tool都会handle的很好,不需要手工干预什么。

 

遇到critical的design,需要分析local density,congestion 和timing,需要注意的是,在place 阶段 clock都是ideal的,所以很多icg 的timing 是看不精确的,只有到cts 做完之后才能看到这些icg 的精确timing,所以需要对critical icg 额外地加一些clock gating check的margin。

 

通常,遇到placement问题,大致的debug步骤跟方法有哪些?

placement 遇到的主要问题是timing,还有一些place导致的潜在的DRC问题。 

  • 如果是timing问题,首先看timing report, 如果logic level很长,那就需要大概估算下当前的frequecy 是不是可以meet,需不需要前端重新综合;如果本身logic level 不长,但是有很多buffer在path上,那要看下这条path是属于一个hierarchy还是多个hierarchy,属于一个hierarchy的话在ameba view里看下这个hierarchy 在place之后的分布,如果分布的比较散,注意看下是因为什么原因导致分布的不好,一般有可能是IO的place 和macro的floorplan没有做好,把跟两块都有联系的logic 扯的太远,所以需要调整floorplan。如果调整floorplan也无法解决,可以尝试加useful skew 的方法来meet timing。

  • 另外在stdcell 区域看到的congestion的hot spot要格外注意,有可能是复杂的mux 放在一起导致的,需要加额外的module padding,或者需要前端禁用pin density高的cell 重新综合。

 

如何衡量placementQA?

placement的目标是在帮后续优化留够margin的基础上尽可地提高density 使chip面积最小化。place的QA主要靠后续CTS, routing的结果来衡量。如果一个design place timing没问题,但是到了routing 却发现route不通那也没啥用。 

 

Innovus的placement可以根据congestion有效降低local density。

  • Innovus在根据timing做place 方面的表现非常抢眼,可以根据对timing critical的path进行集中的place达到合理的module分布。

  • Innovus还提供了early clock flow,即在place 之前就把ccopt的setting和ccopt spec 读进design,然后设一些earlyclock flow的setting,那么在coarse place之后, tool就会根据目前flip flop的摆放开始build tree, NDR的routing 所需要的资源也会比一般的place 估计的更准一点。clock routing 引入的congestion 也可以在早期得到处理。

  • Innovus可以在place阶段通过auto useful skew 自动进行clock latency的调整,使得timing critical的design 的timing 不再难做。此步骤会生成latency.sdc的文件,用该文件报的timing就是已经把clock latency算在内而得出的。之后在生成ccopt spec的时候,该文件也会自动转换成ccopt spec里的clock pin的insertion delay, ccopt也会honor这个skew. early clockflow和 auto useful skew 是一对好伙伴,一起使用效果更好哟。

  • 在advanced node上一些因为place导致的后期的routing和pg pin access (via pillar)和pg之间的DRC, innovus 也可以在早期就detect到,通过checkPlace还可以报出这些violation。

  • Innovus还有个比较厉害的功能叫layer promotion 会自动把critical path 的early global routing 的layer promote 到高层去,使得一样的距离net上的delay更小。而且这个layer 的promotion 会一直keep到routing stage 会在真正的routing  的时候 honor 这些routing 的promotion。 

 

要做好CTS需要掌握哪些知识跟技能?

  • common sense就是知道CTS在干嘛, CTS就是build所有clock的clock tree 使得理想情况下clock能同时到达所有的FF,然而现实没那么理想,到各个FF的clock总是有长有短,所以只要求这个长短在一定的范围内即可,这个范围将要吞掉一部分在place中留下的margin。

 

  • 要了解自己的design,知道其中的clock哪些是main clock, 哪些是test clock 或者频率较低的clock。对不同的clock 做不同的constrain 和setting 可以使CTS更加有效。比如对不critical的clock 不必设很严格的NDR,不用很大的width和spacing可以节省routing resource。此外要预知clock 对clock gating timing的影响,这些影响是在ideal clock 的时候看不到的。所以需要做一些特殊的setting使得这些icg 更靠近root 端以减小CTS对clock gating的影响。

 

  • 要知道design中哪些clock之间有talk,那么这些clock 需要balance。IP内部的clock latency需要设多少insertion_delay等,情况太复杂不能一一赘述,总之一切都是以setup和hold能meet为首要目标。

通常,遇到CTS问题,大致的debug步骤跟方法有哪些?

CTS承上启下,遇到的问题一般情况比较复杂,既有可能跟place相关也有可能跟routing相关,因为default的CTS流程都会将clock routing上,然后做完clock routing之后再重新fix一下skew 和transition。

 

通常CTS遇到的问题,就是skew 比较大, latency比较长,

  • 对于latency比较长,可以根据design 大小分析这个latency是不是合理,也可以看log 在第一步clusterting做完报出来的clock latency的最大值,如果clustering 做完latency 还比较小那么可以看看log 是在哪一步导致latency 突然变长进行具体分析。

  • 可以查看skew在每一步的变化,在innovus 的log里可以搜索“Primary reporting” 这样的关键字来查看每一步做完之后 latency 和skew的变化,来分析是哪一步导致的问题。大多数问题都是在clock routing之后出现的,这个时候需要分析clock routing的setting是否合理,NDR是不是足够,还有看看clock cell有没有给对, driven是不是够大。

  • 对于skew 较大、latency过长的问题还需要分析design的clock structure,看看有没有不需要balance的FF,比如一些clock generator 的FF 可以设ignore pin 从clock tree 中去掉。如果设了ignore pin 那么CTS是会修Clock transition  但不会跟别的FF做balance,如果设了exclude pin 那么就是完全不修transition在后面postcts 的时候修data transition。还有一些counter 可以设skew group,即这些FF相互之间balance 但是不跟别的FF balance,那么保证的counter之间的timing 可以meet 还可以不跟别的FF balance 不会被physical上较远的FF拉长。

 

如何衡量CTSQA?

CTS的QA主要就是latency和skew ,好的CTS做完不会导致hold 插很多buffer,就说明skew是合理的。另外就是保证common path足够长,这个都是tool 在不复杂的情况下能保证的。如果情况复杂,就需要人为的干预做一些anchor buffer 并且fix 住, guide CCOPT 更好的balance。

 

  • Innovus 最NB的就是CCOPT, CCOPT的NB之处就是concurrent 优化timing和build tree,在build tree的过程中看timing  优化timing 然后重写skew tree 来meet timing。 ccopt 看到的critical 不是path 而是critical loop。一个timing loop里的slack之和除以stage number 具体可以参看user guide :).

  • 做了ccopt 之后就可以很好地处理一下在place阶段处理不好的clock gating 的timing还有怎么都修不掉的setup,但是前提是得保证你的SDC 足够正确,要不然有false path 让ccopt 看到它会很努力的修这些false path,导致别的path 都被skew 了一轮,而且还会导致比较长的run time。所以好东西一定要好好的用起来哟。

要做好Route需要掌握哪些知识跟技能?

routing当然了解design 最高能routing到多少层,哪些层是double pattern,哪些层是厚的metal。还有 std cell 出pin多少层。当然这些你也可以不需要掌握,只要PG打好就是一个routeDesign 的事儿,至少你得知道你的process 吧,在route 的setting 里把相应的process指定好基本上default 的setting 就能handle 一个design了。

 

通常,遇到Route问题,大致的debug步骤跟方法有哪些?

遇到的问题主要有 runtime太久, run完之后short 和DRC 太多,还有就是routing之后timing degrade的问题。

  • run time如果太久的话可以查看下过程中的log里的DRC在哪个layer 或者是哪种类型,如果是底层layer比较多可以在routing之前的db上做个checkPlace 看看有没有一些place 没做好导致的routing DRC。如果出现在高层layer或者某种类型的DRC特别多,可以设少一点的end iteration 重新run下,快速得到一个中间结果看看高层的layer是什么问题导致DRC无法修掉。

  • 在充分的routing和repair之后发现DRC和short比较多的情况下,也需要分析类型比较多的DRC是怎么导致的,如果是因为cell的摆放引起的,那么可以看checkPlace 能不能报出这些问题,如果能报出可以用refinePlace 重新把cell 移开,如果checkPlace 报不出可以自己写一些edge rule来挪开这些cell。

  • 另外还有一些是从thin的layer 到thick layer跳层的大孔比thin layer的track 大,导致这些via 和thin layer routing的short 或者spacing的DRC。这些问题可以通过调整routing 的setting 来解决。

  • 还有一些DRC可能是因为tool 的repair iteration不够引起的,可以通过ecoRoute-fix_drc 再修一轮来fix 这些剩下来的DRC。

  • routing之后的timing degrade 是一个普遍的问题,原因很多,有的是因为congestion 区域太多,使得tool 自动detour了经过这片区域的net,使得net length 变长timing degrade. 还有就是SI 引起的timing degrade。这些问题都可以通过postroute 通过size up 一些cell 来修回来。

 

如何衡量RouteQA?

routing的DRC和timing 是routing 要meet的目标。 DRC要在手工可修的范围;timing 即使degrade也要在所留的margin之内。那么这样的routing就达标了。

 

  • Innovus routing最大的优势就是 DRC和calibre的correlation 非常的好,基本上calibre上的DRC在innovus 里都能被识别到。

  • 另外目前的innovus routing还可以做到在routing的过程中优化timing使得routing的结果和postRoute 的结果 correlation 非常好。 

 

要做好DRC需要掌握哪些知识跟技能?

修DRC需要了解design rule,还需要会使用innovus里一些editwire的button和gui。

 

通常,遇到DRC问题,大致的debug步骤跟方法有哪些?

DRC的问题主要就是tool 没有handle好,在用了ecoRoute -fix_drc之后如果还是没有改善那么就需要手工去handle了,这个时候熟练运用各种innovus的快捷键会对修drc有很大的帮助。

 

如何衡量DRCQA?

DRC的QA就是修干净了,在calibre里没有报出错了。

因为innovus 和calibre 的DRC correlation非常好,尤其是在advanced node上,所以基本上在innovus里fix 干净的DRC在signoff tool里就很少有没有fix的drc了。

 

Innovus手工操作速度快且方便,可以自动snap wire, via, snap到track, snap到pin都没问题。不想snap 还可以关掉。画线可以自动gen 出孔,不想gen 也可以关掉,总之是又迅速又便捷。

 

转载于:https://www.cnblogs.com/lelin/p/11407511.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/diedai7174/article/details/101205201

智能推荐

攻防世界_难度8_happy_puzzle_攻防世界困难模式攻略图文-程序员宅基地

文章浏览阅读645次。这个肯定是末尾的IDAT了,因为IDAT必须要满了才会开始一下个IDAT,这个明显就是末尾的IDAT了。,对应下面的create_head()代码。,对应下面的create_tail()代码。不要考虑爆破,我已经试了一下,太多情况了。题目来源:UNCTF。_攻防世界困难模式攻略图文

达梦数据库的导出(备份)、导入_达梦数据库导入导出-程序员宅基地

文章浏览阅读2.9k次,点赞3次,收藏10次。偶尔会用到,记录、分享。1. 数据库导出1.1 切换到dmdba用户su - dmdba1.2 进入达梦数据库安装路径的bin目录,执行导库操作  导出语句:./dexp cwy_init/[email protected]:5236 file=cwy_init.dmp log=cwy_init_exp.log 注释:   cwy_init/init_123..._达梦数据库导入导出

js引入kindeditor富文本编辑器的使用_kindeditor.js-程序员宅基地

文章浏览阅读1.9k次。1. 在官网上下载KindEditor文件,可以删掉不需要要到的jsp,asp,asp.net和php文件夹。接着把文件夹放到项目文件目录下。2. 修改html文件,在页面引入js文件:<script type="text/javascript" src="./kindeditor/kindeditor-all.js"></script><script type="text/javascript" src="./kindeditor/lang/zh-CN.js"_kindeditor.js

STM32学习过程记录11——基于STM32G431CBU6硬件SPI+DMA的高效WS2812B控制方法-程序员宅基地

文章浏览阅读2.3k次,点赞6次,收藏14次。SPI的详情简介不必赘述。假设我们通过SPI发送0xAA,我们的数据线就会变为10101010,通过修改不同的内容,即可修改SPI中0和1的持续时间。比如0xF0即为前半周期为高电平,后半周期为低电平的状态。在SPI的通信模式中,CPHA配置会影响该实验,下图展示了不同采样位置的SPI时序图[1]。CPOL = 0,CPHA = 1:CLK空闲状态 = 低电平,数据在下降沿采样,并在上升沿移出CPOL = 0,CPHA = 0:CLK空闲状态 = 低电平,数据在上升沿采样,并在下降沿移出。_stm32g431cbu6

计算机网络-数据链路层_接收方收到链路层数据后,使用crc检验后,余数为0,说明链路层的传输时可靠传输-程序员宅基地

文章浏览阅读1.2k次,点赞2次,收藏8次。数据链路层习题自测问题1.数据链路(即逻辑链路)与链路(即物理链路)有何区别?“电路接通了”与”数据链路接通了”的区别何在?2.数据链路层中的链路控制包括哪些功能?试讨论数据链路层做成可靠的链路层有哪些优点和缺点。3.网络适配器的作用是什么?网络适配器工作在哪一层?4.数据链路层的三个基本问题(帧定界、透明传输和差错检测)为什么都必须加以解决?5.如果在数据链路层不进行帧定界,会发生什么问题?6.PPP协议的主要特点是什么?为什么PPP不使用帧的编号?PPP适用于什么情况?为什么PPP协议不_接收方收到链路层数据后,使用crc检验后,余数为0,说明链路层的传输时可靠传输

软件测试工程师移民加拿大_无证移民,未受过软件工程师的教育(第1部分)-程序员宅基地

文章浏览阅读587次。软件测试工程师移民加拿大 无证移民,未受过软件工程师的教育(第1部分) (Undocumented Immigrant With No Education to Software Engineer(Part 1))Before I start, I want you to please bear with me on the way I write, I have very little gen...

随便推点

Thinkpad X250 secure boot failed 启动失败问题解决_安装完系统提示secureboot failure-程序员宅基地

文章浏览阅读304次。Thinkpad X250笔记本电脑,装的是FreeBSD,进入BIOS修改虚拟化配置(其后可能是误设置了安全开机),保存退出后系统无法启动,显示:secure boot failed ,把自己惊出一身冷汗,因为这台笔记本刚好还没开始做备份.....根据错误提示,到bios里面去找相关配置,在Security里面找到了Secure Boot选项,发现果然被设置为Enabled,将其修改为Disabled ,再开机,终于正常启动了。_安装完系统提示secureboot failure

C++如何做字符串分割(5种方法)_c++ 字符串分割-程序员宅基地

文章浏览阅读10w+次,点赞93次,收藏352次。1、用strtok函数进行字符串分割原型: char *strtok(char *str, const char *delim);功能:分解字符串为一组字符串。参数说明:str为要分解的字符串,delim为分隔符字符串。返回值:从str开头开始的一个个被分割的串。当没有被分割的串时则返回NULL。其它:strtok函数线程不安全,可以使用strtok_r替代。示例://借助strtok实现split#include <string.h>#include <stdio.h&_c++ 字符串分割

2013第四届蓝桥杯 C/C++本科A组 真题答案解析_2013年第四届c a组蓝桥杯省赛真题解答-程序员宅基地

文章浏览阅读2.3k次。1 .高斯日记 大数学家高斯有个好习惯:无论如何都要记日记。他的日记有个与众不同的地方,他从不注明年月日,而是用一个整数代替,比如:4210后来人们知道,那个整数就是日期,它表示那一天是高斯出生后的第几天。这或许也是个好习惯,它时时刻刻提醒着主人:日子又过去一天,还有多少时光可以用于浪费呢?高斯出生于:1777年4月30日。在高斯发现的一个重要定理的日记_2013年第四届c a组蓝桥杯省赛真题解答

基于供需算法优化的核极限学习机(KELM)分类算法-程序员宅基地

文章浏览阅读851次,点赞17次,收藏22次。摘要:本文利用供需算法对核极限学习机(KELM)进行优化,并用于分类。

metasploitable2渗透测试_metasploitable2怎么进入-程序员宅基地

文章浏览阅读1.1k次。一、系统弱密码登录1、在kali上执行命令行telnet 192.168.26.1292、Login和password都输入msfadmin3、登录成功,进入系统4、测试如下:二、MySQL弱密码登录:1、在kali上执行mysql –h 192.168.26.129 –u root2、登录成功,进入MySQL系统3、测试效果:三、PostgreSQL弱密码登录1、在Kali上执行psql -h 192.168.26.129 –U post..._metasploitable2怎么进入

Python学习之路:从入门到精通的指南_python人工智能开发从入门到精通pdf-程序员宅基地

文章浏览阅读257次。本文将为初学者提供Python学习的详细指南,从Python的历史、基础语法和数据类型到面向对象编程、模块和库的使用。通过本文,您将能够掌握Python编程的核心概念,为今后的编程学习和实践打下坚实基础。_python人工智能开发从入门到精通pdf

推荐文章

热门文章

相关标签