数字IC设计工具教程——VCS(lab1 VCS Simulation Basics)

2023-11-06 10:59

本文主要是介绍数字IC设计工具教程——VCS(lab1 VCS Simulation Basics),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数字IC设计工具教程——VCS(lab1)

参考:Synopsys VCS lab1

注:VCS(Verilog Compile Simulator)

文章目录

  • 数字IC设计工具教程——VCS(lab1)
    • 注:VCS(Verilog Compile Simulator)
    • Getting Started
    • Part A: 两步仿真流程
      • Task 1: 编译生成仿真可执行文件
      • Task 2: 运行仿真
      • Task 3: 检查仿真结果
      • Task 4: 用不同的名称创建仿真可执行文件
    • Part B: 使用库目录
      • Task 1: 用设计的库目录编译&仿真
      • Task 2: 用"-f File"开关编译

Getting Started

本实验使用以下8bit进位选择加法器:
在这里插入图片描述
我们的目标是使用这个简单的设计来了解两步VCS仿真过程的基础。 本实验分为三个部分。 每个部分都有其自己的关联任务。 这是将要做的事情的预览:

  • 编译加法器Verilog源文件以生成仿真可执行文件。
  • 通过执行仿真可执行文件来仿真8位加法器。
  • 解释控制台上显示的仿真结果,以确定8位加法器是否正常工作。
  • 在A部分中,8位加法器的所有Verilog源文件都位于工作目录中。
  • 在B部分中,一些8位加法器的Verilog源文件在工作目录中,其余的在库目录中。 您将对其进行编译,然后使用编译时文件来简化VCS编译命令行键入。

在这里插入图片描述

Part A: 两步仿真流程

Task 1: 编译生成仿真可执行文件

在lab1的A部分中,所有8位进位选择加法器的Verilog源文件都位于lab1工作目录中。登录到工作站后,进入lab1 Part A目录。

1. shell> cd VCS_labs/lab1/parta

应该看到4个文件:fa.v,add4.v,add8.v和addertb.v

2. shell> ls

fa.v,add4.v和add8.v是图1-1中块的Verilog源文件,addertb.v是用来检验加法器功能的testbench。

编译Verilog文件并生成simv仿真二进制可执行文件。

3. shell> vcs -full64 addertb.v fa.v add4.v add8.v

当编译完成,将会看到下面信息:
在这里插入图片描述
当编译完成后,所在的目录文件中会产生csrcsimvsimv.daidir三个文件,其中simv是编译后的仿真可执行文件。
在这里插入图片描述

Task 2: 运行仿真

运行testbench并通过执行simv来仿真设计。

1. shell> simv

当仿真结束,将看到下面信息:
在这里插入图片描述
表明仿真已经结束,仿真时的CPU用时与存储占用空间情况也会被报告。

Task 3: 检查仿真结果

通过嵌入在testbench中的Verilog系统任务调用,上面的报告中将会看到下面的打印输出。

*** Testbench Successfully completed!***

这验证了执行是成功的!在lab2中我们将看到如何生成信息来帮助我们debug代码错误。

Task 4: 用不同的名称创建仿真可执行文件

VCS默认的仿真可执行文件名是simv。我们可以使用–o开关引导VCS生成不同的可执行文件名称。

编译Verilog文件并生成addertest仿真二进制可执行文件。

shell> vcs -full64 addertb.v fa.v add4.v add8.v -o addertest

Part B: 使用库目录

Task 1: 用设计的库目录编译&仿真

在lab1的Part B,我们把fa.vadd4.v移动到库目录(lib)。新的文件目录结构如下所示。
在这里插入图片描述
切换到lab1 Part B工作目录。只有两个文件add8.vaddertb.v。再一次编译设计,这次,我们需要参考库目录(lib)文件。

可以将–R开关作为速记,在编译后立即执行仿真。

shell> vcs -full64 addertb.v add8.v –y ../../lib +libext+.v -R

注意,由于我们的库文件具有.v扩展,因此需要+libext开关才能让vcs搜索.v扩展文件。

源文件内容没有改变,只有文件的物理位置发生了变化,应该看到与Part A相同的仿真结果。

Task 2: 用"-f File"开关编译

使用–f编译时间开关简化命令行输入。 首先创建一个包含设计的所有源文件或库名称的文件。 在编译设计时,用–f开关参考该文件。

使用gvim创建文件"adder.f"包含下列文件。

addertb.v
add8.v
-y ../../lib +libext+.v

-f开关编译并仿真设计,如下所示。

shell> vcs -full64 -f adder.f -R

编译仿真结果和之前的一样。

这篇关于数字IC设计工具教程——VCS(lab1 VCS Simulation Basics)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java中的工具类命名方法

《Java中的工具类命名方法》:本文主要介绍Java中的工具类究竟如何命名,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java中的工具类究竟如何命名?先来几个例子几种命名方式的比较到底如何命名 ?总结Java中的工具类究竟如何命名?先来几个例子JD

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删

如何为Yarn配置国内源的详细教程

《如何为Yarn配置国内源的详细教程》在使用Yarn进行项目开发时,由于网络原因,直接使用官方源可能会导致下载速度慢或连接失败,配置国内源可以显著提高包的下载速度和稳定性,本文将详细介绍如何为Yarn... 目录一、查询当前使用的镜像源二、设置国内源1. 设置为淘宝镜像源2. 设置为其他国内源三、还原为官方

Maven的使用和配置国内源的保姆级教程

《Maven的使用和配置国内源的保姆级教程》Maven是⼀个项目管理工具,基于POM(ProjectObjectModel,项目对象模型)的概念,Maven可以通过一小段描述信息来管理项目的构建,报告... 目录1. 什么是Maven?2.创建⼀个Maven项目3.Maven 核心功能4.使用Maven H

Python实现特殊字符判断并去掉非字母和数字的特殊字符

《Python实现特殊字符判断并去掉非字母和数字的特殊字符》在Python中,可以通过多种方法来判断字符串中是否包含非字母、数字的特殊字符,并将这些特殊字符去掉,本文为大家整理了一些常用的,希望对大家... 目录1. 使用正则表达式判断字符串中是否包含特殊字符去掉字符串中的特殊字符2. 使用 str.isa

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

基于Java实现回调监听工具类

《基于Java实现回调监听工具类》这篇文章主要为大家详细介绍了如何基于Java实现一个回调监听工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录监听接口类 Listenable实际用法打印结果首先,会用到 函数式接口 Consumer, 通过这个可以解耦回调方法,下面先写一个

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的