linux下开发verilog环境,iverilog_module

2023-10-21 09:30

本文主要是介绍linux下开发verilog环境,iverilog_module,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

linux下使用iverilog仿真verilog易用版本

该项目是提供一个在linux使用iverilog+gtkwave的项目模板,用于快速新建项目和仿真项目。

没使用过的iverilog的请点击此处

优势

虽然iverilog只能仿真,但是仿真速度很快,对于比较小的模块或者中型项目的验证,完全可以使用iverilog进行前期开发,以提高开发效率。

轻量

免费

环境配置简单

在本模板上易用

文件说明

.

├── db.dat 记录上次仿真项目,用于重复仿真时直接运行仿真项目

├── imgs 一些图片

│   ├── 20200415-140023.png

│   ├── 20200421-231449.png

│   ├── 20200421-232012.png

│   ├── 20200421-232053.png

│   └── 20200421-232159.png

├── LICENSE

├── main 提供仿真项目引导的shell脚本

├── module 所有仿真项目放在该路径下,一个项目一个文件夹

│   ├── counter 计数器项目

│   │   ├── counter.v

│   │   ├── readme.md

│   │   └── tb.v

│   ├── crc crc循环冗余校验项目呢

│   │   ├── CRC_7.v

│   │   ├── readme.md

│   │   └── tb_crc7.v

│   ├── decode38 38译码器项目

│   │   ├── decode38.v

│   │   ├── readme.md

│   │   └── tb_decode38.v

│   ├── idata 测试项目

│   │   ├── idata1.v

│   │   ├── idata2.v

│   │   ├── tb_idata.v

│   │   └── topdata.v

│   ├── led 简单分频器项目

│   │   ├── readme.md

│   │   ├── tb_led.v

│   │   └── top.v

│   └── 说明.txt

├── README.md

├── run 命令执行仿真指定项目

├── .shell 存放一些其他的shell脚本

│   └── test.sh

├── sim 仿真文件和结果

│   ├── ans.txt

│   ├── tb

│   ├── tb_led.v

│   ├── tb.lxt2

│   └── top.v

└── .TCL 存放一些其他tcl脚本

├── clk.tcl

├── main.tcl

├── verilog2tcl.tcl

└── vfile.v

上面的 .TCL 和 .shell 是隐藏文件夹!

环境安装

在deepin或者ubuntu上,使用命令安装。

使用sudo apt-get install iverilog安装iverilog。

使用sudo apt-get install gtkwave安装波形查看工具。

vscode选择性安装

使用

cd iverilog_module

./main

根据提示选择需要仿真的项目

772c1dd53a8134f559e8aa868352474a.png

c3631d93a1ec53b839a269187f8e7000.png

run脚本方式使用

例如我们要仿真crc7,crc7所在路径为./module/crc ,则使用方法为

cd iverilog_module

执行脚本 ./run -d ./module/crc

这样项目就会开始仿真

8b89703a4278f306f0f6d8811834a0b3.png

终端输入./run -h显示帮助

1d61e3fb84ccf799d073092579d814bc.png

格式说明

每个仿真项目可添加一个readme.md文件作为自身项目的说明,如果项目要在main脚本下显示简短功能说明则要按一下方式写。

0a7a21a498b8944b1269c2ae2244cd78.png

fab0930938b1dd3492d1610fcd5f9cd5.png

修改说明

2020.6.4修改说明

1.添加在分项目中子文件夹下面放置verilog的文件,仿真时将会一并拷贝到sim文件夹。

2.添加隐藏除了正在调试的工程之外的所有工程,减少调试时视觉上的影响。

Usage: run [para]

run -d dir 仿真dir目录

run -i dir 在指定文件夹生成testbech模板,不存在路径则先创建路径

run -f file 运行单.v文件分析

run 仿真上次仿真的目录

run -h 显示帮助

run -r 刷新仿真数据,不在重新开启新的gtkwave

run -hide 隐藏除了正在调试所有工程问价夹(module路径下的文件夹)

run -unhide 显示所有隐藏的工程文件夹(module路径下的)

没有加入环境变量时,上面的run用 ./run代替。

2020.6.24

增加任意分频器的模板,使用方法同 生成testbech模板一样。

yhp@yhp-PC /m/y/_/F/iverilog_module> ./run -h

Usage: run [para]

run -d dir仿真dir目录

run -i dir在指定文件夹生成testbech模板,不存在路径则先创建路径

run -f file 运行单.v文件分析

run 仿真上次仿真的目录

run -h 显示帮助

run -r 刷新仿真数据,不在重新开启新的gtkwave

run -clk dir在指定文件夹生成任意分频器的模板divide.v,不存在路径则先创建路径

run -hide 隐藏除了正在调试所有工程问价夹(module路径下的文件夹)

run -unhide 显示所有隐藏的工程文件夹(module路径下的)

例如我要在module/mclk下生成分频器,则执行./run -clk module/mclk,当然首先得在项目路径下!

78ce2348818b7c70de364ab9c4fcd840.png

生成的divide.v这个分频器文件,将会时钟输出50%占空比的波形,设置分频数N和分频器计数器位宽可以实现1-N分频。以下为其中的部分代码:

`timescale 1ns / 1ps

// ********************************************************************

//FileName: divide.v

//Author:hpy

//Email:yuan_hp@qq.com

//Date:2020年06月18日

//Description:任意整数时钟分频

// --------------------------------------------------------------------

module divide#(

parameter WIDTH = 3, //计数器的位数,计数的最大值为 2**WIDTH-1

parameter N = 3 //分频系数,请确保 N < 2**WIDTH-1,否则计数会溢出

) (

input clk,

input rst_n,

output clkout

);

我们再使用./run -i module/mclk生成testbech仿真模板,对其稍加修改,将divide.v进行例化!

8d91be5e6e3bf39190b87bd308e9abc1.png

然后在 module/mclk路径下的tb.v中例化divide模块,如下:

//生成始时钟

parameter NCLK = 4;

initial begin

clk=0;

forever clk=#(NCLK/2) ~clk;

end

/****************** BEGIN ADD module inst ******************/

//Modulenamme top (rst,clk);

divide divide(

.clk(clk),

.rst_n(rst)

);

/****************** BEGIN END module inst ******************/

然后执行 ./run -d module/mclk对该项目进行仿真,并打开gtkwave查看波形!

yhp@yhp-PC /m/y/_/F/iverilog_module> ./run -d module/mclk

INFO: 当前仿真的目录为 module/mclk

LXT2 info: dumpfile wave.lxt2 opened foroutput.

运行结束!

8157f0acda051b4734a4f7a04f9d33c4.png

2020.12.1

添加了一个使用verilog实现的cpu,在module文件夹下的mini-mcu的readme.md文件有比较详细的介绍。能够实现汇编编译代码,生成带有数据的程序存储器,并自动根据使用的命令裁剪cpu。

项目下存在的仿真模块

---------------iverilog仿真项目menu---------------

1.任意bcd计数器

2.呼吸灯

3.仿真计数器

4.仿真7位CRC

5.仿真38译码器

6.led流水灯

7.序列检测状态机示例

8.这是一个简单的分频器

9.模板生成任意分频器的示例

10.自动售货机(三段式状态机)

11.三人表决器

12.FIFO实现

13.这是一个学习verilog基础语法的例子合集

14.实现一个可裁剪的处理器(mini-mcu)

15.单脉冲发生器

----------------

这篇关于linux下开发verilog环境,iverilog_module的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

nginx-rtmp-module模块实现视频点播的示例代码

《nginx-rtmp-module模块实现视频点播的示例代码》本文主要介绍了nginx-rtmp-module模块实现视频点播,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录预置条件Nginx点播基本配置点播远程文件指定多个播放位置参考预置条件配置点播服务器 192.

在Mysql环境下对数据进行增删改查的操作方法

《在Mysql环境下对数据进行增删改查的操作方法》本文介绍了在MySQL环境下对数据进行增删改查的基本操作,包括插入数据、修改数据、删除数据、数据查询(基本查询、连接查询、聚合函数查询、子查询)等,并... 目录一、插入数据:二、修改数据:三、删除数据:1、delete from 表名;2、truncate

基于Python开发PPTX压缩工具

《基于Python开发PPTX压缩工具》在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,不便于传输和存储,所以本文将使用Python开发一个PPTX压缩工具,需要的可以了解下... 目录引言全部代码环境准备代码结构代码实现运行结果引言在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,

Linux环境变量&&进程地址空间详解

《Linux环境变量&&进程地址空间详解》本文介绍了Linux环境变量、命令行参数、进程地址空间以及Linux内核进程调度队列的相关知识,环境变量是系统运行环境的参数,命令行参数用于传递给程序的参数,... 目录一、初步认识环境变量1.1常见的环境变量1.2环境变量的基本概念二、命令行参数2.1通过命令编程