- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
专业资料
word完美格式
Verilog语法基础讲解之参数化设计
在Verilog语法中,可以实现参数化设计。所谓参数化设计,就是在一个功能模块中,对于一个常量,其值在不同的应用场合需要设置为不同的置,则将此值在设计时使用parameter 关键字声明,那么在上层模块例化使用该功能模块时,可以根据具体需求重新配置该常量的值,从而实现不同应用场合对对应常量的灵活调整。
以下为使用Verilog设计的一个控制LED闪烁灯的模块代码:
01 module counter(Clk,Rst_n,led);
02
03 input Clk; //系统时钟,50M
04 input Rst_n; //全局复位,低电平复位
05
06 output reg led; //led输出
07
08 reg [24:0]cnt; //定义计数器寄存器
09
10 //计数器计数进程
11 always@(posedge Clk or negedge Rst_n)
12 if(Rst_n == 1b0)
13 cnt = 25d0;
14 else if(cnt == 25d24_999_999)
15 cnt = 25d0;
16 else
17 cnt = cnt + 1b1;
18
19 //led输出控制进程
20 always@(posedge Clk or negedge Rst_n)
21 if(Rst_n == 1b0)
22 led = 1b1;
23 else if(cnt == 25d24_999_999)
24 led = ~led;
25 else
26 led = led;
27
28 endmodule
在此设计中,定义了一个名为cnt的计数器,该cnt在输入时钟”Clk”的驱动下,每个时钟的上升沿执行一次自加操作,当计数到,计数器清零,同时led驱动状态发生翻转。由于系统时钟为50M,即周期为20ns,cnt每计,即500ms,驱动led状态翻转一次,从而可以实现控制led以1s为周期进行亮灭闪烁。在这个系统中,我们可以看到,如果我们希望将闪烁速度进行更改,例如改为每50ms让led翻转一次,则需要在代码中将”cnt == 25d24_999_999”中25d24_999_999这个常量修改为25d24_999_99。
现在考虑另外一种情况,假如某个系统中有三个LED灯需要通过这种方式来进行驱动闪烁,每个LED灯的闪烁频率还不一样。现假设LED1闪烁频率为1s,LED2为0.1s,LED3为0.01秒。那么这三个LED驱动模块中,”25d24_999_999”这个常量就需要分别修改为
LED1:”25d24_999_999”
LED2:”25d24_999_99”
LED3:”25d24_999_9”
因此,必须独立的设计三个这样的模块,然后在上层模块中分别例化这三个模块,以实现需求的功能。
独立设计这样三个模块并分别例化,确实能够完全实现上述假设系统需求的功能,但是通过这种方式设计出来的模块,不具备通用性,如果要求发生变化,则还需要回到底层模块中去修改对应的常量,而底层模块中可能不止一个地方使用到了这个常量,例如上述代码中,第14行和第23行就分别用到了这个常量。如果模块中对此常量的使用次数较多,在修改的过程即增加了工作量,又极容易发生遗漏,从而导致错误。
而参数化设计的使用,则可以非常完美的解决这一问题。这里首先放上该设计使用参数化设计之后的该模块代码:
01 module counter(Clk,Rst_n,led);
02
03 input Clk; //系统时钟
04 input Rst_n; //全局复位,低电平复位
05
06 output reg led; //led输出
07
08 reg [24:0]cnt; //定义计数器寄存器
09
10 parameter CNT_MAX = 25d24_999_999;
11
12 //计数器计数进程
13 always@(posedge Clk or negedge Rst_n)
14 if(Rst_n == 1b0)
15 cnt = 25d0;
16 else if(cnt == CNT_MAX)
17 cnt = 25d0;
18 else
19 cnt = cnt + 1b1;
20
21 //led输出控制进程
22 always@(posedge Clk or negedge Rst_n)
23 if(Rst_n
文档评论(0)