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

智能推荐

第1篇 目标检测概述 —(2)目标检测算法介绍_检测类算法的作用-程序员宅基地

文章浏览阅读1.4k次,点赞3次,收藏8次。目标检测算法是一种计算机视觉算法,用于在图像或视频中识别和定位特定的目标物体。本节课就给大家重点介绍下基于深度学习的目标检测算法!_检测类算法的作用

Linux编译mplayer播放badapple及编译fbv加载图片(基于V3S预告板子要开源了)_v3s笔记-程序员宅基地

文章浏览阅读1.8k次,点赞3次,收藏15次。Linux编译mplayer播放badapple及编译fbv加载图片(基于V3S)1.编译前准备:1.linux5.10内核2.2018.02bulidroot3.v3s板子2.linux内核配置1.修改设备树(linux-5.10/arch/arm/boot/dts/文件夹下)1.修改sun8i-v3s.dtsi文件的最后一个dma的位置添加以下代码: codec_analog: codec-analog@01c23000 { compatible = "allwinner,sun_v3s笔记

我们应如何度过自己的大学生活?_如何度过大学生活1000字-程序员宅基地

文章浏览阅读3.1k次。我们应如何度过自己的大学生活?  踏着九月的烈日,我们成功地来到了河南理工大学,开始了我们的大学生活,那么你可曾想过,我们到底应该如何度过我们的大学生活才算有意义呢?  可曾记得高中老师说的最多的一句话:“好好学吧!上了大学就轻松了!”每当听到这句话时都会给我们莫大的鼓励,也让我们对大学充满了憧憬。那么大学生活真如高中老师说的那样轻松吗?其实不然!高中老师所谓的轻松只是在一定程度上正课的时..._如何度过大学生活1000字

python snownlp情感分析简易demo(分享),没有我Python干不成的事!_snowlp情感分析代码-程序员宅基地

文章浏览阅读745次。SnowNLP是国人开发的python类库,可以方便的处理中文文本内容,是受到了TextBlob的启发而写的,由于现在大部分的自然语言处理库基本都是针对英文的,于是写了一个方便处理中文的类库,并且和TextBlob不同的是,这里没有用NLTK,所有的算法都是自己实现的,并且自带了一些训练好的字典。注意本程序都是处理的unicode编码,所以使用时请自行decode成unicode。MIT许可下发行。其github主页可能有些不准确,我也是随便提取的数据,不过snownlp还是号称情感分析准确很高的!_snowlp情感分析代码

命令行安装todesk_todesk命令行csdn-程序员宅基地

文章浏览阅读653次,点赞10次,收藏7次。要想通过命令行安装todesk,也是比较简单的。_todesk命令行csdn

如何开发一个个人微信小程序,微信小程序开发入门教程_微信小程序怎么开发自己的小程序-程序员宅基地

文章浏览阅读10w+次,点赞183次,收藏1.1k次。做任何程序开发要首先找到其官方文档,我们先来看看其有哪些官方文档。微信小程序开发文档链接为:https://mp.weixin.qq.com/debug/wxadoc/dev/index.html,如下图:这里就是做微信小程序开发的全部官方文档。知道了文档的位置,下面我们来介绍下如何做一个微信小程序开发:第一步:下载微信小程序开发者工具并安装,下载路径:https://mp.weix..._微信小程序怎么开发自己的小程序

随便推点

如何在金山云上部署高可用Oracle数据库服务_rman target sys/holyp#ssw0rd2024@gdcamspri auxilia-程序员宅基地

文章浏览阅读788次。如何在金山云上部署高可用Oracle数据库服务根据不同需求,基于金山云云服务器、专属云、物理主机、云硬盘和托管服务自建Oracle数据库,通过Oracle Data Guard实现高可用,实现主备数据复制、有计划切换(Switchover)和故障切换(Failover),并利用对象存储归档数据库历史数据。具体的架构示意图如下:本文介绍采用金山云云服务器搭建高可用Oracle数据库(采用版本是..._rman target sys/holyp#ssw0rd2024@gdcamspri auxiliary sys/holyp#ssw0rd2024@gd

Spring整合Activemq-程序员宅基地

文章浏览阅读7.6k次,点赞6次,收藏10次。spring整合activemq_spring整合activemq

语义分割入门的总结-程序员宅基地

文章浏览阅读740次。点击上方“小白学视觉”,选择加"星标"或“置顶”重磅干货,第一时间送达作者:Yanpeng Sunhttps://zhuanlan.zhihu.com/p/74318967声明:仅做学术分..._语义分割两个目标重合怎么

SpringBoot实践(三十五):JVM信息分析_怎样查看springboot项目的jvm状态-程序员宅基地

文章浏览阅读902次。JVM分析可以也可以使用,那么什么时候用到jvm信息分析呢,一般生产测试环境,能够最大化将问题暴露,但是总有些问题只有生产运行很长时间后才会被发现,jvm分析经常用于运行了很久的系统有异常情况时的调优,比如堆内存本身分配不合理,新生代中eden比例太低等。_怎样查看springboot项目的jvm状态

基于springboot+vue的戒毒所人员管理系统 毕业设计-附源码251514_戒毒所管理系统-程序员宅基地

文章浏览阅读288次。戒毒所人员管理系统的开发是采用java语言,基于MVVM模式进行开发,采取MySQL作为后台数据的主要存储单元,采用Springboot框架实现了本系统的全部功能。戒毒所人员管理系统,具有戒毒人员管理、尿检管理、戒毒管理、治疗分类、社会跟踪等功能,本系统代码的复用率高,系统维护代价小,具有方便、灵活、高效等特征。_戒毒所管理系统

【LeetCode】面试题57 - II. 和为s的连续正数序列_leet code 和为s的正数序列 java-程序员宅基地

文章浏览阅读174次。来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/he-wei-sde-lian-xu-zheng-shu-xu-lie-lcof题目描述:输入一个正整数 target ,输出所有和为 target 的连续正整数序列(至少含有两个数)。序列内的数字由小到大排列,不同序列按照首个数字从小到大排列。示例 1:输入:target = 9..._leet code 和为s的正数序列 java