Cummings的《Simulation and Synthesis Techniques for Asynchronous FIFO Design》,经过自己的一些改变,理论部分为转载,代码自己完成。 换一种描述方法: verilog代码实现就一句:assign gray_code = (bin_code>>1) ^ bin_code; 使用gray码解决了一个问题,但同时也带来另一个问题, ]),rd_addr_gray_d2[addr_width-2:0]}) ;//高两位不同 assign empty = ( rd_addr_gray == wr_addr_gray_d2 ); 五、Verilog
1.信号命名规则 信号命名规则在团队开发中占据着重要地位,统一、有序的命名能大幅减少设计人员之间的冗余工作,还可便于团队成员代码的查错和验证。 Verilog HDL 语言关键字与其它任何字符串之间都应当保留一个空格。如: always @ ( ...... ) 使用大括号和小括号时,前括号的后边和后括号的前边应当留有一个空格。 DataOut + 4'b0001; end //end always 模块 不同层次之间的语句使用Tab 键进行缩进,每加深一层缩进一个Tab;在endmodule,endtask,endcase 等标记一个代码块结束的关键词后面要加上一行注释说明这个代码块的名称 4.模块调用规范 如3.2.2 节所述,在Verilog 中,有两种模块调用的方法,一种是位置映射法,严格按照模块定义的端口顺序来连接,不用注明原模块定义时规定的端口名,其语法为: 被调用模块名 用户自定义调用名 因此,在良好的代码中,严禁使用位置调用法,全部采用信号映射法。
我们以一个简单的加法器为例,来看下如何用vcs+verdi仿真Verilog文件并查看波形。
在verilog编写代码时,可能模块列表太长,或者变量定义列表太长,不容易看到代码的重点。用代码折叠功能可以大方便的看代码、编写代码的效率。 配置方法 下面是emacs自带hide/show的配置方法,verilog-mode除了默认的module port列表、注释等折叠规则,需要再定义几个折叠关键词,比如begin/end、task/endtask ;; define verilog hide/show keywords (setq hs-special-modes-alist (cons '(verilog-mode "\\<begin\\ ) hs-special-modes-alist)) (add-hook 'verilog-mode-hook 'hs-minor-mode) 菜单和快捷键 配置好后,当打开verilog文件时 add-to-list 'load-path "~/.emacs.d/fold-this.el") (require 'fold-this) 配置好之后,选中一段文字,再执行M-x fold-this,就可以看到这段代码被折叠了
Verilog语言和VHDL语言是两种不同的硬件描述语言,但并非所有人都同时精通两种语言,所以在某些时候,需要把Verilog代码转换为VHDL代码。 上图是把转换成VHDL格式的代码,再转换回verilog后与原代码对比的图,可以看出,一些注释之类的信息都没有了,原来的代码规范和风格也发生了变化。 笔者之前就曾试着写过Verilog转VHDL代码的工具,见:Verilog HDL代码转VHDL代码,无奈因为不是软件开发出身,写出来的东西通用性和完善性很差。 Xhdl软件转换后状态机的问题 含有状态机的Verilog代码被xhdl软件转换后会出现两种情况: 1、当verilog代码中parameter常量写在紧挨着端口位置时,xhdl软件会将其转换为vhdl 对于原verilog代码中default后没有任何表达式的情况,在vhdl中对应的地方写上“null”,如图: ?
定义:流水线设计就是将组合逻辑分割,并在各级之间插入寄存器,暂存中间数据的方法。以面积换速度。
所以这篇文章是写给一些刚开始学习FPGA、Verilog HDL的同学,我看过一些大神写的代码,然后尽量模仿大神写法,经过好几个大神的影响和自己的习惯摸索,最终算是总结出了一套自己的代码书写风格,当然我的代码风格还是一直在进化中 之前整理过一篇,如何高效的编写Verilog HDL——菜鸟篇,点击查看。 熟悉verilog的人都知道,Verilog HDL设计其实使用20%的语法就可以设计出90%以上的电路,其中最长用的便是always块了,用软件自带的IDE的话编写效率其实是很差的。 第三、代码的工整。 在编写代码的时候多用空格和TAB,把定义的信号对齐,这样写出代码是很漂亮的,每一段代码之间应该用分隔线隔开,这样整体看起来很清晰。 ?
代码覆盖率会清楚的看到哪一行没跑到,条件覆盖率也比较简单。每个if里面就一个条件。 乘法器调用方法,一般是在乘法器的输入保证寄存器输入,结果输出到各个复用模块时打一拍再使用。
废话不多说,先上源代码链接和testbench的链接,推荐使用UE查看源代码,UE中的VHDL语法、Verilog语法和SystemVerilog语法高亮文件的下载链接在这里。 上篇的最后给出了本篇所附代码的uart通信模型的工作过程。本篇的主要内容在源代码里,因此文章内容略显简单。 二、源代码组成分析 链接中给出的源代码由4个.v文件组成,其中uart_xmt.v是发送控制器,uart_rcv.v是接收控制器,uart_ctl.v是控制电路。 uart_xmt.v和uart_rcv.v中各有一个状态机,uart_ctl.v中有两个状态机,这里不给出过多的解释,代码中我都给出了详细注释。 代码中的CPU的读写操作和自动比对操作都必须定义成任务,不能定义成函数,因为任务是要花费仿真时间的。
介绍几种自动生成verilog代码的方法。 这种方法的好处是脚本相对固定,只需要修改配置文件就可以重新生成verilog代码。 这种方法的好处是只需要把精力花了编写模板身上,而其它部分都是由现成的库来实现,这样就只需要写很少量的python代码了。缺点是这种模板语言与Verilog语言本身有比较大的差异,需要稍微学习一下。 第四种:Verilog里内嵌python 在Verilog代码注释里嵌入几行python代码,而保持大部分Verilog不动。 当然为了保证代码可以再次生成,我们不能删除python源码,而是需要在注释下方生成。重新生成时会先删除PY_VLG_BEGIN和PY_VLG_END之间的verilog代码。
注意:feof判断文件结束是通过读取函数fread/fscanf等返回错误来识别的,故而判断文件是否结束应该是在读取函数之后进行判断。比如,在while循环读取一个文件时,如果是在读取函数之前进行判断,则如果文件最后一行是空白行,可能会造成内存错误。
如下图为工厂流水线,工厂流水线就是将一个工作(比如生产一个产品)分成多个细分工作,在生产流水线上由多个不同的人分步完成。这个待完成的产品在流水线上一级一级往下传递。
其实我大学时学习的是VHDL语言,后来由于公司都是使用的Verilog,又重新学习了Verilog,好在有C语言基础,Verilog很快就上手了。 ? Verilog标准文档主要有3个版本,分别是: Verilog-1995 Verilog-2001 Verilog-2005 都是由IEEE颁布。 虽然一些官方的代码,如Xilinx一些IP核代码,为了兼容以前的综合工具,还是基于Verilog-2001标准,但我还是强烈建议你使用最新的Verilog-2005标准。 ? 良好的代码规范可以提高代码的可读性、可复用性、简洁清晰,这也是一种职业素质的体现。 我们的目标是: Write Nowhere, Read Everywhere ? 封面 都有哪些内容? Verilog代码规范反面示例,可以参考:如何写出让同事无法维护的Verilog代码?
Verilog HDL通过对reg型变量建立数组来对存储器建模,可以描述RAM型存储器,ROM存储器和reg文件。数组中的每一个单元通过一个数组索引进行寻址。 在Verilog语言中没有多维数组存在。 memory型数据是通过扩展reg型数据的地址范围来生成的。
微信公众号:西电通院专用集成电路课程学习 用工具建工程对Verilog进行仿真、综合或者其它操作时,在写脚本的时候常常需要工程中Veriog文件的列表,若工程中.v文件过多,则常常需要手动编写文件列表。 另外,该代码提供了一种操作Windows系统路径的操作方法,可以简单修改一下,用作它用。如找到某种类型的文件或某个文件进行拷贝、转移、修改、删除等操作。 源代码 #include <stdio.h> #include <windows.h> #include <unistd.h> #include <math.h> #include <time.h } } getch(); fclose(fp1); return 0; } 版本更新记录 ---- 版本号:V1.1.2 更新日期:2013-07-17 14:46:46 修改代码 ,扩展name的长度为800,可以处理长路径的情况 版本号:V1.1.1 更新日期:2013-05-18 10:55:38 修改代码,添加判断语句&& (j==k-2),避免.vhd等文件也被列出来
图片 数字IC经典电路设计 经典电路设计是数字IC设计里基础中的基础,盖大房子的第一部是打造结实可靠的地基,每一篇笔者都会分门别类给出设计原理、设计方法、verilog代码、Testbench、仿真波形 同步复位的典型代码描述如下: module sync_reset( input rst_n, //同步复位信号 input clk, //时钟 input 异步复位的典型代码描述如下: module async_reset( input rst_n, //异步复位信号 input clk, //时钟 input 异步复位、同步释放的典型代码描述如下: module areset_srelease( input rst_n, //异步复位信号 input clk, / : 图片 Testbench代码描述如下: `timescale 1ns/1ps module areset_srelease_tb(); reg rst_n; reg clk
大家好,又见面了,我是你们的朋友全栈君 需求说明:Verilog设计基础 内容 :流水线设计 来自 :时间的诗 流水线设计 前言: 本文从四部分对流水线设计进行分析
用vhdlcom将所有的VHDL RTL代码编译成库 1.1 将所有的vhdl文件放到vhdl.f文件中,如: vhdl.f ——— my_design.vhd 用vericom将所有的verilog RTL代码编译成库 2.1 将所有的verilog文件放到verilog.f文件中,如: verilog.f ——— my_verilog_design.v my_verilog_lib.v tb_top_design.v 以上tb_top_design 为顶层设计. 2.2 编译成库 vericom -f verilog.f 编译完成后,可看到work.lib++库中新增了my_verilog_design.tdc 若出现verilog版本问题,可考 虑增加-2001等参数:vericom -2001 -f verilog.f b) 编译后的log为vericomLog/compiler.log
写在前面 在上篇文章:同步FIFO的两种Verilog设计方法(计数器法、高位扩展法)中我们介绍了FIFO的基本概念,并对同步FIFO的两种实现方法进行了仿真验证。 而异步FIFO因为读写时钟不一致,显然无法直接套用同步FIFO的实现方法,所以在本文我们将用Verilog实现异步FIFO的设计。 有关格雷码的介绍可参考:Verilog实现的格雷码与二进制码的互相转换 四位二进制码从0111变为1000的过程中,这两个数虽然在数值上相邻,但它们的每个比特都将发生改变,采样的值就可能是任意的四位二进制数 3、Verilog实现 根据以上可以设计异步FIFO的实现: 分别构造读、写时钟域下的读、写指针,指针位数需拓展一位。
今天给大侠带来FPGA Verilog 1995-VS Verilog-2001,话不多说,上货。 Verilog需要不断的跟踪源代码的行号和文件名,可编程语言接口(PLII)可以取得并利用行号和源文件的信息,以标记运行是的错误。 但如果Verilog代码经过其他工具的处理,源码的行号和文件名可能丢失。故在Verilog‐2001中增加了`line,用来标定源码的行号和文件名。 配置块位于模块定义之外,可以指定每一个Verilog模块的版本及其源代码的位置。 Verilog程序设计从顶层模块开始执行,找到在顶层模块中实例化的模块,进而确定其源代码的位置,照此顺序,直到确定整个设计的源程序。 ?