关于verilog请教下

[复制链接]
2722|10
 楼主| zhaigch 发表于 2009-11-28 21:21 | 显示全部楼层 |阅读模式
module counter4(clk,dout,en,oc);
input wire clk;
input wire en;
output reg [3:0] dout;
output reg oc;
reg [3:0] temp;
always @(posedge clk)
begin
if(en==1)
begin
  temp<=temp+1;
  if(temp=="1111")
  oc<=1;
  else
  oc<=0;
  dout<=temp; end
else
dout<=4'bz;
oc<="z";
end
endmodule

怎么进位信号老是没有呢!
请教下

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

×
yxwsz 发表于 2009-11-28 23:22 | 显示全部楼层
你真是verilog大牛啊, 都可以这样子写:
if(temp=="1111")
难道编译的时候没有看报警信息吗?
ic00 发表于 2009-11-29 10:49 | 显示全部楼层
你这个程序没有设计好,一个十六位的计数器。你没有考滤到复位的问题。我想你的那个进位没有分明白是同步还是异步。
 楼主| zhaigch 发表于 2009-11-29 12:24 | 显示全部楼层
没有报警信息
我只是想说为什么没有进位信号
yxwsz 发表于 2009-11-30 14:09 | 显示全部楼层
if(temp== 4'b1111)
一只小蜗牛 发表于 2009-12-1 15:00 | 显示全部楼层
看完lz的程序,我的鼻血都出来了。
建议lz先从一些仿真库里找些现成的模块来改。
等改得多了,有感觉了,再自己构建。
可木 发表于 2009-12-1 20:10 | 显示全部楼层
楼主的程序写的很雷人。。呵呵
lelee007 发表于 2009-12-1 20:23 | 显示全部楼层
temp=="1111"

verilog里边的字符串是不能用于综合的
 楼主| zhaigch 发表于 2009-12-3 23:02 | 显示全部楼层
module counter4(clk,dout,en,oc);
input wire clk;
input wire en;
output reg [3:0] dout;
output reg oc;
reg [3:0] temp;
always @(posedge clk)
if(en==1)
        begin
                temp<=temp+1;
                if(temp==4'b1111)
                oc<=1;
                else
                oc<=0;
                dout<=temp;       
        end
else
begin
        dout<=4'bzzzz;
        oc<="z";
end
endmodule



这会就对了,各位还有什么可以教导的么,受益匪浅 啊!!
学习了
 楼主| zhaigch 发表于 2009-12-3 23:03 | 显示全部楼层
我还是个初学者,还是自学的!!还请多多指教
ic00 发表于 2009-12-4 22:38 | 显示全部楼层
大家都是一样的,相互帮助
您需要登录后才可以回帖 登录 | 注册

本版积分规则

64

主题

158

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部