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

智能推荐

什么是内部类?成员内部类、静态内部类、局部内部类和匿名内部类的区别及作用?_成员内部类和局部内部类的区别-程序员宅基地

文章浏览阅读3.4k次,点赞8次,收藏42次。一、什么是内部类?or 内部类的概念内部类是定义在另一个类中的类;下面类TestB是类TestA的内部类。即内部类对象引用了实例化该内部对象的外围类对象。public class TestA{ class TestB {}}二、 为什么需要内部类?or 内部类有什么作用?1、 内部类方法可以访问该类定义所在的作用域中的数据,包括私有数据。2、内部类可以对同一个包中的其他类隐藏起来。3、 当想要定义一个回调函数且不想编写大量代码时,使用匿名内部类比较便捷。三、 内部类的分类成员内部_成员内部类和局部内部类的区别

分布式系统_分布式系统运维工具-程序员宅基地

文章浏览阅读118次。分布式系统要求拆分分布式思想的实质搭配要求分布式系统要求按照某些特定的规则将项目进行拆分。如果将一个项目的所有模板功能都写到一起,当某个模块出现问题时将直接导致整个服务器出现问题。拆分按照业务拆分为不同的服务器,有效的降低系统架构的耦合性在业务拆分的基础上可按照代码层级进行拆分(view、controller、service、pojo)分布式思想的实质分布式思想的实质是为了系统的..._分布式系统运维工具

用Exce分析l数据极简入门_exce l趋势分析数据量-程序员宅基地

文章浏览阅读174次。1.数据源准备2.数据处理step1:数据表处理应用函数:①VLOOKUP函数; ② CONCATENATE函数终表:step2:数据透视表统计分析(1) 透视表汇总不同渠道用户数, 金额(2)透视表汇总不同日期购买用户数,金额(3)透视表汇总不同用户购买订单数,金额step3:讲第二步结果可视化, 比如, 柱形图(1)不同渠道用户数, 金额(2)不同日期..._exce l趋势分析数据量

宁盾堡垒机双因素认证方案_horizon宁盾双因素配置-程序员宅基地

文章浏览阅读3.3k次。堡垒机可以为企业实现服务器、网络设备、数据库、安全设备等的集中管控和安全可靠运行,帮助IT运维人员提高工作效率。通俗来说,就是用来控制哪些人可以登录哪些资产(事先防范和事中控制),以及录像记录登录资产后做了什么事情(事后溯源)。由于堡垒机内部保存着企业所有的设备资产和权限关系,是企业内部信息安全的重要一环。但目前出现的以下问题产生了很大安全隐患:密码设置过于简单,容易被暴力破解;为方便记忆,设置统一的密码,一旦单点被破,极易引发全面危机。在单一的静态密码验证机制下,登录密码是堡垒机安全的唯一_horizon宁盾双因素配置

谷歌浏览器安装(Win、Linux、离线安装)_chrome linux debian离线安装依赖-程序员宅基地

文章浏览阅读7.7k次,点赞4次,收藏16次。Chrome作为一款挺不错的浏览器,其有着诸多的优良特性,并且支持跨平台。其支持(Windows、Linux、Mac OS X、BSD、Android),在绝大多数情况下,其的安装都很简单,但有时会由于网络原因,无法安装,所以在这里总结下Chrome的安装。Windows下的安装:在线安装:离线安装:Linux下的安装:在线安装:离线安装:..._chrome linux debian离线安装依赖

烤仔TVの尚书房 | 逃离北上广?不如押宝越南“北上广”-程序员宅基地

文章浏览阅读153次。中国发达城市榜单每天都在刷新,但无非是北上广轮流坐庄。北京拥有最顶尖的文化资源,上海是“摩登”的国际化大都市,广州是活力四射的千年商都。GDP和发展潜力是衡量城市的数字指...

随便推点

java spark的使用和配置_使用java调用spark注册进去的程序-程序员宅基地

文章浏览阅读3.3k次。前言spark在java使用比较少,多是scala的用法,我这里介绍一下我在项目中使用的代码配置详细算法的使用请点击我主页列表查看版本jar版本说明spark3.0.1scala2.12这个版本注意和spark版本对应,只是为了引jar包springboot版本2.3.2.RELEASEmaven<!-- spark --> <dependency> <gro_使用java调用spark注册进去的程序

汽车零部件开发工具巨头V公司全套bootloader中UDS协议栈源代码,自己完成底层外设驱动开发后,集成即可使用_uds协议栈 源代码-程序员宅基地

文章浏览阅读4.8k次。汽车零部件开发工具巨头V公司全套bootloader中UDS协议栈源代码,自己完成底层外设驱动开发后,集成即可使用,代码精简高效,大厂出品有量产保证。:139800617636213023darcy169_uds协议栈 源代码

AUTOSAR基础篇之OS(下)_autosar 定义了 5 种多核支持类型-程序员宅基地

文章浏览阅读4.6k次,点赞20次,收藏148次。AUTOSAR基础篇之OS(下)前言首先,请问大家几个小小的问题,你清楚:你知道多核OS在什么场景下使用吗?多核系统OS又是如何协同启动或者关闭的呢?AUTOSAR OS存在哪些功能安全等方面的要求呢?多核OS之间的启动关闭与单核相比又存在哪些异同呢?。。。。。。今天,我们来一起探索并回答这些问题。为了便于大家理解,以下是本文的主题大纲:[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JCXrdI0k-1636287756923)(https://gite_autosar 定义了 5 种多核支持类型

VS报错无法打开自己写的头文件_vs2013打不开自己定义的头文件-程序员宅基地

文章浏览阅读2.2k次,点赞6次,收藏14次。原因:自己写的头文件没有被加入到方案的包含目录中去,无法被检索到,也就无法打开。将自己写的头文件都放入header files。然后在VS界面上,右键方案名,点击属性。将自己头文件夹的目录添加进去。_vs2013打不开自己定义的头文件

【Redis】Redis基础命令集详解_redis命令-程序员宅基地

文章浏览阅读3.3w次,点赞80次,收藏342次。此时,可以将系统中所有用户的 Session 数据全部保存到 Redis 中,用户在提交新的请求后,系统先从Redis 中查找相应的Session 数据,如果存在,则再进行相关操作,否则跳转到登录页面。此时,可以将系统中所有用户的 Session 数据全部保存到 Redis 中,用户在提交新的请求后,系统先从Redis 中查找相应的Session 数据,如果存在,则再进行相关操作,否则跳转到登录页面。当数据量很大时,count 的数量的指定可能会不起作用,Redis 会自动调整每次的遍历数目。_redis命令

URP渲染管线简介-程序员宅基地

文章浏览阅读449次,点赞3次,收藏3次。URP的设计目标是在保持高性能的同时,提供更多的渲染功能和自定义选项。与普通项目相比,会多出Presets文件夹,里面包含着一些设置,包括本色,声音,法线,贴图等设置。全局只有主光源和附加光源,主光源只支持平行光,附加光源数量有限制,主光源和附加光源在一次Pass中可以一起着色。URP:全局只有主光源和附加光源,主光源只支持平行光,附加光源数量有限制,一次Pass可以计算多个光源。可编程渲染管线:渲染策略是可以供程序员定制的,可以定制的有:光照计算和光源,深度测试,摄像机光照烘焙,后期处理策略等等。_urp渲染管线

推荐文章

热门文章

相关标签