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 文件注释 每个文件头须包含注释说明,文件头位置指的是文件最 ...
随机推荐
- spring定时器(二)
此定时器可重置定时时间. 1. spring的定时器配置文件application.xml: <?xml version="1.0" encoding="UTF-8 ...
- centos7系统下安装nodejs开发环境
1)安装基础工具(if not exists) yum install -y net telnet tools vim wget ntp 2)同步系统时间(if necessary) ntpdate ...
- 用php生成静态html页面(通用2种方法)
因为每次用户点击动态链接的时候都会对服务器发送数据查询的要求 对于一个访问量可能达百万千万级别的网站来说 这无疑是服务器一个大大的负担 所以把动态数据转换成静态html页面就成了节省人力物力的首选 因 ...
- Codevs 1025 选菜
题目描述 Description 在小松宿舍楼下的不远处,有PK大学最不错的一个食堂--The Farmer's Canteen(NM食堂).由于该食堂的菜都很不错,价格也公道,所以很多人都喜欢来这边 ...
- java汉化
http://download.eclipse.org/technology/babel/babel_language_packs/R0.13.0/luna/luna.php _x86_64版本下载地 ...
- C++ 中指针与引用的区别
指向不同类型的指针的区别在于指针类型可以知道编译器解释某个特定地址(指针指向的地址)中的内存内容及大小,而void*指针则只表示一个内存地址,编译器不能通过该指针所指向对象的类型和大小,因此想要通过v ...
- java的构造方法
当一个类a继承一个类b,类b继承类c,类c继承类d时, 先执行d的构造,然后c.b:当该执行a的构造时,如果有成员变量,就先执行成员变量,最后构造 子类继承父类,子类重写父类的某个方法,当父类构造时, ...
- 第18章 图元文件_18.2 增强型图元文件(emf)(2)
18.2.7 增强型图元文件的查看和打印程序 (1)传递EMF到剪贴板,剪贴板类型应为:CF_ENHMETAFILE (2)CopyEnhMetaFile用于复制图元文件 (3)剪贴板中的图元文件会自 ...
- java io (一)
对于文件内容的操作主要分为两大类 分别是:字符流 字节流 其中,字符流有两个抽象类:Writer Reader 其对应子类FileWriter和FileReader可实现文件的读写操作 Buffe ...
- android studio 应用小知识总结
1.在复制一个工程文件后 想修改包名,则在Android下的java中的 Android test中,鼠标右键Refactor->rename->Rename_package->Do ...