Verilog代码规范I
Verilog代码规范I
"规范"这问题
"规范"这个富含专业气息的词汇(个人感觉),其实规范这种东西,就是大家都约定熟成的东西,一旦你不遵守这个东西,专业人士就会觉得你不够专业,特别是程序开发方面的问题。
为什么要规范呢?一方面能体现你足够专业,另一方面也是最重要的一方面,代码的规范性有利于开发交流,让代码的可读性大大增强,也有利于降低代码的出错率。
网上关于EDA设计方面的代码规范问题的资料,以前开发的时候都没有养成一个很好的代码规范,在大的项目工程中,这方面的弊端开始慢慢显现,对后续的修改和维护造成很大的影响,重新去编写又浪费很多的时间,所以请记住一句话"千里之行始于足下",不要到走了很远之后才发现导向错了。
Verilog代码有哪些规范?
- 文件名必须体现出设计模块的功能;
在verilog设计中,模块名就是文件名,这是由于软件编译的问题而限制的。所以设置模块名的时候也决定了文件名。因此,模块名的设定要体现出模块的功能,这样设定对于大的工程项目设计很有用处,便于查找分析。
- 时钟信号及低电平有效信号的命名:
时钟信号一般的命名为:clk;
请回忆一下,你所编写的程序中低电平复位信号是如何编写的,目前我所见过的版本有:reset,rst,reset_n,rst_n;普遍就是这四种。前两种体现出该信号是高电平有效的,而后两种体现该复位信号是低电平有效的,在设计规范中就是采用*_n来表示低电平有效的。所以低电平有效的信号一律采用*_n表示,增强代码的可读性。
- 参数parameter和宏定义`define
在定义参数和宏定义时,名字要采用大写进行表示,如下:
parameter DATA_WIDTH = 32;
`define AHB_TRANS_SEQ 2'b11;
- 信号、端口、模块、例化
有关这四个方面的代码设计最好采用小写进行设计,如下:

- 命名字符的长度
一般字符命名的长度不要超过32个;
- 有关模块调用的实体名的设定,参考如下:
mux4 u_mux4_1 (…);
mux4 u_mux4_2 (…);
- 位宽的描述
在Verilog的设计中一般采用的为[x:0];在VHDL中一般采用的是x downto 0;
采用的都是从高在左低位在右符合人的阅读顺序的方式。
- Begin和end、case和endcase、if和else的对准问题
这里采用一个实例进行说明:

- 到这里所说到的都是关于文本输入形式的,那么在原理图输入方式中有没有相关的规范问题呢?答案是肯定的!!!所以经常采用原理图输入的好好注意了!!!
原理图输入方式中,有时会将自己所写的文本生生成一个原理图的模块,然后导入到原理图的设计中,这时该原理图也被设置为顶层模块,所以有时问题就产生在这里。当有多个模块导入原理图时,这是就需要将这些模块连接起来,如果在连接的时候用一些分立的逻辑元件将模块与模块之间连接起来,这就产生了一个所谓"胶合逻辑"的问题,因为该逻辑元件在综合时是没有加入到任何一个模块里面的,所以就无法进行整体的最优化综合,所以就无法产生一个最优化的电路,这个逻辑元件将两个模块有缝地连接起来,这样的电路在同步中又怎么会稳定呢?
所以请记住一点,有文本输入和原理图输入的工程中,原理图作为顶层文件时,原理图最好是页水平的分层结构,即原理图中的模块都是采用文本输入之后生成的,这样就避免了"胶合逻辑",让综合器更好地综合我们设计的电路。
"胶合逻辑"实例:是否在你的原理图中出现过呢?。。。。。。。。。。。。。

- 非阻塞和阻塞问题,这个问题在FPGA设计中是老生常谈的问题
下面看看一个实例,相信你就懂了:

从时间上进行分析的话,非阻塞赋值就是同时赋值,而阻塞赋值就是顺序赋值,软件综合时也会帮你对电路进行简化。
- 信号敏感列表
什么是信号敏感列表呢?就是在需要信号输入的模块中,如always @()--括号内包含的信号就是敏感信号,也就是说在括号内的信号都将会影响模块的工作或者是模块内某些信号的输出。
那什么信号是敏感信号呢?凡是影响模块输出和工作状态的信号都将是敏感信号,一般有:时钟信号、复位信号、置数信号、某些赋值语句的右边信号还有一些条件信号。

- 复位&初始化
相信你看过的经典代码中,一般都会包含有复位信号rst_n吧!
为什么要复位呢?
一个是为了初始化,另一个是在系统工作异常时重新进入初始状态(就像电脑有时死机重启一样)。
为什么要初始化呢?
在FPGA中经常要用到reg,不是吗?而且是经常要用到,没有reg就没有FPGA。而reg在上电后里面所寄存的是1还是0是不一定的,这将会造成很大的问题,会造成输出不确定、会造成状态机进入与确定的状态…………所以就需要在上电的时候,利用复位信号进行初始化,就reg的值进行初始化,使一切都是确定的,防止不确定状态的出现。实例如下:

每日推送不同科技解读,原创深耕解读当下科技,敬请关注微信公众号“科乎”。

Verilog代码规范I的更多相关文章
- Verilog代码规范(持续更新)
1.输入输出的定义,看起来整齐 2.always.if或其他语句后begin写在同一行,这样可以避免begin占用过多的行,代码密度更大 3.end后面要有注释,以标明是哪个关键词的结束,除了endc ...
- Verilog 编写规范
在学习Python时,作者有一句话对我影响很大.作者希望我们在学习编写程序的时候注意一些业内约定的规范.在内行人眼中,你的编写格式,就已经暴露了你的程度.学习verilog也是一样的道理,一段好的ve ...
- iOS代码规范(OC和Swift)
下面说下iOS的代码规范问题,如果大家觉得还不错,可以直接用到项目中,有不同意见 可以在下面讨论下. 相信很多人工作中最烦的就是代码不规范,命名不规范,曾经见过一个VC里有3个按钮被命名为button ...
- 谈谈PHP代码规范
[转] http://www.syyong.com/php/Talk-about-PHP-code-specification.html 我向往这样一个php世界,里面没有代码规范之争.你我都一样,都 ...
- 2016 正确 sublime安装PHPcs PHPcodesniffer代码规范提示插件,修正网上部分不详细描述
对你有助请点赞,请顶,不好请踩------送人玫瑰,手留余香!-------------------14:37 2016/3/212016 正确 sublime安装PHPcs PHPcodesniff ...
- C#与Java对比学习:类型判断、类与接口继承、代码规范与编码习惯、常量定义
类型判断符号: C#:object a; if(a is int) { } 用 is 符号判断 Java:object a; if(a instanceof Integer) { } 用 inst ...
- 作业三: 代码规范、代码复审、PSP
分) 对于是否需要有代码规范,请考虑下列论点并反驳/支持: 这些规范都是官僚制度下产生的浪费大家的编程时间.影响人们开发效率, 浪费时间的东西. 我是个艺术家,手艺人,我有自己的规范和原则. 规范不能 ...
- 转!!Java代码规范、格式化和checkstyle检查配置文档
为便于规范各位开发人员代码.提高代码质量,研发中心需要启动代码评审机制.为了加快代码评审的速度,减少不必要的时间,可以加入一些代码评审的静态检查工具,另外需要为研发中心配置统一的编码模板和代码格式化模 ...
- C#代码规范
C#代码规范 一.文件命名 1 文件名 文件名统一使用帕斯卡命名法,以C#类名命名,拓展名小写. 示例: GameManager.cs 2 文件注释 每个文件头须包含注释说明,文件头位置指的是文件最 ...
随机推荐
- linux文件分发脚本
1.说明 此脚本可分发两类文件,1.固定内容文件,2.(每台被分发主机)内容不同的文件 ppp.sh为拨号脚本,每台被分发主机内容不同 根据分发文件名字不同(ppp.sh和其他文件)自动选择分发方式 ...
- my_ls
#include<stdio.h> #include<dirent.h> #include<string.h> #include<sys/types.h> ...
- docker-7 docker在阿里云的使用
在传统模式中,开发团队在开发环境中完成软件开发,自己做了一遍单元测试, 测试通过,ᨀ交到代码版本管理库.运维把应用部署到测 试环境, QA 进行测试,没问题后通知部署人员发布到生产环境. 在上述过程中 ...
- DNS 原理入门
导读 DNS 是互联网核心协议之一.不管是上网浏览,还是编程开发,都需要了解一点它的知识.本文详细介绍DNS的原理,以及如何运用工具软件观察它的运作.我的目标是,读完此文后,你就能完全理解DNS. 一 ...
- android 中Activity的onStart()和onResume()的区别是什么
首先你要知道Activity的四种状态:Active/Runing 一个新 Activity 启动入栈后,它在屏幕最前端,处于栈的最顶端,此时它处于可见并可和用户交互的激活状态.Paused 当 Ac ...
- linux原始套接字(2)-icmp请求与接收
一.概述 上一篇arp请求使用的是链路层的原始套接字.icmp封装在ip数据报里面,所以icmp请 ...
- Azure Linux VM Swap 分区
默认情况下,Windows Azure上的Linux VM是没有Swap分区的.下面我们以Ubuntu为例,为Windows Azure上的Linux虚拟机创建Swap分区. Windows Azur ...
- 解决chrome在docky上的图标模糊或不能锁定的问题
1,终端执行以下命令:sudo nautilus2,打开usr/share/application,找到chrome的图标,右键找到属性,把“命令”里的内容换成/usr/bin/google-chro ...
- java变量的初始化
public class Init { private int age;//非静态初始化语句<3> private static String name; //静态初始化语句,先初始化静态 ...
- DOM、Window操作
一.DOM的基本概念 DOM是文档对象模型,这种模型为树模型:文档是指标签文档:对象是指文档中每个元素:模型是指抽象化的东西. 一.基本语法: 数据类型(字符串,小数,整数,布尔,时间) var, v ...