5235|1

5

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

问一下verilog移位寄存器的问题 [复制链接]

module test(CLK,STB,DATA,DOUT); 
     
    input CLK,STB,DATA; 
    output[7:0] DOUT; 
    reg[7:0] DOUT; 
     
    reg[7:0] shifter; 
    reg[7:0] bufferreg; 
     
    reg datacoming; 
    reg[2:0] count; 
     
    //initialize 
    initial 
    begin 
        count = 0; 
        datacoming = 0; 
        bufferreg = 8'b11111111; 
    end 
     
    always @(posedge CLK)  
    begin 
        if(STB == 1)   
            datacoming = 1; 
        else 
        begin 
            if(count == 1) 
            begin 
                datacoming = 0; 
            end 
            else 
                datacoming = 1; 
        end 
        if(datacoming == 1) 
        begin 
            shifter <= shifter << 1; 
            shifter[0] <= DATA;     
            count = count + 1;     
            if(count == 0) 
            begin 
                bufferreg = shifter; 
            end 
        end 
        DOUT = bufferreg; 
    end 
 
endmodule 
这是程序,主要目的是将8位移位寄存器每次采集的数据放到一个缓冲寄存器,然后输出。 
STB的主要作用是标志数据帧的开始,在bit0持续一个时钟周期(高电平),其它的信号大家都能看懂的,但我仿真出来却有问题,大家能看一下是哪出问题了吗?谢谢!

附件为时序图

QQ截图未命名.jpg (87.01 KB, 下载次数: 4)

时序图

时序图
此帖出自FPGA/CPLD论坛

最新回复

initial 是不可综合语句,可以给寄存器定义时赋初值; begin             if(count == 1)             begin                 datacoming = 0;             end             else                 datacoming = 1; 有问题。条件应设为:if(count != 0) 因为count取值范围7~0之间。  详情 回复 发表于 2011-7-31 11:44
点赞 关注
 

回复
举报

17

帖子

0

TA的资源

一粒金砂(中级)

沙发
 
initial 是不可综合语句,可以给寄存器定义时赋初值;
begin
            if(count == 1)
            begin
                datacoming = 0;
            end
            else
                datacoming = 1;
有问题。条件应设为:if(count != 0)
因为count取值范围7~0之间。
此帖出自FPGA/CPLD论坛
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

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

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

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

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

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

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