z295287653 发表于 2010-5-20 23:08:17

分频器。。。。

我刚刚学cpld,用verilog写了一个10分频模块,请问计数器cnt在always里面赋值时是写成cnt【2:0】好呢,还是直接写成cnt好。本人有点懒,写成cnt了感觉方便,读起来也方便,不知道有没有其他影响。谢谢各位指教咯、、、、、


/*
模块名称:偶数分频
设计人员:
模块功能:说明:N分频则在计数器计到2N-1时输出翻转
                  修改计时器的位数可以达到任何偶数分频
端口说明:inputclk\restb;
                  output out;
版本:v1.0 2010-5-20新建
*/

               
                module div(
                       clk,
                       restb,//低有效
                       out
                        );
                inputclk;
                inputrestb;
                output out;
               
                wire   clk;
                wire   restb;
                reg       out;
                reg cnt;//计数器
                               
                initial //初始化
                        begin
                                cnt=0;       
                                out=0;
                        end
                       
                always @(posedge clk or negedge restb)
                        begin
                                if(~restb)//在if语句里面如果超过一句话就要用begin-end
                                        begin//复位信号、全部清零
                                                cnt<=0;
                                                out=0;
                                        end
                                else if(cnt==4)//计数器清零、输出翻转
                                        begin
                                                cnt<=0;
                                                out=~out;
                                        end
                                else                        //计数器递加
                                        cnt<=cnt+1'b1;
                        end
               
endmodule

tear086 发表于 2010-5-20 23:38:41

如不嫌弃,可以看看我的粗浅博文。
http://www.cnblogs.com/yuphone/archive/2010/02/08/1666130.html

还有,如果没记错的话,那么initial是不可综合的。

z295287653 发表于 2010-5-20 23:50:06

回复【1楼】tear086 .COM 缺氧
-----------------------------------------------------------------------

就是说initial可以不要是吧

z295287653 发表于 2010-5-20 23:56:37

1楼的博文什么都有哦,受益匪浅啊。。继续关注哈哈

suipeng70 发表于 2010-5-21 08:53:21

我刚刚学cpld,用verilog写了一个10分频模块,请问计数器cnt在always里面赋值时是写成cnt【2:0】好呢,还是直接写成cnt好。本人有点懒,写成cnt了感觉方便,读起来也方便,不知道有没有其他影响。谢谢各位指教咯、、、、、
*********************************************************************************************************************
没有影响。但定义变量时的【2:0】是不能偷懒的。

semonpic 发表于 2010-5-22 19:32:05

回复【1楼】tear086 .COM 缺氧
-----------------------------------------------------------------------

你是好心人。

cuso4 发表于 2010-5-31 18:36:29

回复【1楼】tear086 .COM 缺氧
-----------------------------------------------------------------------

博客写的很好啊

raohao101 发表于 2011-10-25 16:58:14

mark
分屏器!
页: [1]
查看完整版本: 分频器。。。。