1.开源verilog仿真工具iverilog+GTKWave初体验
2.QEMU虚拟机管理器:一种高效硬件模拟器
3.如何跑通《UVM实战》书上的源源码例子?
4.SystemVerilog $unit ç¼è¯åå
ä»ç»
5.å
³äºverilog çassign
开源verilog仿真工具iverilog+GTKWave初体验
本文旨在带你体验开源的Verilog仿真工具Icarus Verilog和GTKWave。首先,码仿Icarus Verilog以其轻便性著称,淘宝兼容Windows、源源码Linux和MacOS,码仿且源代码开源。淘宝本地社工库源码它能够通过tb文件生成仿真波形数据,源源码并能将Verilog转换为VHDL格式。码仿
要开始,淘宝首先进行安装:安装Icarus Verilog后,源源码检查其版本。码仿接着,淘宝安装GTKWave,源源码同样确认版本。码仿在测试bench(tb)文件中,淘宝你需要添加相应的代码。
进入项目目录后,使用命令行编译Verilog文件,成功后会生成一个.out文件以及.vcd文件。然而,打开.vcd文件时,spring源码书可能遇到问题,特别是当文件过大时,GTKWave可能无法有效查看波形,导致卡死。此时,推荐使用lxt或转换为lxt2格式,lxt是GTKWave专有的波形格式,能更好地处理大文件。
解决完这些问题后,你可以添加波形到GTKWave中。此外,如果你需要,还能利用Icarus Verilog的功能将Verilog源文件glitch.v转换为VHDL格式,生成glitch.vhd文件,以便在不同硬件描述语言之间进行转换。
QEMU虚拟机管理器:一种高效硬件模拟器
QEMU(Quick EMUlator)是一种开源的虚拟机监视器和模拟器,支持多种硬件平台模拟,如x、ARM、PowerPC等,手机控制源码被广泛应用于虚拟化、嵌入式系统开发和仿真等领域。
作为虚拟机监视器,QEMU能在物理主机上同时运行多个虚拟机,并提供管理控制能力。它支持多种操作系统,包括Linux、Windows等。作为模拟器,QEMU可以在一个主机上执行不同架构的二进制代码,实现跨平台软件开发与测试,便于开发人员在不同体系结构下调试程序。
QEMU具备丰富的功能和扩展性,如硬件加速、网络配置、磁盘镜像和快照等,被广泛应用于云计算、容器技术、嵌入式系统仿真和移动设备开发等领域。
QEMU是TV桌面源码一款开源的模拟器及虚拟机监管器(VMM)。它主要提供两种功能:一是作为用户态模拟器,执行不同于主机架构的代码;二是作为虚拟机监管器,模拟全系统,利用其他VMM(如Xen、KVM等)实现硬件虚拟化支持,创建接近主机性能的虚拟机。
用户可通过Linux发行版的软件包管理器安装QEMU,例如在Debian系列发行版上,可使用以下命令安装:
除此之外,用户也可以选择从源码安装。
获取QEMU源码,可以从QEMU下载官网上下载QEMU源码的tar包。以命令行下载2.0版本的QEMU为例:
获取源码后,可根据需求配置和编译QEMU。configure脚本用于生成Makefile,其选项可用./configure --help查看。
安装完成后,会生成以下应用程序:
QEMU作为系统模拟器时,会模拟出一台能够独立运行操作系统的虚拟机。每个虚拟机对应主机中的c 精品源码一个QEMU进程,虚拟机的vCPU对应QEMU进程的一个线程。
系统虚拟化主要虚拟出CPU、内存及I/O设备。虚拟出的CPU称为vCPU,QEMU为了提高效率,借用KVM、XEN等虚拟化技术,直接利用硬件对虚拟化的支持,在主机上安全地运行虚拟机代码(需要硬件支持)。
虚拟机内存会被映射到QEMU的进程地址空间,在启动时分配。在虚拟机看来,QEMU所分配的主机上的虚拟地址空间为虚拟机的物理地址空间。
QEMU在主机用户态模拟虚拟机的硬件设备,vCPU对硬件的操作结果会在用户态进行模拟,如虚拟机需要将数据写入硬盘,实际结果是将数据写入主机中的一个镜像文件中。
使用qemu-img创建虚拟机镜像,虚拟机镜像用于模拟虚拟机的硬盘,在启动虚拟机之前需要创建镜像文件。
使用qemu-system-x启动x架构的虚拟机。由于test-vm-1.qcow2中并未给虚拟机安装操作系统,所以会提示“无可启动设备”。
启动VM安装操作系统镜像。指定虚拟机内存大小、使用KVM加速、添加fedora的安装镜像。安装完成后,重启虚拟机即可从硬盘启动。之后再次启动虚拟机,只需执行以下命令:
qemu-img支持多种文件格式,可通过qemu-img -h查看。其中raw和qcow2是比较常用的两种格式,raw是qemu-img命令默认的格式,qcow2是qemu目前推荐的格式,功能最多。
Qemu软件虚拟化实现的思路是采用二进制指令翻译技术,提取guest代码,然后将其翻译成TCG中间代码,最后再将中间代码翻译成host指定架构的代码。
从宏观上看,源码结构主要包含以下几个部分:
(1)开始执行:/vl.c中的main函数定义,它也是执行的起点,主要建立一个虚拟的硬件环境,通过参数解析初始化内存、设备、CPU参数等。
(2)硬件模拟:所有硬件设备都在/hw/目录下面,每个设备都有独自的文件,包括总线、串口、网卡、鼠标等。它们通过设备模块串在一起,在vl.c中的machine_init中初始化。
(3)目标机器:QEMU模拟的CPU架构有Alpha、ARM、Cris、i、MK、PPC、Sparc、Mips、MicroBlaze、SX和SH4。在QEMU中使用./configure可以配置运行的架构。
(4)主机:使用TCG代码生成主机的代码,这部分代码在/tcg/目录中,对应不同的架构,分别在不同的子目录中。
(5)文件总结:TCG动态翻译、TB链、TCG代码分析、IOCTL使用流程、内存管理等相关内容。
如何跑通《UVM实战》书上的例子?
在求职过程中,面试官常会询问关于UVM实战的学习情况,特别是是否实践过书中的例子。我最近抽空按照《UVM实战》书中的指导进行了实践,现在已经能够成功运行书中的例子。以下是关键步骤和注意事项:
首先,确保你的虚拟机上安装了VCS和Verdi工具,可以从华章网站获取《UVM实战》的源代码。在虚拟机设置中,将共享文件夹指向代码目录,以便于访问。将example_and_uvm_source_code文件夹复制到你的工作目录下。
在代码中,有两个部分需要修改。一是setup_vcs脚本,用于设置VCS和Verdi的路径。你需要根据你的实际工具路径进行调整,可能需要修改export语句格式。二是run脚本,需要添加必要的命令,如"–full",这对于位Linux系统至关重要,否则可能会遇到VCS_HOME路径错误。
为了便于debug和波形dump,我增加了dump波形相关的代码,并在top_tb文件夹中添加了输出仿真信息到test.log的命令。这样,你就可以跟踪仿真过程,查找关键信息。
经过这些步骤,你应该就能成功运行《UVM实战》中的例子了。如果你觉得这些信息有帮助,请别忘了点赞支持!我是不二鱼,祝你在学习和求职路上顺利。
SystemVerilog $unit ç¼è¯åå ä»ç»
SVä¸å¢å äºç¼è¯åå çæ¦å¿µï¼å°±æ¯ SVæºæ件ç¼è¯çæ¶åï¼ä¸èµ·ç¼è¯çæææºæ件ç¼è¯åå åå¨æ索顺åºä¸æ第ä¸ä½
举个æ å
è¿éæ们å建äºä¸¤ä¸ªå ï¼a_dpkåb_dpkï¼ï¼ä¸¤ä¸ªå ä¸çé½åªæä¸ä¸ªæå°å½æ°ï¼åæ¶moduleä¸ä¹æä¸ä¸ªæå°å½æ°ï¼ï¼æå°å½æ°ç¨äºæ示æå¨ä½ç½®ï¼
æå°ç»æå¦ä¸ï¼
image-
è¿è¡ç»æå¦ä¸ï¼
å¯ä»¥çå°æ¤æ¶æå°çæ¯å¨moduleä¸å¯¼å ¥çå
é£ä¹æ¥ä¸æ¥æ们æå¨moduleä¸å¯¼å ¥çå 注éæï¼å³æ import a_dpk::*; 注éæ
ä¸é¢è¿è¡ç»æï¼
æ¤æ¶ç»äºæå¯¼å ¥$unitç¼è¯åå åçå 容æå°åºæ¥äº
è¿ä¹å°±æ¯ä¸ºä»ä¹ ç¼è¯åå åå¨æç´¢è§åä¸æ第ä¸
é£ä¹ä¸ºä»ä¹ç¼è¯åå åå« $unit å¢ï¼æ们å¯ä»¥åæ代ç æ´æ¹ä¸ä¸
æ们æ b_dpk 注éæï¼ä½ä¾æ§å°å ¶å¯¼å ¥ï¼ççè¿è¡ç»æ
è¿éç´æ¥æ¾ç¤ºéè¯¯å¨ $unit ï¼æ许$unitåªæ¯ä¸ä¸ªå称ï¼å°±å¥½åä¸ä¾ä¸moduleå½å为 test_tb ä¸æ ·
æ ¼å¼ä¸ºï¼
è¿æ¯Cè¯è¨ä¸å¸¸ç¨çæå·§ï¼å¦æ第ä¸æ¬¡éå°å¯¼å ¥è¯å¥å°å ¶ç¼è¯å°$unitä¸ï¼å次åºç°åä¸ä¼ç¼è¯
ä¸é¢æ们å°ä¸ç¯ç¬è®°ä¸çå ç¨è¿ç§æ¹å¼ä»¿çä¸ä¸ï¼å ç»åºä¸ç¯ç¬è®°ä¸å çå 容
æ们å°æ件åå½å为 definitions.dpk ï¼å ¶ä¸åç¼ .dpk æ¯é便起ç
ä¸é¢æ¯æºç åæµè¯æ件
è¿è¡ç»æå¦ä¸
æ¬æ主è¦åè
å ³äºverilog çassign
å ³äºé®é¢è¡¥å ï¼å ¶å®å¦ææ³åèµå¼çè¯ï¼ä¸è¬é½ä¼ä¹ æ¯æ§å°å®ä¹ä¸ä¸regååéï¼ç¶åå¨alwaysè¯å¥åå ç´æ¥èµå¼å°±å¯ä»¥äºï¼ç±»ä¼¼äºï¼reg a;a=1ãå¾å°æ人å®ä¹wireååéç¶ååèµå¼çï¼wireåä¸è¬é½æ¯å¨ä¸å±æ¨¡åä¸è°ç¨ä¸å±æ¨¡åçè¾å ¥è¾åºæ¶æä¼å®ä¹çç±»åï¼ä¸è¬é½æ¯è¿æ ·ãèassignå½ä»¤ä¸è¬é½ä¹ æ¯æ§å°å½åè¿çº¿ç¨ï¼æ¯å¦æ³æä¸ä¸ªæ¨¡åçè¾åºç»å¦ä¸ä¸ªæ¨¡åå½è¾å ¥ï¼å°±å¯ä»¥assign Input=Output;
è³äºæ¶éé£ä¸¤å¥ï¼å ¶å®é£ä¸ªä¹æ¯ä¹ æ¯æ§çåæ³ï¼ä¸è¬é½ä¹ æ¯ä½¿ç¨æ¶éä¿¡å·åæ¥æ´ä¸ªæ¨¡åï¼èæ¶éä¿¡å·å°±æ¯ä»testbenchæ件ä¸ååºçãç¹å«æ¯å¯¹äºå¤§çå·¥ç¨ï¼è¿æ ·ç设å®ä¼æ¹ä¾¿å个模åä¹é´çåæ¥ãæå¯ä¸æ¯ä»ä¹å·¥ç¨å¸ï¼åªä¸è¿æ¯åå¦äºverilogä¸å¹´çç 究çèå·²ï¼åµåµ
åå¦è å§ï¼ä½ åçè¿ä¸ªæ太å¤ä¸è§èçå°æ¹= =
è½ç¶assignå¯ä»¥è¿æ ·ç¨ï¼ä¸è¿å¾å°æ人è¿ä¹åãassignç¸å½äºè¿çº¿ï¼ä¸è¬å®çç¨å¤æ¯å°ä¸ä¸ªåéçå¼ä¸é´æå°èµå¼ç»å¦å¤ä¸ä¸ªï¼å°±åæè¿ä¸¤ä¸ªåéè¿å¨ä¸èµ·ä¸æ ·ã
æ¿ä½ åäºä¸ªtestbenchï¼åºè¯¥è¿ç®æ¯æ¯è¾è§èçï¼ä½ å¯ä»¥åèæçæ¹ä¸ä¸ãå¦æè¿ä¸è¡çè¯ä½ æä½ çæºä»£ç ç»ææå¯ä»¥å¸®ä½ çä¸ä¸
`timescale 1ns / 1ps
////////////////////////////////////////////////////////////////////////////////
// Company:
// Engineer:
//
// Create Date: :: //
// Design Name: tb_binseg
// Module Name: D:/Xilinx/.1/myproject/test/testbench.v
// Project Name: test
// Target Device:
// Tool versions:
// Description:
//
// Verilog Test Fixture created by ISE for module: tb_binseg
//
// Dependencies:
//
// Revision:
// Revision 0. - File Created
// Additional Comments:
//
////////////////////////////////////////////////////////////////////////////////
`timescale 1ns / 1ps
////////////////////////////////////////////////////////////////////////////////
// Company:
// Engineer:æåç±³é£æº
//
// Create Date: :: //
// Design Name: test
// Module Name: D:/Xilinx/.1/myproject/convolution/convolutiontest.v
// Project Name: convolution
// Target Device:
// Tool versions:
// Description:
//
// Verilog Test Fixture created by ISE for module: convolution
//
// Dependencies:
//
// Revision:
// Revision 0. - File Created
// Additional Comments:
//
////////////////////////////////////////////////////////////////////////////////
module test;
// Inputs
reg clk;
reg din;
reg en;
// Outputs
wire dout;
// Instantiate the Unit Under Test (UUT)
binseg tb(
.din(din),
.en(en),
.dout(dout));
initial begin
// Initialize Inputs
clk=0;
din=0;
en=1;
// Wait ns for global reset to finish
#;
en=0;
// Add stimulus here
end
always #4 Clk=~Clk;
always@(posedge clk)
begin
if(din<=4'b)
begin
din=din+1;
end
else
begin
din=0;
end
end
endmodule