ZYNQ_project:led

本次实验完成:led流水间隔0.5s

闪烁间隔0.25s。

名词解释:

analysis分析:对源文件进行全面的语法检查。

synthesis综合:综合的过程是由 FPGA 综合工具箱 HDL 原理图或其他形式源文件进行分析,进而推演出由 FPGA 芯片中底层基本单元表示的电路网表的过程。通俗的讲就是将自己的设计映射到 FPGA 中。

Implementation设计实现:加入一些约束文件。然后可以进行后仿真。

bitstream生成bit流文件:下载进开发板。

时序图:

代码:

分为流水与闪烁。

复制代码
// led闪烁实验,间隔0.25s
module led(
    input       wire            sys_clk     ,
    input       wire            sys_rst_n   ,

    output      reg     [1:0]   led_out     
);
    parameter   MAX_CNT25MS = 1_250_0000 ;

    reg     [23:0]  cnt_25ms ;
    wire            cnt_25ms_flag ;
    always @(posedge sys_clk or negedge sys_rst_n) begin
        if(~sys_rst_n) 
            cnt_25ms <= 24'd0 ;
        else if(cnt_25ms == MAX_CNT25MS - 1)
            cnt_25ms <= 24'd0 ;
        else 
            cnt_25ms <= cnt_25ms + 1'b1 ;
    end
    assign  cnt_25ms_flag = (cnt_25ms == MAX_CNT25MS - 1) ;
    // led_out  
    always @(posedge sys_clk or negedge sys_rst_n) begin
        if(~sys_rst_n) 
            led_out <= 2'd0 ;
        else if(cnt_25ms_flag)
            led_out <= ~led_out ;
    end

endmodule

// 流水
module led(
    input       wire            sys_clk     ,
    input       wire            sys_rst_n   ,
    output      reg     [1:0]   led_out     
);
    parameter MAX_CNT500MS = 25_000_000 ; // 0.5s 5000_0000 1s

    reg     [25:0]      cnt_1s ;
    // reg     [25:0]      cnt_1s
    always @(posedge sys_clk or negedge sys_rst_n) begin // �첽��λ����Ϊ���������¼���
        if(!sys_rst_n)
            cnt_1s <= 26'd0 ;
        else if(cnt_1s == MAX_CNT500MS - 1)
            cnt_1s <= 26'd0 ;
        else 
            cnt_1s <= cnt_1s + 1'b1 ;
    end

    // reg     [1:0]   led_out  
    always @(posedge sys_clk or negedge sys_rst_n) begin
        if(!sys_rst_n) 
            led_out <= 2'b01 ;
        else if(cnt_1s == MAX_CNT500MS - 1)
            led_out <= ~led_out ;
        else
        	led_out <=  led_out ;
    end
ila_0 your_instance_name (
	.clk        ( sys_clk       ) , // input wire clk


	.probe0     ( led_out   ) , // input wire [1:0]  probe0  
	.probe1     ( cnt_1s    ) // input wire [25:0]  probe1
);
endmodule

仿真代码:

复制代码
`timescale 1ns/1ns
module test_led();
    reg             sys_clk     ;
    reg             sys_rst_n   ;

    wire    [1:0]   led_out     ;

led led_inst(
    .sys_clk        ( sys_clk   ) ,
    .sys_rst_n      ( sys_rst_n ) ,
    .led_out        ( led_out   ) 
);

    parameter CYCLE = 20 ;
    defparam  led_inst.MAX_CNT500MS = 25 ;
    initial begin
        sys_clk = 1'b1 ;
        sys_rst_n <= 1'b0 ;
        #(CYCLE * 5 )  ;
        sys_rst_n <= 1'b1 ;
    end
    always #(CYCLE / 2) sys_clk = ~sys_clk ;

endmodule
相关推荐
Alaso_shuang12 小时前
verilog的学习
学习·fpga开发·数字逻辑·数字电路
文火冰糖的硅基工坊13 小时前
[硬件电路-124]:模拟电路 - 信号处理电路 - 测量系统的前端电路详解
前端·嵌入式硬件·fpga开发·架构·信号处理·电路
文火冰糖的硅基工坊13 小时前
[硬件电路-112]:模拟电路 - 信号处理电路 - 二极管的应用 - 峰值检测电路与波形展示
嵌入式硬件·fpga开发·信号处理·电路
XMAIPC_Robot16 小时前
基于STM32+FPGA工业打印机运动控制卡的核心解决方案
stm32·嵌入式硬件·fpga开发
ChipCamp2 天前
Chisel芯片开发入门系列 -- 14. CPU芯片开发和解释4(Load/Store指令再探)
arm开发·青少年编程·fpga开发·scala·dsp开发·risc-v·chisel
霖002 天前
深入讲讲异步FIFO
笔记·vscode·单片机·嵌入式硬件·学习·fpga开发
水果里面有苹果2 天前
3-verilog的使用-1
fpga开发
嵌入式-老费2 天前
再谈fpga开发(总结篇)
fpga开发
minglie12 天前
基于 AXI-Lite 实现可扩展的硬件函数 RPC 框架(附完整源码)
fpga开发
朱古力(音视频开发)2 天前
NDI开发指南
fpga开发·音视频·实时音视频·视频编解码·流媒体