[X]关闭

ZYnq里面仿真出现了问题 有一个信号一直是X

文档创建者:永反倒是
浏览次数:3390
最后更新:2017-12-05
本帖最后由 永反倒是 于 2017-12-5 21:46 编辑

设计程序:
`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////////
// Module Name:    clkdiv
// 产生一个波特率9600的16倍频的时钟,9600*16= 153600
// 相当于100MHz的2*326分频,2*50000000/153600=2*326
//////////////////////////////////////////////////////////////////////////////////
module clkdiv(clk100,rstn,clk);
input clk100;              //系统时钟

input rstn;
output clk;  //采样时钟输出
reg [15:0] cnt;
reg clkout;
assign clk = clkout;
//分频进程,对100Mhz的时钟2*326分频
always @(posedge clk100)   
begin
    if(!rstn)
       begin  cnt <= 16'd0; end
     else
     begin
          if(cnt == 16'd324)
          begin
            clkout <= 1'b1;
            cnt <= cnt + 16'd1;
          end
          else if(cnt == 16'd651)
          begin
            clkout <= 1'b0;
            cnt <= 16'd0;
          end
          else
          begin
            cnt <= cnt + 16'd1;
          end
      end
end
endmodule

仿真程序:
`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////////
// Company:
// Engineer:
//
// Create Date: 2017/12/05 18:31:59
// Design Name:
// Module Name: uart_simu
// Project Name:
// Target Devices:
// Tool Versions:
// Description:
//
// Dependencies:
//
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
//
//////////////////////////////////////////////////////////////////////////////////


module uart_simu(

    );
   reg rstn;
   reg clk100;


   wire clk;

   clkdiv mytest(
            .clk100(clk100),
            .rstn(rstn),
            .clk(clk)

   );
    initial
    begin
         rstn = 0; #10;rstn = 1;
         clk100 = 0; forever #20 clk100 = ~clk100;
    end
endmodule



仿真结果:



本帖子中包含更多资源

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

x
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则