笔记5-vivado中clock 的IP - 单端的晶振输入

 这里选MMCM 进行配置

 

 

 

 用例化来调用IP,先找到生成IP后,接口例化的地方,软件已经自动例化好,只需将下面这段拷贝到工程文件中进行调用

 拷贝到led_prj.v文件中

  1 `timescale 1ns / 1ps
  2 //////////////////////////////////////////////////////////////////////////////////
  3 // Company: 
  4 // Engineer: 
  5 // 
  6 // Create Date: 2023/09/03 13:42:40
  7 // Design Name: 
  8 // Module Name: led_prj
  9 // Project Name: 
 10 // Target Devices: 
 11 // Tool Versions: 
 12 // Description: 
 13 // 
 14 // Dependencies: 
 15 // 
 16 // Revision:
 17 // Revision 0.01 - File Created
 18 // Additional Comments:
 19 // 
 20 //////////////////////////////////////////////////////////////////////////////////
 21 
 22 
 23 module led_prj(         clk                     ,           //50M--20ns
 24                         rst_n                   ,
 25                         led_out                 ,
 26                         clk_out_200m            ,
 27                         clk_out_100m            ,
 28                         clk_out_100m_180        ,
 29                         clk_out_50m             ,
 30                         clk_out_25m
 31     );
 32 
 33 parameter               T40_ms = 24'd10_000_000  ;
 34 
 35 input                   clk                     ;
 36 input                   rst_n                   ;
 37         
 38 output  [3-1 :0]        led_out                 ;
 39 output                  clk_out_200m            ;
 40 output                  clk_out_100m            ;
 41 output                  clk_out_100m_180        ;
 42 output                  clk_out_50m             ;
 43 output                  clk_out_25m             ;
 44     
 45 reg     [24-1:0]        cnt0                    ;
 46 reg     [3-1 :0]        led_out                 ;
 47 wire                    add_cnt0                ;
 48 wire                    end_cnt0                ;
 49 
 50 wire                    locked                  ;
 51 
 52 always@(posedge clk or negedge rst_n)begin
 53     if(!rst_n)begin
 54         cnt0 <= 0;
 55     end
 56     else if(add_cnt0)begin
 57         if(end_cnt0)begin
 58             cnt0 <= 0;
 59         end
 60         else begin
 61             cnt0 <= cnt0 + 1'b1;
 62         end
 63     end
 64 end
 65 
 66 assign add_cnt0 = 1;
 67 assign end_cnt0 = add_cnt0 && cnt0 == T40_ms -1;
 68 
 69 always@(posedge clk or negedge rst_n)begin
 70     if(!rst_n)begin
 71         led_out <= 3'b001;
 72     end
 73     else if(end_cnt0)begin
 74         led_out <= {led_out[1:0],led_out[2]};
 75     end
 76 end
 77 
 78 clk_wiz_0 instance_name
 79    (
 80     // Clock out ports
 81     .clk_out1_200m      (clk_out_200m           ),     // output clk_out1_200m
 82     .clk_out2_100m      (clk_out_100m           ),     // output clk_out2_100m
 83     .clk_out3_100m_180  (clk_out_100m_180       ),     // output clk_out3_100m_180
 84     .clk_out4_50m       (clk_out_50m            ),     // output clk_out4_50m
 85     .clk_out5_25m       (clk_out_25m            ),     // output clk_out5_25m
 86     // Status and control signals
 87     .reset              (~rst_n                 ),      // input reset
 88     .locked             (locked                 ),      // output locked
 89    // Clock in ports
 90     .clk_in1            (clk                    )       // input clk_in1                   
 91     );      
 92 
 93 //调用IP中的ILA,在线调试逻辑分析仪,先在工程中例化接口
 94 //时钟必须有
 95 //需要看什么信号,就添加几个probex,比如 需看cnt0 和 led_out
 96 `ifdef ILA_LED_PRJ
 97     ila_led_prj u_ila_led_prj(
 98                 .clk    (clk        ),
 99                 .probe0 (cnt0       ),
100                 .probe1 (end_cnt0   ),
101                 .probe2 (led_out    )
102     );
103 `endif
104 
105 
106 
107 endmodule
View Code

仿真测试文件led_sim.v也需稍微改动下

 1 `timescale 1ns / 1ps
 2 //////////////////////////////////////////////////////////////////////////////////
 3 // Company: 
 4 // Engineer: 
 5 // 
 6 // Create Date: 2023/09/03 21:33:34
 7 // Design Name: 
 8 // Module Name: led_sim
 9 // Project Name: 
10 // Target Devices: 
11 // Tool Versions: 
12 // Description: 
13 // 
14 // Dependencies: 
15 // 
16 // Revision:
17 // Revision 0.01 - File Created
18 // Additional Comments:
19 // 
20 //////////////////////////////////////////////////////////////////////////////////
21 
22 
23 module led_sim();     
24  
25 reg                 clk                 ;
26 reg                 rst_n               ;
27 
28 wire [3-1:0]        led_out             ;
29 
30 wire                clk_out_200m        ;
31 wire                clk_out_100m        ;
32 wire                clk_out_100m_180    ;
33 wire                clk_out_50m         ;
34 wire                clk_out_25m         ;
35 
36 parameter           CLK_CYCLE = 20  ;   //  20ns 
37 
38 initial begin
39     clk = 0;
40     forever begin
41         #(CLK_CYCLE/2);
42         clk = ~clk;
43     end
44 end
45 
46 initial begin
47    #1;
48    rst_n = 0;
49    #(CLK_CYCLE*5);
50    rst_n = 1;
51 end
52 
53 //渚嬪寲
54 led_prj     u_led_prj(         
55                         .clk                (clk                ),           //50M--20ns
56                         .rst_n              (rst_n              ),
57                         .led_out            (led_out            ),
58                         .clk_out_200m       (clk_out_200m       ),
59                         .clk_out_100m       (clk_out_100m       ),
60                         .clk_out_100m_180   (clk_out_100m_180   ),
61                         .clk_out_50m        (clk_out_50m        ),
62                         .clk_out_25m        (clk_out_25m        )
63 );
64 
65 endmodule
View Code

 综合分析

 

 添加信号,观察波形

用ILA 在线调试工具抓取波形 ,先把IO分配好

在led_prj.v文件中,修改ILA例化端口 

 

修改ILA 的IP 设置

 

 确认后,直接点生成bit, 进行编译 - 综合 -布局 布线- 生成bit - 下载烧录 ,软件自动调出ILA 波形窗口

 发现只有25M的时钟,其他几个时钟没看到,是因为时钟采用率不够导致,需要修改下如下

 直接点生成bit文件,下载到板上进行验证抓取波形如下:

除了200M时钟没看到,其他的几个时钟都能看到,200M试过同相 和 反相的 

assign  clk_200m_temp = clk_out_200m;

assign  clk_200m_temp = ~ clk_out_200m;

这两种情况下,都是无法看到。估计这也是采样速率问题导致。不纠结了,可以用示波器观察引脚输出的波形即可

 

posted @ 2023-09-05 23:22  MyBooks  阅读(120)  评论(0编辑  收藏  举报