5450|13

78

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

异步复位计数器 [复制链接]

请教:
    想要在CPLD上实现一个异步计数器,在时钟的上升及下降沿都需要+1计数,代码如下:
    reg[7:0] counter;
    always @(clk)
       begin
        if(en == 0)      
            begin
                counter <= 0;
            end
        else
            begin
                    counter <= counter + 8'h01;
            end
       end

    其中:en  -  使能信号,为0时,复位计数器,为1时使能计数器
          clk - 输入时钟
          counter - 8bit计数寄存器

    奇怪的是,用synplify8.6综合后,counter[7:0]变成了counter[0],读其数值,只有0,1两个。

最新回复

具体实现如下:     wire wHighClk;     reg[7:0] counter;     reg clk_temp1,clk_temp2;     always @(posedge wHighClk)               begin                 clk_temp1  详情 回复 发表于 2010-1-21 19:19
点赞 关注

回复
举报

56

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
好好仿真,看下时序图.

帮顶下.
 
 

回复

59

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
应该好好看看综合的报告,关注一下哪些信号使用到了counter,以及en 信号可能变化的情况。楼主的意思是counter的其它位被优化掉了。
 
 
 

回复

58

帖子

0

TA的资源

一粒金砂(初级)

4
 
一般不推荐在一个进程里做双沿的处理吧
 
 
 

回复

74

帖子

0

TA的资源

一粒金砂(初级)

5
 
帮顶 关注 学习中---
 
 
 

回复

83

帖子

0

TA的资源

一粒金砂(初级)

6
 
楼主仿真了吗? 问题解决了吗?

关注下。
 
 
 

回复

71

帖子

0

TA的资源

一粒金砂(初级)

7
 
1、你写的代码不是异步复位,是同步复位!
2、三楼说的也不对,这里没有双沿处理!
3、应该是计数器所有的位没有全部被使用或输出,被优化掉了!
 
 
 

回复

81

帖子

0

TA的资源

一粒金砂(初级)

8
 
引用 6 楼 guolh 的回复:
1、你写的代码不是异步复位,是同步复位!
2、三楼说的也不对,这里没有双沿处理!
3、应该是计数器所有的位没有全部被使用或输出,被优化掉了!

不太会用Verilog,但是他代码中好像没有指出是什么沿吧,要不应该有risingedge或fallingedge之类的字眼吧,请赐教
 
 
 

回复

82

帖子

0

TA的资源

一粒金砂(初级)

9
 
reg[7:0] counter;
always@(posedge clk or negedge en) //时钟上升沿计数,en高异步复位!
     begin
          if(~en)                  //
               begin
                    counter <= 0;
               end
          else
               begin
                    counter <= counter + 8'h01;
               end
      end

其中: en      -  使能信号,为0时,复位计数器,为1时使能计数器
       clk     -  输入时钟
       counter -  8bit计数寄存器

这样一定没问题
 
 
 

回复

84

帖子

0

TA的资源

一粒金砂(初级)

10
 
楼上说的不错,最近也正在做HDLC方面的VHDL
 
 
 

回复

68

帖子

0

TA的资源

一粒金砂(初级)

11
 
guanzhu,bangding
 
 
 

回复

82

帖子

0

TA的资源

一粒金砂(初级)

12
 
多谢各位!问题解决:

不能直接用上、下沿来触发,需要引入一个更高频率的时钟(至少为信号的2倍),通过高频时钟来查询信号的上下沿。

 
 
 

回复

88

帖子

0

TA的资源

一粒金砂(初级)

13
 
学习....好像直接用时钟的边沿来触发,就无法综合了
 
 
 

回复

95

帖子

0

TA的资源

一粒金砂(中级)

14
 
具体实现如下:

    wire wHighClk;
    reg[7:0] counter;
    reg clk_temp1,clk_temp2;

    always @(posedge wHighClk)      
        begin
                clk_temp1<=clk;
                clk_temp2<=clk_temp1;
        end

    always @(negedge wHighClk)
        begin
        if(en == 0)      
            begin
                counter <= 0;
            end
        else if((clk_temp2==0 && clk_temp1==1) || (clk_temp2==1 && clk_temp1==0))
            begin
                counter  <= counter  + 8'h01;
                end
        end


    其中:en  -  使能信号,为0时,复位计数器,为1时使能计数器
          clk - 输入时钟
          counter - 8bit计数寄存器
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表