Congestion的解决方法

2023-10-25 07:10
文章标签 方法 解决 congestion

本文主要是介绍Congestion的解决方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

b52b371c99e74550835ad7b90a0c2eba.jpg

congestion是与绕线好坏直接挂钩的参数,如何分析和解决congestion问题可以通过整体和局部两个方向入手。

一,整体

1.floorplan
模块的形状或floorplan导致的core内摆放standard cell的区域呈现整体或局部长宽比例失调的长方形,容易造成单一方向绕线资源紧张,需要调整模块形状或者sram的摆放。
2.power plan
过多占用绕线层做power plan或者strap下加过量的power via可能造成power mesh附近的绕线问题,需要调整power mesh的密度和power via array的数量。
3.综合
初始利用率高可以先用dcg/dct去综合根据综合时序结果再去迭代调整die size(利用率高到综合的时序都无法收敛的时候扩大面积是最容易的)。

如果是约束严苛导致的place利用率激增,可以通过开放lvt,禁用大驱动cell,放松transition约束等方法。
第三种可能是网表中使用了过多AOI/OAI cell导致pin density过高,这类问题统一设cell padding(也叫keepout)。

create_keepout_margin -outer {0.14 0 0 0.14} [get_flat_cells -filter "ref_name =~ *AOI* ll *OAI*"]

4.tech file

常见的tech file问题来自via定义“ContactCode”,设置“is default contact = 1”,让绕线使用多种via。

二,局部

1.core区

处理办法通常设置module padding或instance padding(keepout margin)来解决,如果问题出现在power mesh附近且power plan无法让步,那就在power mesh下做与power mesh等宽的partial blockage array。

2.sram相关

这类可以分为,sram上,sram与core区之间,sram之间的channel里。

sram上,先分析congestion原因,是channel里cell过多造成的,还是sram出pin方向错误引起的,亦或是floorplan不合理让sram上走了大量信号线,进而调整channel里cell数量,sram方向,sram位置。

sram与core区之间,通常出现在sram上走线比较多,相邻core区pin density或cell density过高的情况,通常会在sram靠近core区的边上加soft blockage、partial blockage array(如图1)、hard blockage array(如图2),partial blockage加array的原因是大块的采用partial blockage可能造成局部利用率高的情况,虽然整体符合partial设置的比例局部却没有达到预期的效果,hard blockage array的效果与其类似。

2eb11f55e7144c009a0801979b03f8b0.png

图1.partial blockage array脚本示例

 cef3e1eb9f364f1fbebe4037da6708d9.png

图2.hard blockage array脚本示例

channel里有严重的congestion一般会先检查sram的出pin的方向,然后加soft blockage限制channel里cell的数量,也可以加宽channel增加绕线资源。

在解决办法上除了加keepout和五花八门的blockage以外,工具也提供了很多option直接过间接的能解决congestion问题。

#优化high density区域,但会消耗更多run time

set_app_option -name place.legalize.stream_place -value true

 

set_app_option -name place.legalize.stream_effort_limit -value 300

#优化cong的effort

set_app_options -name place_opt.place.congestion_effort -value high 

 

set_app_options -name place_opt.final_place.effort -value high

#打开 pin density aware

set_app_options -name place.coarse.pin_density_aware -value true

 

set_app_options -name place.legalize.optimize_pin_access_using_cell_spacing -value true

#降低利用率

set_app_options -name  opt_area.effort -value high

#使用two pass flow在initial_place阶段可以对时序和congestion都有改善,但不适用于SPG flow,因为SPG flow跳过initial_place阶段。

set_app_options -name place_opt.initial_drc.global_route_based -value true

 

set_app_options -name place_opt.initial_place.two_pass -value true

 

 

 

 

 

 

 

这篇关于Congestion的解决方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/280885

相关文章

RedisTemplate默认序列化方式显示中文乱码的解决

《RedisTemplate默认序列化方式显示中文乱码的解决》本文主要介绍了SpringDataRedis默认使用JdkSerializationRedisSerializer导致数据乱码,文中通过示... 目录1. 问题原因2. 解决方案3. 配置类示例4. 配置说明5. 使用示例6. 验证存储结果7.

Swagger在java中的运用及常见问题解决

《Swagger在java中的运用及常见问题解决》Swagger插件是一款深受Java开发者喜爱的工具,它在前后端分离的开发模式下发挥着重要作用,:本文主要介绍Swagger在java中的运用及常... 目录前言1. Swagger 的主要功能1.1 交互式 API 文档1.2 客户端 SDK 生成1.3

Java 枚举的基本使用方法及实际使用场景

《Java枚举的基本使用方法及实际使用场景》枚举是Java中一种特殊的类,用于定义一组固定的常量,枚举类型提供了更好的类型安全性和可读性,适用于需要定义一组有限且固定的值的场景,本文给大家介绍Jav... 目录一、什么是枚举?二、枚举的基本使用方法定义枚举三、实际使用场景代替常量状态机四、更多用法1.实现接

java String.join()方法实例详解

《javaString.join()方法实例详解》String.join()是Java提供的一个实用方法,用于将多个字符串按照指定的分隔符连接成一个字符串,这一方法是Java8中引入的,极大地简化了... 目录bVARxMJava String.join() 方法详解1. 方法定义2. 基本用法2.1 拼接

java连接opcua的常见问题及解决方法

《java连接opcua的常见问题及解决方法》本文将使用EclipseMilo作为示例库,演示如何在Java中使用匿名、用户名密码以及证书加密三种方式连接到OPCUA服务器,若需要使用其他SDK,原理... 目录一、前言二、准备工作三、匿名方式连接3.1 匿名方式简介3.2 示例代码四、用户名密码方式连接4

springboot项目中使用JOSN解析库的方法

《springboot项目中使用JOSN解析库的方法》JSON,全程是JavaScriptObjectNotation,是一种轻量级的数据交换格式,本文给大家介绍springboot项目中使用JOSN... 目录一、jsON解析简介二、Spring Boot项目中使用JSON解析1、pom.XML文件引入依

如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socket read timed out的问题

《如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socketreadtimedout的问题》:本文主要介绍解决Druid线程... 目录异常信息触发场景找到版本发布更新的说明从版本更新信息可以看到该默认逻辑已经去除总结异常信息触发场景复

IDEA中Maven Dependencies出现红色波浪线的原因及解决方法

《IDEA中MavenDependencies出现红色波浪线的原因及解决方法》在使用IntelliJIDEA开发Java项目时,尤其是基于Maven的项目,您可能会遇到MavenDependenci... 目录一、问题概述二、解决步骤2.1 检查 Maven 配置2.2 更新 Maven 项目2.3 清理本

java中BigDecimal里面的subtract函数介绍及实现方法

《java中BigDecimal里面的subtract函数介绍及实现方法》在Java中实现减法操作需要根据数据类型选择不同方法,主要分为数值型减法和字符串减法两种场景,本文给大家介绍java中BigD... 目录Java中BigDecimal里面的subtract函数的意思?一、数值型减法(高精度计算)1.

CentOS 7 YUM源配置错误的解决方法

《CentOS7YUM源配置错误的解决方法》在使用虚拟机安装CentOS7系统时,我们可能会遇到YUM源配置错误的问题,导致无法正常下载软件包,为了解决这个问题,我们可以替换YUM源... 目录一、备份原有的 YUM 源配置文件二、选择并配置新的 YUM 源三、清理旧的缓存并重建新的缓存四、验证 YUM 源