【数字IC设计】VCS门级网表仿真

news2024/11/19 16:47:21

本文参考自文章。
除了RTL仿真以外,在IC设计过程中还会进行门级网表的仿真。当设计代码功能仿真通过之后,我们便使用Design Compiler工具对其进行逻辑综合,将RTL代码转化为由与、或、非等门电路和触发器组成的电路,称为门级网表(netlist)。门级网表中包含了电路的实际信息,例如逻辑门单元的扇入扇出系数,延迟等等。对门级网表进行仿真可以发现由于引入这些实际信息所暴露出的错误,因此是必要的。
本文以一个alu设计为例,演示门级网表仿真的流程。

rtl代码

编写的rtl代码如下所示,它是一个简单的alu运算器,支持加、减、乘和比较等运算。

module alu
(
   input  wire        clk,
   input  wire        rst_n,
   input  wire        en,
   input  wire [1:0]  op,
   input  wire [31:0] A,
   input  wire [31:0] B,
   output reg  [31:0] Out
);

always@(posedge clk or negedge rst_n) begin
    if(~rst_n) begin
        Out <= 32'd0;
    end
    else if(en) begin
        case(op)
            2'd0 : Out <= A + B;
            2'd1 : Out <= A - B;
            2'd2 : Out <= A * B;
            2'd3 : Out <= (A > B) ? 32'd1 : 32'd0;
        endcase
    end
end
endmodule

逻辑综合

编写如下综合脚本,这里需要输出门级网表和sdf文件。

set_app_var search_path /home/eda/Desktop/alu/digital_lib/TSMC_013/synopsys
set_app_var target_library slow.db
set_app_var link_library slow.db
read_file -format verilog {./alu.v}
check_design
create_clock -period 10 [get_ports clk]
set_input_delay -max 3 -clock clk [remove_from_collection [all_inputs] clk]
set_output_delay -max 2.5 -clock clk [all_outputs]
set_input_transition 0.15 [all_inputs]
check_design
compile
report_clock
report_timing
report_area
write_sdc alu.sdc
write_sdf -version 2.1 alu.sdf
write_file -format verilog -output alu_netlist.v

输入dc,然后source run.tcl开始综合。综合完成后,可以得到alu.sdf文件和alu_netlist.v文件。
SDF文件(Standard Delay File)提供了延迟信息表示的标准ASCII文件格式,VCS支持版本1.0、1.1、2.0、2.1和3.0。在SDF格式中可以指定固有延迟(intrinsic delays),互连延迟(interconnect delays),端口延迟(port delays),时序检查(timing checks),时序约束(timing constraints)和路径脉冲(PATHPULSE)。
下面是alu.sdf的一部分:
在这里插入图片描述
下面是alu_netlist文件的一部分:
在这里插入图片描述

门级网表仿真

为了对门级网表进行仿真,编写如下tb:

module alu_tb;

reg         clk;
reg         rst_n;
reg         en;
reg  [1:0]  op;
reg  [31:0] A;
reg  [31:0] B;
wire [31:0] Out;

initial begin
   clk = 1'b0;
   forever begin
       #5 clk = ~clk;
   end
end

initial begin
   rst_n = 1'b0;
   #100
   rst_n = 1'b1;
end

always@(posedge clk or negedge rst_n) begin
   if(~rst_n) begin
       en <= 1'b0;
       op <= 2'b0;
       A  <= 32'd0;
       B  <= 32'd0;
   end
   else if({$random} % 100 <60) begin
       en <= 1'b1;
       op <= {$random} % 4;
       A  <= {$random} % 1024;
       B  <= {$random} % 1024;
   end
   else begin
       en <= 1'b0;
   end
end

initial begin
    $fsdbDumpfile("alu.fsdb");
    $fsdbDumpvars(0);
end

initial begin
`ifdef NET_SIM
    $sdf_annotate("./alu.sdf",
    alu,,,
    "TYPICAL",
    "1:1:1",
    "FROM_MTM");
`endif
end

initial begin
   #1000
   $finish;
end

alu alu_inst
(
  .clk  (clk  ),
  .rst_n(rst_n),
  .en   (en   ),
  .op   (op   ),
  .A    (A    ),
  .B    (B    ),
  .Out  (Out  )
);

endmodule

与rtl仿真不同的是,在门级网表仿真时,需要使用$sdf_annotate系统任务读取SDF文件,并将延迟值“反向标注(back-annotates)”到设计中,即在源文件中添加或者更改延迟值。该函数的详细使用可以参见文章。
然后,编写仿真的makefile脚本:

OUTPUT = alu
CM = -cm line+cond+fsm+branch+tgl
CM_NAME = -cm_name ${OUTPUT}
CM_DIR = -cm_dir ./${OUTPUT}.vdb
LIB_FILE = -v ./digital_lib/TSMC_013/verilog/tsmc13.v

all: listfile com sim verdi clean

listfile:
	find -name "*.v" > filelist.f

com:
	vcs -full64 -cpp g++-4.8 -cc gcc-4.8 -LDFLAGS -Wl,--no-as-needed \
	-sverilog -debug_access -timescale=1ns/10ps \
	-f filelist.f -l com.log -kdb -lca +define+NET_SIM +neg_tchk \
	${CM} ${CM_NAME} ${CM_DIR} ${LIB_FILE}

sim:
	./simv -l sim.log ${CM}	${CM_NAME} ${CM_DIR}

cov:
	dve -full64 -covdir *.vdb &

urg:
	urg -dir *.vdb

verdi:
	verdi -f filelist.f -ssf *.fsdb -nologo &

clean:
	rm -rf csrc *.log *.key *simv* *.vpd *DVE*
	rm -rf verdiLog *.fsdb *.bak *.conf *.rc *.f

上述代码中,我们在makefile文件中添加了一个开关选项,由于网表.v文件是由工艺库单元例化的,工艺库中给出了一个verilog文件,包含各个单元。
运行make com; make sim; make verdi,得到如下仿真波形:
在这里插入图片描述
由图可知,输出相对于时钟上升沿有一定的延迟,这是门级网表仿真和rtl仿真不同的地方。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1095063.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

25栈和队列-理解栈和队列

目录 LeetCode之路——232. 用栈实现队列 分析&#xff1a; LeetCode之路——225. 用队列实现栈 分析&#xff1a; 栈&#xff08;Stack&#xff09;和队列&#xff08;Queue&#xff09;是两种基本的数据结构&#xff0c;它们在计算机科学中用于不同的目的。以下是它们的定…

【传输层协议】UDP/TCP结构特点与原理(详解)

文章目录 1. UDP1.1 UDP结构1.2 UDP特点1. 无连接2. 不可靠3. 面向数据报4. 缓冲区5. 大小受限6. 无序性 2. TCP2.1 TCP结构2.2 TCP特点1. 有连接2. 可靠性3. 面向字节流4. 拥塞控制5. 头部开销 2.3 TCP原理1. 确认应答&#xff08;安全机制&#xff09;2. 超时重传&#xff08…

Ceph分布式存储的简单介绍与Ceph集群的部署搭建

文章目录 1. 存储的概述1.1 单机存储设备1.1.1 DAS&#xff08;直接附加存储&#xff09;1.1.2 NAS&#xff08;网络附加存储&#xff09;1.1.3 SAN&#xff08;存储区域网络&#xff09; 1.2 单机存储的缺陷1.3 分布式存储&#xff08;软件定义的存储 SDS&#xff09;1.4 分布…

【计算机网络笔记】数据交换之报文交换和分组交换

系列文章目录报文交换分组交换存储-转发报文交换 vs 分组交换总结 系列文章目录 什么是计算机网络&#xff1f; 什么是网络协议&#xff1f; 计算机网络的结构 数据交换之电路交换 报文交换 报文&#xff1a;源&#xff08;应用&#xff09;发送的信息整体。比如一个文件、一…

Transformer 中 Positional Encoding 实现

参考博文&#xff1a; https://www.cnblogs.com/nickchen121/p/16470736.html 解决问题 位置编码的主要目的是确保模型能够理解序列中的元素之间的相对位置和顺序&#xff0c;从而更好地捕捉到语义信息。在Transformer模型中&#xff0c;位置编码通常与词嵌入&#xff08;w…

前端小知识之【浏览器内核】

目录 &#x1f31f;前言&#x1f31f;PC端浏览器内核&#x1f31f;Trident内核&#x1f31f;Gecko内核&#x1f31f;WebKit内核(Chromium)&#x1f31f;Blink内核 &#x1f31f;移动端浏览器内核&#x1f31f;应用&#x1f31f;写在最后 &#x1f31f;前言 通常所谓的浏览器内…

docker安装nessus

注册地址:https://zh-tw.tenable.com/products/nessus/nessus-essentials 临时邮箱:http://24mail.chacuo.net/ 帮助文档:https://docs.tenable.com/nessus/Content/DeployNessusDocker.htmdocker pull tenableofficial/nessusdocker run --name "my-nessus" -d -p 8…

【Go入门】编程语言比较:Golang VS Python

Golang&#xff1a;最佳人工智能语言&#xff0c;性能优于 Python 本节是学习go的引入&#xff0c;为了了解Python与go编程语言间比较。后续会完成相关课程&#xff0c;并分享笔记。 如今&#xff0c;世界各地有数百万用户使用 Golang 作为机器学习和人工智能的编程语言。 最好…

算法通过村第十四关-堆|白银笔记|经典问题

文章目录 前言在数组中寻找第K大的元素堆排序原理合并K个排序链表总结 前言 提示&#xff1a;想要从讨厌的地方飞出来&#xff0c;就得有藏起来的翅膀。 --三岛由纪夫《萨德侯爵夫人》 这里我们主要看一下经典的题目&#xff0c;这三个题目来说都是堆的热点问题。重点再理解处理…

Qt不能安装自己想要的版本,如Qt 5.15.2

使用在线安装工具安装Qt5.15.2时&#xff0c;发现没有Qt 5的相关版本&#xff0c;只有Qt 6的版本&#xff0c;这时选择右边的Archive&#xff0c;再点击筛选&#xff0c;这时就会出现之前的Qt版本。

vscode插件路径转移C盘之外盘

改变vscode系统路径 最近C盘路径不够了&#xff0c;网上的工具使用没那么精细&#xff0c;还不如自己手动看每个文件夹大小。在整理过长遇到vscode插件路径转移&#xff0c;方法如下&#xff1a; 桌面图标右键点击属性 改变–extensions-dir后面参数就可以了。

Web3 整理React项目 导入Web3 并获取区块链信息

上文 WEB3 创建React前端Dapp环境并整合solidity项目&#xff0c;融合项目结构便捷前端拿取合约 Abi 我们用react 创建了一个 dapp 项目 并将前后端代码做了个整合 那么 我们就来好好整理一下 我们的前端react的项目结构 我们在 src 目录下创建一个 components 用来存放我们的…

Python学习----Day07

函数 函数是组织好的&#xff0c;可重复使用的&#xff0c;用来实现单一&#xff0c;或相关联功能的代码段。函数能提高应用的模块性&#xff0c;和代码的重复利用率。你已经知道Python提供了许多内建函数&#xff0c;比如print()。但你也可以自己创建函数&#xff0c;这被叫做…

C++ 程序员入门需要多久,怎样才能学好?

文章目录 C学习方案有哪些推荐的在线教程或学习资源可以帮助我学习C编程&#xff1f;你能给我一些关于C内存管理的进阶学习资源吗&#xff1f; AI解答 C学习方案 C是一种功能强大且广泛应用的编程语言&#xff0c;作为一个初学者&#xff0c;学习C需要一定的时间和努力。学习…

【java学习—七】对象的实例化过程(33)

文章目录 1. 简单类对象的实例化过程2. 子类对象的实例化过程 1. 简单类对象的实例化过程 2. 子类对象的实例化过程

YOLO目标检测——打电话数据集【含对应voc、coco和yolo三种格式标签】

实际项目应用&#xff1a;安全监控、智能驾驶、人机交互、智能城市数据集说明&#xff1a;YOLO目标检测数据集&#xff0c;真实场景的高质量图片数据&#xff0c;数据场景丰富。使用lableimg标注软件标注&#xff0c;标注框质量高&#xff0c;含voc(xml)、coco(json)和yolo(txt…

快速学习MyBatisPlus

文章目录 前言一、条件构造器和常用接口1.wapper介绍2.QueryWrapper&#xff08;1&#xff09;组装查询条件&#xff08;2&#xff09;组装排序查询&#xff08;3&#xff09;组装删除查询&#xff08;4&#xff09;条件优先级&#xff08;5&#xff09;组装select子句&#xf…

c++命名空间,缺省参数,引用

首先为了解决命名冲突&#xff0c;c提出了命名空间这一功能 比如using namespace std; 就是使用std&#xff08;c官方库定义的命名空间&#xff09;这个命名空间里面的命名。 using就可以直接指定本文件用那个命名空间。 也可以用::域作用限定符 如std::cin>> 并且会…

Linux网络编程系列之服务器编程——信号驱动模型

一、什么是信号驱动模型 在服务器中&#xff0c;信号驱动模型是一种事件处理模型&#xff0c;它能够异步地响应来自外部的事件。服务器可以注册一组回调函数&#xff0c;来处理来自客户端或其他进程的信号或事件&#xff0c;当信号或事件触发时&#xff0c;操作系统会通知服务器…

云耀服务器L实例部署Nextcloud企业云盘系统|华为云云耀云服务器L实例评测使用体验

文章目录 Nextcloud简介1.1 部署华为云云耀服务器L实例1.1.1 云耀服务器L实例购买1.1.2 云耀服务器L实例初始化配置1.1.3 远程登录云耀服务器L实例 2. 云耀服务器L实例中间件部署2.1 安装配置环境2.1.1 安装基本工具2.1.2 安装MariaDB2.1.3 安装Nginx2.1.4 安装PHP 3. 安装Next…