- 1、本文档共25页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
verilog编程细则
版板所有 ? 广州周立功单片机发展有限公司 2007 版板所有 ? 广州周立功单片机发展有限公司 2007 作 者: 日 期:2008-7-2 1. 良好的编程风格有利于减少消耗的硬件资源,提高设计的工作频率。 2. 提高系统的可移植性和可维护性。 3. 程序的格式化能体现程序员的基本素质和整个团队的风貌。 简介 规范的重要性: 命名规则 注释 代码格式 命名规则 注释 代码格式 用于命名的字符集为:字母A~Z和a~z, 数字0~9以及下划线组成。 例如: data_bus data_width clk48M 48M_clk data__bus data*bus 命名字符集 名称不能以数字开头 数据总线 48M时钟信号 数据位宽 不能连续使用下划线 不能包含非字母符号* 使用有意义的名字,以利于望文生义 参数(parameter)、常量(constant)和块标号(block label)名必须一致采用大写;而信号,变量和结构名(construct)以及实例标号(instance)必须一致采用小写。有利于在仿真时,区分不变和变化的 数据。 大小写规则 module display_led( clk_48M, //时钟 ledout //LED输出 ); input clk_48M; //48M系统时钟 output [7:0] ledout; //LED输出控制 reg [22:0] count; //计数器 reg [7:0] led_reg; //LED输出缓存区 wire led_clk; //LED显示时钟控制 parameter COUNTER=100; assign led_clk = count[22]; //LED显示时间控制 模块标号小写 变量小写 常量大写 在不区分大小写的情况下,名字必须唯一。例如,名字state和State不能同时出现在同一设计中,这是因为有的EDA工具不区分大小写。 名字必须唯一 module casestatement ( a, State, state, dout ); input a; input State; input [2:0] state; output dout; reg dout; parameter STATE = 3bx11; always @(a or b or state) case(state State) 3b001: dout=ab; 3b010: dout=a|b; endcase endmodule 输入信号 参数 输入信号 不同类型的信号命名习惯 如果一个名字由多个字组成,则使用下划线连接,用以增加名字的可读性。为了使信号的
文档评论(0)