2443|3

51

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

请教一个verilog 程序! [复制链接]

前仿没有问题,用Quater 2编译也成功了,但后仿时出现网表文件错误……

请高人指教……

谢谢……
`timescale 1ns/100ps
`define clk_cycle 50

module sim_all(clk,rst,rst1,wr_en,rd_en);
  
    input clk,rst,rst1,wr_en,rd_en;
    wire [7:0]d_out;
    wire clk_10mb;
    wire clk_out;
    wire[7:0] addr,out,wr_addr;
    reg[7:0] data;

      fdivision  a(.clk(clk),.clk_10mb(clk_10mb));
      half_clk  b(.clk_in(clk_10mb),.clk_out(clk_out));
     dram     c(.clk(clk_10mb),.rst(rst),.wr_en(wr_en),.rd_en(rd_en),.wr_addr(addr),.d_out(d_out));
     counter  d(.out(out),.data(d_out),.clk_5mb(clk_out),.rst(rst1),.en(rd_en));
     addr_generator f(.rst(rst),.clk(clk_10mb),.enable(wr_en),.addr(addr));
endmodule

module fdivision(clk,clk_10mb);
    input clk;
    output clk_10mb;
    reg clk_10mb=0;
    reg[7:0] j=8'd0;
    always@(posedge clk )
   begin
        if(j==4)
        begin
            j<=0;
            clk_10mb<=~clk_10mb;
        end
        else
        j<=j+8'd1;
    end
endmodule

module half_clk(clk_in,clk_out);
    input clk_in;
    output clk_out;
    reg clk_out=0;
     always@(posedge clk_in)
    begin
    clk_out<=~clk_out ;
   end
endmodule

module dram(clk,rst,wr_en,rd_en,d_out,wr_addr);
input clk,rst,wr_en,rd_en;
input[7:0]wr_addr;

output[7:0] d_out;
reg[7:0] d_out;
reg[7:0] memory[0:255];
reg[7:0] rd_addr;

always @(posedge clk or negedge rst)
begin   
  if(!rst )
  begin
   rd_addr<=wr_addr;
   memory[wr_addr]<=wr_addr;
  end
end

always @(posedge clk)
begin   
  if(rd_en)  
  d_out<=memory[rd_addr];   
end
endmodule

module counter(out,data,clk_5mb,rst,en);
    input [7:0] data;
    input clk_5mb,rst,en;
    output[7:0] out;
    reg[7:0] out;
      
    always@(posedge clk_5mb )
   
    begin
    if(!rst)
        else if(en)
       out<=out+8'd1;
         end
endmodule

module addr_generator(rst,clk,enable,addr);
input rst,clk,enable;
output[7:0] addr;
reg[7:0] addr;
always@(posedge rst or posedge clk )
begin
  if(rst)
    addr=8'h0;
  else if(enable)
    addr<=addr+8'd1;
end
endmodule

激励:

`timescale 1ns/100ps
`define clk_cycle 50
module sim_all_tb;
    reg clk,rst,rst1,wr_en,rd_en;
    reg [7:0] data_in;
    reg [7:0] data_out;
    reg [7:0] wr_addr;
    reg [7:0] rd_addr;
    wire rest,clk_in,clk_out,clk_10mb,clk_5mb;
   
    wire[7:0] d_out,d_in,data,out;
   
    always #`clk_cycle clk=~clk;
    sim_all uut(.clk(clk),.rst(rst),.rst1(rst1),.wr_en(wr_en),.rd_en(rd_en));
    initial
    begin
        clk=0;rst=1;wr_en=0;rd_en=0;rst1=1;      
    end
    initial
    begin
       #1000 rst=1;
       #1000 rst=0;
       #1000 rd_en=1;
       #1000 rst1=0;
       #2000 rst1=1;
       #1000 wr_en=1;
       #1000 wr_en=0;
       #1000 rst1=0;
       #2000 rst1=1;
       #3000 wr_en=1;
       #1000 wr_en=0;
       #1000 rst1=0;
       #2000 rst1=1;         
       #100000 $stop;   
    end
endmodule



本文来自eeworld博客,转载请标明出处:http://blog.eeworld.net/zoupgfj/archive/2009/06/25/4297691.aspx

最新回复

喜欢VHDL,顶起来~~  详情 回复 发表于 2009-7-1 14:51
点赞 关注

回复
举报

67

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
把错误信息贴出来啊
 
 

回复

71

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
 
 
 

回复

53

帖子

0

TA的资源

一粒金砂(初级)

4
 
喜欢VHDL,顶起来~~
 
 
 

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

随便看看
查找数据手册?

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
快速回复 返回顶部 返回列表