Verilog编程规范(补充中)

    良好的编程规范可以提高设计人员的工作效率,方便非原作者对代码进行维护。

一、命名约定

1.文件的名称与模块的名称一致,arbiter.v文件内部模块为module arbiter。

2.每个模块用一个文件表示,而且一个文件最多表示一个模块。

3.在整个层次化的设计中采用不变的名称,例如在例化的时候,顶层模块和调用的底层模块的变量名称保持一致。

   推荐使用如下的例化方式

   block1  u_block1(

                 .rst_n (rst_n),

                 .clk (clk),

                 .addr (addr),

                 .wr_data (wr_data)

                 ....................

                         );

    不推荐用如下的例化方式

   block1  u_block1(

                 .reset_n (rst_n),

                 .clock (clk),

                 .address (addr),

                 .WR_data (wr_data)

                 ....................

                         );

4.表示参数名和宏名的常量必须用大写表示。

例如,parameter DATA_WIDTH=10;

5.使用有意义的命名,以便对命名的对象一目了然。

二、文件头描述,在文件的开始位置加上本文件的描述,以便修改和其他使用者使用。

//
// Company: 
// Engineer: 
// 
// Create Date:    08:28:22 03/27/2014 
// Design Name: 
// Module Name:    a 
// Project Name: 
// Target Devices: 
// Tool versions: 
// Description: 
//
// Dependencies: 
//
// Revision: 
// Revision 0.01 - File Created
// Additional Comments: 
//
//

三、注释规则

非原作者只通过读代码很难理解设计者的意图,不利于代码的维护和改进。

1.尽量使用单行注释//,不推荐使用多行注释/*....................*/。

2.删除冗余的注释和代码,让程序尽量简洁。

四、编码风格

1.在例化模块时,不推荐使用表达式。

2.if条件判断语句,括号内部的表达式应该为1bit位宽的数值。

3.在代码对齐时推荐使用空格键,而不是推荐使用Tab键。

4.将用到的内部变量声明在同一个段中。

5.不能将x赋值给信号,testbench例外。

6.reg型变量不能再两个always语句中赋值,在一个always中赋值后,在其他的always语句中不能改变其值。

7.避免使用inout类型的端口。

8.矢量端口在例化时最好声明数据宽度,以提高代码的可读性。

例如 block u_block(

               .vector (vector [7:0])

                              );

9.组合逻辑always的敏感信号列表包括所有的输入信号。

10.组合逻辑用(=)阻塞赋值,时序逻辑用(<=)非阻塞赋值。

11.在可综合代码中不要使用initial、wait、fork-join和while语句,而且不能使用casex和casez语句,只能使用case和if-else语句作为条件分支语句。

12.case语句和if-else语句必须保持完整性,即case语句要有default缺省项,if语句要有对应的else项。

13.模块中的每个输出信号原则上必须通过寄存器输出。任何不通过寄存器输出的信号必须加以注释,注意防止出现反馈回路。

14.尽量使用assign语句设计组合逻辑。

15.从RTL级转换到gate级的综合工具一般都不支持Wait 声明和# delay声明,为了有效的综合,这些语句应该避免。

16.端口声明的顺序--在保证先输入再输出的基础上按如下顺序clocks,resets,control signals,address bus,data bus。

     

    


  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
华为verilog编程规范是一种用于指导和规范在华为公司进行verilog编程规范文件。这个规范涵盖了verilog语言的各个方面,旨在提高代码的可读性、可维护性和可重用性。 首先,华为verilog编程规范明确了命名规范。在这个规范,变量、模块、端口和信号的命名必须具有清晰、简洁和有意义的名称,以增加代码的可读性和理解性。 其次,规范指导了代码的结构和格式。它强调使用适当的缩进、注释和空格来增加代码的可读性,并提醒程序员不要使用过长的行或复杂的语句。 此外,华为verilog编程规范还规定了在编写代码时应遵循的规则。例如,规范要求程序员使用合适的数据类型、操作符、条件语句和循环结构,并强调避免使用过于复杂或技巧性的编程技巧,以确保代码的可维护性和可靠性。 另外,在设计验证方面,规范还提供了一些指导原则。例如,它鼓励使用模块化的设计方法,将功能划分为独立的模块,并使用规定的接口定义和进行模块间的通信。 最后,华为verilog编程规范还包括了一些特定的最佳实践和建议,帮助程序员编写高质量的代码。例如,规范建议使用有意义的信号命名和注释,以及进行适当的代码复用和模块化设计。 总之,华为verilog编程规范是一份详细的指南,旨在提高华为公司内部verilog代码的质量和一致性,确保代码的可读性、可维护性和可重用性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值