数字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

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

Java Scanner类解析与实战教程

《JavaScanner类解析与实战教程》JavaScanner类(java.util包)是文本输入解析工具,支持基本类型和字符串读取,基于Readable接口与正则分隔符实现,适用于控制台、文件输... 目录一、核心设计与工作原理1.底层依赖2.解析机制A.核心逻辑基于分隔符(delimiter)和模式匹

spring AMQP代码生成rabbitmq的exchange and queue教程

《springAMQP代码生成rabbitmq的exchangeandqueue教程》使用SpringAMQP代码直接创建RabbitMQexchange和queue,并确保绑定关系自动成立,简... 目录spring AMQP代码生成rabbitmq的exchange and 编程queue执行结果总结s

基于Python实现数字限制在指定范围内的五种方式

《基于Python实现数字限制在指定范围内的五种方式》在编程中,数字范围限制是常见需求,无论是游戏开发中的角色属性值、金融计算中的利率调整,还是传感器数据处理中的异常值过滤,都需要将数字控制在合理范围... 目录引言一、基础条件判断法二、数学运算巧解法三、装饰器模式法四、自定义类封装法五、NumPy数组处理

MySQL慢查询工具的使用小结

《MySQL慢查询工具的使用小结》使用MySQL的慢查询工具可以帮助开发者识别和优化性能不佳的SQL查询,本文就来介绍一下MySQL的慢查询工具,具有一定的参考价值,感兴趣的可以了解一下... 目录一、启用慢查询日志1.1 编辑mysql配置文件1.2 重启MySQL服务二、配置动态参数(可选)三、分析慢查

基于Python实现进阶版PDF合并/拆分工具

《基于Python实现进阶版PDF合并/拆分工具》在数字化时代,PDF文件已成为日常工作和学习中不可或缺的一部分,本文将详细介绍一款简单易用的PDF工具,帮助用户轻松完成PDF文件的合并与拆分操作... 目录工具概述环境准备界面说明合并PDF文件拆分PDF文件高级技巧常见问题完整源代码总结在数字化时代,PD

Python按照24个实用大方向精选的上千种工具库汇总整理

《Python按照24个实用大方向精选的上千种工具库汇总整理》本文整理了Python生态中近千个库,涵盖数据处理、图像处理、网络开发、Web框架、人工智能、科学计算、GUI工具、测试框架、环境管理等多... 目录1、数据处理文本处理特殊文本处理html/XML 解析文件处理配置文件处理文档相关日志管理日期和

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3