数字集成电路后端(Innovus)开发设计

2023-10-25 01:10

本文主要是介绍数字集成电路后端(Innovus)开发设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、本文目的是对数字IC进行:

1、平面规划设计(Floorplanning the Design);

9c9d4d0fe4064acd91660b65e6d80aa5.png

2、电源路径设计(Routing Power with Special Route);

6ebde07958e14ba3884f5805e46025fb.png

3、使用Early Global Router分析路径(布线)可行性(Analyzing Route Feasibility with the Early Global Router)。

77264dfcbb5b40ac8970706b859958b2.png

二、设计过程与结果:

1、平面规划设计(Floorplanning the Design)

1)从根目录进入工作路径/share/training/cadence/INNOVUS_181_BLK/FPR/work,如下图所示:

0b826d57d0f040a389d8895dd6ce5d95.png

2)在此路径下打开Innovus如下图:

43e48c961cef4fe491708bd69d3bfcf0.png

3)导入路径/share/training/cadence/INNOVUS_181_BLK/FPR/work下dtmf.globals设计文件,如下图:

a12fc39b43864864897c5decdb9168b3.png

4)切换到floorplan view查看设计中的macro,module和port,如下图:

ce13b82e4a864dffbb493f6aca6a2884.png

5)通过Tools > Design Browser显示设计的hierarchy层次,如下图:35bc1efde3434b84ab3e5d1b58d46d55.png

6)尺寸定义与设计检查:通过Floorplan > Specify Floorplan定义芯片与模块大小,芯片或模块大小有两种方式来指定,我根据Aspect Ratio,即给定利用率指定尺寸,由工具算出H和W,默认矩形,H×W即为面积,如下图所示:

180f78f9df3548eeb69cf1f77ce86875.png

(此外可通过Dimension定义尺寸,即直接指定H和W大小)

7)由于此lab是带IO的设计,需要指定Core2IO的间距(如果是模块级设计则需要指定Core2Die的间距),此时将IO和CORE之间的距离设为100μm,如下第一张图,设置完后Layout如下第二张图所示:

c77899d9c7ba4bae9227d905166cc42a.png1915520c24e84daebbd2c8acf9743def.png

 8)使用命令Check Design -netlist检查设计参考库以及netlist本身的问题,运行后在work/checkDesign/目录下生成了DTMF_CHIP.main.htm.ascii文件,是Check Design的详细信息,如下图:c70754335aa246e5a073093c8ea6fbb8.png

2、电源路径设计(Routing Power with Special Route)

1)手动摆放macro,ip与halo,或执行File > Load > Floorplan选择dtmf_blocks.fp,完成后的Layout如下图所示:6d766869e9c34056a8dee0232e513e9e.png

2)更改PLLCLK网络的Placement Halo使之均为30μm,如下第一张图,改动成功后结果如下第二张图所示:

d699a8ed4ce844eb922505fe92fcd0a1.png    

 abd8caba694d4c7c8b4c8a92ac79e0f1.png

3)进行Powerplaning设计,加入电源环,设置参数如下第一张图所示,加入电源环后效果如下第二张图所示(红色与蓝色部分):

  e93215aed81a4f5499c02db8260007af.png804f1424d64b4b34aaebf645f1ab087b.png

4)之后给PLLCLK网络加上电源环,选中PLLCLK后,基本参数设置与电源环形状设置如下两张图所示:

  b5dfabe8420c4757bd4111751e12ccdb.png

 c17fee4499a246199a1beb515add21b8.png

5)设置后的电源环效果如下图所示:e68e78aff9084f9fab6e10aa4c2d7007.png

6)添加Power Stripe:Power > Power Planning > Add Power Stripe,将各参数设置如下图所示:1f8531f029a243ce8060d40042fda1f2.png

7)添加Power Stripe后,可见VDD与VSS间距为1微米,且VDD组间距、VSS组间距均为100微米,结果如下图:984256ac263547d49bb46c15d6dd9237.png

8)摆放cell:Design Browser > 选中cell后 > q键指定坐标,参数如下图所示:20bf197965c74af490e339e47083f971.png

9)切换physical view即可看见这颗cell的坐标变化结果,如下图:7d92f191885a4ac2b476fbcb3a7ac658.png

10)添加Power Rail并且和Power Stripe打孔:从M6打孔到M1(各层均打VIA),设置参数如下图所示:5e37997fd0764ddfb441dc77d049b73e.png

11)至此,Powerplan完成,效果如下图所示:ca8bec0ca035435790d6a3843a13982c.png16b9a1621ea94809b1d06a4af32afb52.png

3、使用Early Global Router分析路径(布线)可行性(Analyzing Route Feasibility with the Early Global Router)

1)在命令行界面输入getPlaceMode后,输出了所有的PlaceMode如下图:a011b06f09b4461084cfa5a0774a8871.png

2)输入命令defIn scan_input.def,在Place之前读入scan chain的def进一步优化congestion,之后跑Placement命令place_opt_design,可得到Timing Report、DRV结果,以及整体Density的值为48.462%,Routing Overflow大小为0.01%H和0.00%V,如图:2011beaeeb504d79b3805f6a36f39e5c.png

3)输入指令defOutBySection -noNets -noComps -scanChains scan.def,显示Scan Chain连接示意图,也可直接操作:Place > Display > Scan Chain,如下图:aa0fc5da130c4843921add3e1baa089e.png

4)可见局部连接顺序情况及Congestion情况如下图:fb89924398b342f89269a540b143a4d0.png

5) 输入指令restoreDesign ../saved/placeOpt.inv.dat DTMF_CHIP打开Placement后保存的数据,使用前期Global Router引擎分析潜在绕线问题:Route > Early Global Router,操作如下图所示:d5b00f1831f24c638ea0284b39d836de.png

6)可见垂直方向上存在Congestion,其中一条Congestion上绕线风险如图所示:ed4168b29161456a9f98ccef73c3c2f8.png

7)取消勾选垂直方向V的显示,去掉Congestion Label,可见设计均不存在Congestion了,如图:ac92a9bab8e44f90af363c0a963df77a.png

8)使用命令saveDesign ../saved/earlyGlobalRouterByLiTianhao.inn保存设计,之后通过restoreDesign ../saved/earlyGlobalRouterByLiTianhao.inn.dat DTMF_CHIP可以打开设计。设计结果如图:97d6f15caffe4d4b9ca957fb584e12eb.png

放大可查看具体布线情况,确保不存在绕线,如图:

cdc12ce19676497ebdc91faa349202a7.png

三、补充问题:

四、作业

1、Import Design读入数据后,执行checkDesign –netlist输出的结果关注要点:

   Q1.Instance数:5680个,Block数:4个。

   Q2.IO数:57个,其中Input数:28个,Output数:29个。

   Q3.Standard Cell的面积:129865.98平方微米。

b6b0700a4c6842dab83d4d425c2a7fa8.png

2、读入dtmf.fp后,确认如下信息:

   Q1. pllclk这个Block的形状:长280微米,宽300微米,位置坐标:{355.28 355.44} (X-Y系)30aac6a6988c480e864a64ab36b2de95.png

   Q2. CoreRing使用的Layer:Metal 5与Metal 6,宽度是:8微米。

   Q3. Stripe使用的Layer:Metal 6,宽度是:8微米。

3、PowerPlan的操作要点3个

①先给整个芯片加上电源环后再选中BLOCK,给小的BLOCK加电源环;

②基本参数包括宽度等设置好后,还需注意设置电源环形状;

③添加Power Stripe后,须添加Power Rail并且和Power Stripe打孔。

4、Floorplan设计的注意事项3个

①如果lab是带IO的设计,需要指定Core2IO的间距(如果是模块级设计则需要指定Core2Die的间距);

②芯片或模块大小有两种方式来指定,我根据Aspect Ratio,即给定利用率指定尺寸,由工具算出H和W,默认矩形,H×W即为面积,此外可通过Dimension定义尺寸,即直接指定H和W大小;

③导入Floorplan设计时须使用命令Check Design -netlist检查设计参考库以及netlist本身的问题,运行后在work/checkDesign/目录下生成以.main.htm.ascii为后缀的文件,是Check Design的详细信息。

5、Lab 10 Place完成后Timing的确认

   Q1. Place之前的Timing确认:0.098纳秒,截图WNS的Slack:a6004268c411481f885ddb11a16d8c8d.png

   Q2. Place之后的Timing确认:0.112纳秒,截图WNS的Slack:

 739934d97724439896a85fd3a4f6b84e.png

这篇关于数字集成电路后端(Innovus)开发设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

MyBatis设计SQL返回布尔值(Boolean)的常见方法

《MyBatis设计SQL返回布尔值(Boolean)的常见方法》这篇文章主要为大家详细介绍了MyBatis设计SQL返回布尔值(Boolean)的几种常见方法,文中的示例代码讲解详细,感兴趣的小伙伴... 目录方案一:使用COUNT查询存在性(推荐)方案二:条件表达式直接返回布尔方案三:存在性检查(EXI

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

如何基于Python开发一个微信自动化工具

《如何基于Python开发一个微信自动化工具》在当今数字化办公场景中,自动化工具已成为提升工作效率的利器,本文将深入剖析一个基于Python的微信自动化工具开发全过程,有需要的小伙伴可以了解下... 目录概述功能全景1. 核心功能模块2. 特色功能效果展示1. 主界面概览2. 定时任务配置3. 操作日志演示