答疑 | 如何解决“LVS验证时Source端网表未定义SUBCKT”的问题

在某些工艺的LVS运行过程中,会弹出 “Source端网表未定义subcket” 的警告框,如下图所示:

兔二思
兔二思
技术博主

问题描述

在某些工艺的LVS运行过程中,会弹出 “Source端网表未定义subcket” 的警告框,如下图所示:

图片

⚠ Warning

⚠ Problems encountered when checking source netlist

⚠ Source netlist references but does not define 1 subckts: n33_mis_ckt

如果你点击「Proceed」继续往下,Error 提示**无法读取电路。**更多详细的报错说明如下:

图片

解决方案

出现这个 Warning 的根本原因是,Source 端导出的CDL网表文件不完整,缺少了 “n33_mis_ckt” 器件的定义,因此存在语法错误

在代工厂提供的PDK中,有些工艺会在 Calibre 文件夹中,附上一份自定义器件的定义文件。这是为了符合Calibre Command的语法要求加入的文件,例如:empty_subckt.sp、3t_device.cdl

图片

你也可以从PDK的说明文档中看到解释。这里有一份 CSMC 的PDK说明文件,如下:

图片

其中 Subcircuit 一行解释了此文件的用途。按照要求,需将其添加到 Include File 中。也就是CDL网表应包含 “3t_device.cdl” 文件才完整

图片

接下来介绍添加文件的方法。

比较常见的一些做法是

1)可以使用Cadence自己的CDL导出工具,在Include选项处加上此文件

2)还可以,使用集成的Calibre工具进行 Netlist Export 的设置

上述两种方法,都可以用于添加Include文件。但是有个缺点,在每次使用时需要重新设置一遍,无法永久记住配置信息。

那么,如何自动地向CDL网表添加empty_subckt. sp****文件并记住这些设置呢?

我这里选用 Calibre Interactive 交互式工具进行设置:

👉**【步骤1】**

在 Calibre Interactive 界面,标题栏处选择「Setup」-「Preferences…

图片

👉**【步骤2】**

弹出 “Setup Preferences” 对话框,选择子选项卡「Templates」-「Inputs

图片

👉**【步骤3】**

在 “Source Path” 处,添加Include File的路径

图片

直接在%s.src.net文本后面输入。如

%
s.src.net
"/root/PDKs/.../empty_subckt.sp"

其中,引号中的内容是 empty_subckt.sp 文件的路径地址,且两者中间有一个空格。

接着,你可以把设置信息保存成相应工艺专用的Runset文件,然后重新启动一遍 Calibre 运行即可。

完整的操作演示

👇👇👇

图片

-End-

Virtuoso 实战答疑 系列

01 :指定每次调用VIA时的类型和个数

点赞鼓励一下

图片

#答疑分享#Virtuoso