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的更多相关文章

  1. Verilog代码规范(持续更新)

    1.输入输出的定义,看起来整齐 2.always.if或其他语句后begin写在同一行,这样可以避免begin占用过多的行,代码密度更大 3.end后面要有注释,以标明是哪个关键词的结束,除了endc ...

  2. Verilog 编写规范

    在学习Python时,作者有一句话对我影响很大.作者希望我们在学习编写程序的时候注意一些业内约定的规范.在内行人眼中,你的编写格式,就已经暴露了你的程度.学习verilog也是一样的道理,一段好的ve ...

  3. iOS代码规范(OC和Swift)

    下面说下iOS的代码规范问题,如果大家觉得还不错,可以直接用到项目中,有不同意见 可以在下面讨论下. 相信很多人工作中最烦的就是代码不规范,命名不规范,曾经见过一个VC里有3个按钮被命名为button ...

  4. 谈谈PHP代码规范

    [转] http://www.syyong.com/php/Talk-about-PHP-code-specification.html 我向往这样一个php世界,里面没有代码规范之争.你我都一样,都 ...

  5. 2016 正确 sublime安装PHPcs PHPcodesniffer代码规范提示插件,修正网上部分不详细描述

    对你有助请点赞,请顶,不好请踩------送人玫瑰,手留余香!-------------------14:37 2016/3/212016 正确 sublime安装PHPcs PHPcodesniff ...

  6. C#与Java对比学习:类型判断、类与接口继承、代码规范与编码习惯、常量定义

    类型判断符号: C#:object a;  if(a is int) { }  用 is 符号判断 Java:object a; if(a instanceof Integer) { } 用 inst ...

  7. 作业三: 代码规范、代码复审、PSP

    分) 对于是否需要有代码规范,请考虑下列论点并反驳/支持: 这些规范都是官僚制度下产生的浪费大家的编程时间.影响人们开发效率, 浪费时间的东西. 我是个艺术家,手艺人,我有自己的规范和原则. 规范不能 ...

  8. 转!!Java代码规范、格式化和checkstyle检查配置文档

    为便于规范各位开发人员代码.提高代码质量,研发中心需要启动代码评审机制.为了加快代码评审的速度,减少不必要的时间,可以加入一些代码评审的静态检查工具,另外需要为研发中心配置统一的编码模板和代码格式化模 ...

  9. C#代码规范

    C#代码规范  一.文件命名 1 文件名 文件名统一使用帕斯卡命名法,以C#类名命名,拓展名小写. 示例: GameManager.cs 2 文件注释 每个文件头须包含注释说明,文件头位置指的是文件最 ...

随机推荐

  1. Swift内存管理、weak和unowned以及两者区别

    Swift 是自动管理内存的,这也就是说,我们不再需要操心内存的申请和分配.当我们通过初始化创建一个对象时,Swift 会替我们管理和分配内存.而释放的原则遵循了自动引用计数 (ARC) 的规则:当一 ...

  2. kill

    向一个/一些进程发送一个信号 $kill [-slL] -s指定发送的信号,可以使用名称或者信号编号 -l列出当前系统的所有信号 $kill -l 1) SIGHUP 2) SIGINT 3) SIG ...

  3. ELK Kafka json to elk

    Logstash配置     input { kafka { zk_connect => "127.0.0.1:2181" topic_id => "clus ...

  4. HashMap的key可以是可变的对象吗???

    大家都知道,HashMap的是key-value(键值对)组成的,这个key既可以是基本数据类型对象,如Integer,Float,同时也可以是自己编写的对象,那么问题来了,这个作为key的对象是否能 ...

  5. php高级研发或架构师必了解---很多问题面试中常问到!

    一.mysql相关知识    1. mysql优化方式            MYSQL 优化常用方法            mysql 性能优化方案      2.如何分库分表            ...

  6. 带权图的最短路径算法(Dijkstra)实现

    一,介绍 本文实现带权图的最短路径算法.给定图中一个顶点,求解该顶点到图中所有其他顶点的最短路径 以及 最短路径的长度.在决定写这篇文章之前,在网上找了很多关于Dijkstra算法实现,但大部分是不带 ...

  7. 第65课 C++中的异常处理(下)

    1. C++中的异常处理 (1)catch语句块可以抛出异常 ①catch中获捕的异常可以被重新抛出 ②抛出的异常需要外层的try-catch块来捕获 ③catch(…)块中抛异常的方法是throw; ...

  8. C#添加测量运行时间

    使用范围 使用模块化开发,每个模块都有初始化功能,初始化功能可能包括:加载配置表,初始化事件,初始化设置 那么如果想测量每个模块的Init时间呢?Net框架已经提供了测量运行的方法 System.Di ...

  9. java 25 - 3 网络编程之 Socket套接字

    Socket Socket套接字: 网络上具有唯一标识的IP地址和端口号组合在一起才能构成唯一能识别的标识符套接字. Socket原理机制: 通信的两端都有Socket. 网络通信其实就是Socket ...

  10. java 22 - 17 多线程之等待唤醒机制(接16)

    先来一张图,看看什么叫做等待唤醒机制 接上一章的例子. 例子:学生信息的录入和获取 * 资源类:Student  * 设置学生数据:SetThread(生产者) * 获取学生数据:GetThread( ...