久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

標題: FPGA應用—流水燈設計思路+程序詳解 [打印本頁]

作者: piaolin    時間: 2015-11-1 17:58
標題: FPGA應用—流水燈設計思路+程序詳解

一、設計需求

設計一個功能模塊使紅色颶風E45板上的8盞led燈流動起來,像流水一樣。

二、設計思路

首先,有一點要明確的是led燈的每一次流動都是需要時間間隔的。也就是說,8盞led燈所對應的狀態只有經過一段時間延遲后才能發生改變。根據這種思路,在開始設計之前提出兩個問題:第一,led燈的狀態需要多久發生一次改變;第二,led燈的狀態根據什么發生改變。對于第一個問題,可以通過設計計時器來控制時間,如每0.5秒(即2Hz)就產生一個周期的時鐘或時鐘使能信號;對于第二個問題,led燈的狀態可以在生成的2Hz時鐘上升沿發生改變,也可以在時鐘使能信號下發生改變。但在FPGA設計技巧中推薦同步設計,于是本設計放棄采用產生時鐘信號的方案,而是選擇時鐘使能信號。其對應的時序如圖1所示。

圖1 流水燈時序圖

三、設計實現

在計時器的作用下,每隔0.5秒就產生一個高電平的時鐘使能信號cnt_flag,而當檢測到時鐘使能信號為高電平時,led燈狀態led_data發生改變,這樣就實現了流水燈的效果。其對應Verilog HDL實現如下所示:

`timescale 1ns/1ps
module water_led(
    rst_n,
    clk,
    led_data
    );
    //  參數定義
    parameter   DATA_WIDTH = 8;                          //  通過修改該參數可應用于led盞數不同的場合
    
    //  端口定義
    input                           rst_n;               //  全局異步復位
    input                           clk;                 //  50MHz
    output reg  [DATA_WIDTH-1:0]    led_data;
    
    //  實現每0.5秒就產生一個時鐘使能信號
    parameter   DELAY_CNT = 25'd25_000_000;              //  0.5s
    reg         [24:0]              cnt;                 //  計數器變量
    
    wire    cnt_flag = (cnt==DELAY_CNT-1'b1);            //  時鐘使能信號
    
    always @(posedge clk or negedge rst_n)
    begin
        if(rst_n==1'b0)
            cnt <= 0;
        else if(cnt_flag==1'b1)
            cnt <= 0;
        else
            cnt <= cnt + 1'b1;
    end
    
    //  led燈狀態的控制
    always @(posedge clk or negedge rst_n)
    begin
        if(rst_n==1'b0)
            led_data <= {{(DATA_WIDTH-1){1'b0}},1'b1};   //  復位初始化
        else if(cnt_flag==1'b1)
            led_data <= {led_data[DATA_WIDTH-2:0],led_data[DATA_WIDTH-1]};  //  左移
        else
            led_data <= led_data;
    end

endmodule

其modelsim功能仿真如圖2所示(為了使仿真節省大量時間,將參數DELAY_CNT改小,如本設計改為DELAY_CNT=25'd250):

圖2 流水燈modelsim功能仿真

功能仿真正確之后,便可進行綜合(綜合之前記得把DELAY_CNT改為25'd25_000_000)、管腳約束、實現、生成bit流、下載到板子,最后可在板子上看到8盞led燈像流水一樣流動起來。



作者: 小白白白123白3    時間: 2019-12-18 20:29
能發一下那個testbeach文件嗎
作者: dkdzax    時間: 2020-5-30 22:38
運行了一下有四個錯誤




歡迎光臨 (http://m.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 亚洲一区中文字幕在线观看 | 成人欧美一区二区三区在线观看 | 在线播放亚洲 | 欧美一区二区 | 一级做a爰片性色毛片视频停止 | 亚洲午夜电影 | 欧美日韩国产欧美 | 久久精品亚洲国产 | 一级看片免费视频 | 精品国产伦一区二区三区观看体验 | 亚洲视频在线看 | 国产免费一区二区 | 欧美精品在线播放 | 六月成人网| 欧美精品在线视频 | 91久久精品日日躁夜夜躁国产 | 精品福利视频一区二区三区 | 91精品国产一区二区三区动漫 | 日本人做爰大片免费观看一老师 | 日本特黄a级高清免费大片 国产精品久久性 | 国产精品久久 | 视频一区二区三区四区五区 | 国产日屁 | 日本网站在线看 | 久操av在线 | 激情久久av一区av二区av三区 | 黄色大片免费网站 | 日韩欧美手机在线 | 国产精品一区视频 | 国产精品久久国产精品 | 精品国产乱码久久久久久丨区2区 | 香蕉超碰 | 黄色毛片大全 | 日韩在线视频免费观看 | 人人操日日干 | 91免费在线看| 一级做a | 日韩成人精品视频 | 精品欧美乱码久久久久久1区2区 | 国产精品久久久久婷婷二区次 | 久久不射电影网 |