2138|3

27

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

关于modelsim仿真问题! [复制链接]

本帖最后由 guaiguaidou 于 2015-7-27 10:48 编辑

最近学习特权同学的《深入浅出玩转FPGA》一书,想对里面的一个实验进行功能仿真(在书的p60)
但一直都得不到理想情况,请问这个是什么原因?
这是verilog代码:

module handshack
(
        input clk,
        input rst_n,
        input req,    //请求信号,高电平有效
        input [7:0]datain,
        output ack,  //应答信号,高电平有效
        output [7:0]dataout
);

reg reqr1,reqr2,reqr3;

always@(posedge clk or negedge rst_n)
        begin
        if(!rst_n)
                begin
                reqr1 <= 1'b1;
                reqr2 <= 1'b1;
                reqr3 <= 1'b1;
                end
        else
                begin
                reqr1 <= req;
                reqr2 <= reqr1;
                reqr3 <= reqr2;
                end
        end
//pos_req2比pos_req1延后一个时钟,确保数据被稳定锁存      
wire pos_req1 = reqr1 & ~reqr2;    //req上升沿标志位,高有效一个时钟周期
wire pos_req2 = reqr2 & ~reqr3;    //req上升沿标志位,高有效一个时钟周期

reg [7:0]dataoutr;

always@(posedge clk or negedge rst_n)
        begin
        if(!rst_n) dataoutr <= 8'h00;
        else if(pos_req1) dataoutr <= datain;
        end
      
assign dataout = dataoutr;

reg ackr;

always@(posedge clk or negedge rst_n)
        begin
        if(!rst_n) ackr <= 1'b0;
        else if(pos_req2) ackr <= 1'b1;
        else if(!req) ackr <= 1'b0;
        end

assign ack = ackr;

endmodule        

               

下面是我写的testbend:

`timescale 1 ns/ 1 ps

module handshack_vlg_tst();
reg clk;
reg [7:0] datain;
reg req;
reg rst_n;                                          
wire ack;
wire [7:0]  dataout;
   
handshack i1 (
        .ack(ack),
        .clk(clk),
        .datain(datain),
        .dataout(dataout),
        .req(req),
        .rst_n(rst_n)
);

initial                                                
begin                                                                       
        rst_n = 1; #20; rst_n = 0; #20; rst_n = 1;
        clk = 1; forever #10 clk = ~clk;
end     

reg [3:0]i;

always@(posedge clk or negedge rst_n)

begin                                                                          
        if(!rst_n)
        begin
                i <= 1'b0;
                req <= 1'b0;
                datain <= 8'd0;
        end

        else if(!ack)
                case(i)
                0,1,2:
                begin req <= 1'b0;datain <= 8'd0;i <= i+1'b1;end
                3,4,5,6:
                begin req <= 1'b1;datain <= 8'd100;i <= i+1'b1;end
                7:
                i <= i;
                endcase
        else if(ack) req <= 1'b0;                                                                                                  
end                                                   

endmodule




下面是仿真波形:


此帖出自FPGA/CPLD论坛

最新回复

nmg
额,解决的速度真快 谈谈怎么回事儿,让后来人有个借鉴 :)  详情 回复 发表于 2015-7-27 13:43
点赞 关注
 

回复
举报

27

帖子

0

TA的资源

一粒金砂(中级)

沙发
 
额,自己解决了。。
此帖出自FPGA/CPLD论坛

点评

nmg
额,解决的速度真快 谈谈怎么回事儿,让后来人有个借鉴 :)  详情 回复 发表于 2015-7-27 13:43
 
 

回复

5224

帖子

239

TA的资源

管理员

板凳
 
guaiguaidou 发表于 2015-7-27 11:11
额,自己解决了。。

额,解决的速度真快
谈谈怎么回事儿,让后来人有个借鉴 :)
此帖出自FPGA/CPLD论坛
加EE小助手好友,
入技术交流群
EE服务号
精彩活动e手掌握
EE订阅号
热门资讯e网打尽
聚焦汽车电子软硬件开发
认真关注技术本身

点评

初始化赋值问题,应该在initial里面对i、req、datain进行赋值的。不用在rst_n里面赋值  详情 回复 发表于 2015-7-28 09:44
 
 
 

回复

27

帖子

0

TA的资源

一粒金砂(中级)

4
 
nmg 发表于 2015-7-27 13:43
额,解决的速度真快
谈谈怎么回事儿,让后来人有个借鉴 :)

初始化赋值问题,应该在initial里面对i、req、datain进行赋值的。不用在rst_n里面赋值
此帖出自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
快速回复 返回顶部 返回列表