亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? top_hc164_driver.v

?? 通過驗(yàn)證的計(jì)數(shù)器
?? V
字號:
////////////////////////////////////////////////////////////////////////////////
//       ____  _      __  ___                                                 //
//      / __ \(_)____/ / / (_)____      本設(shè)計(jì)由 www.richic.com 提供,并在其低//
//     / /_/ / / ___/ /_/ / / ___/      端產(chǎn)品:FPGA學(xué)習(xí)板、FPGA試驗(yàn)系統(tǒng)以及其//
//    / _, _/ / /__/ __  / / /__        高端產(chǎn)品:FPGA開發(fā)系統(tǒng)中驗(yàn)證通過,您可//
//   /_/ |_/_/\___/_/ /_/_/\___/        以在此基礎(chǔ)上修改,復(fù)制并分發(fā)。但我們并//
//                                      不承諾本設(shè)計(jì)可以用做商業(yè)產(chǎn)品,同時(shí)我們//
//  不保證設(shè)計(jì)的通用性。為了方便更新以及修改請保留設(shè)計(jì)的版本信息,請對自行修改//
//  部分添加足夠注釋。對設(shè)計(jì)如有其他建議請到 www.richic.com網(wǎng)站進(jìn)行討論       //
//                                                                            //
////////////////////////////////////////////////////////////////////////////////
//                                                                            //
//  FPGA實(shí)驗(yàn)教程          http://www.richic.com/lab                           //
//  FPGA實(shí)驗(yàn)教程EDACN鏡像 http://www.edacn.com/rhic/                          //
//  本教程所有設(shè)計(jì)在本公司開發(fā)板上驗(yàn)證通過                                    //
//                                                                            //
////////////////////////////////////////////////////////////////////////////////
//  Company:    www.richic.com                                                //
//  Engineer:   mail007 (Gavin.xue)                                           //
//                                                                            //
//  Design Name:                                                              //
//  Module Name:                                                              //
//  Target Device:                                                            //
//  Tool versions: Simulation:                                                //
//                 Synthesis:     XST(ise6.3...sp2)                           //
//                 Place&Routing: ISE6.3...sp2                                //
//                 Others tools:                                              //
//  Create Date:   2006-01-31 11:37                                           //
//  Description:                                                              //
//                                                                            //
//  LOG:                                                                      //
//                                                                            //
////////////////////////////////////////////////////////////////////////////////
`timescale 1ns/1ns

  // ---------------------------------------------------------------------------
  //HC164用來驅(qū)動(dòng)數(shù)碼管以及LED指示燈,動(dòng)態(tài)掃描數(shù)碼管的是利用視覺暫留的特性進(jìn)行顯
  //示景物引起人的視覺印象,在景物消失后還能在視網(wǎng)膜上保持0。1秒的時(shí)間叫做視覺暫
  //留。可以將數(shù)據(jù)刷新速率可以為10Hz(0.1s),同時(shí)我們需要對四位數(shù)據(jù)進(jìn)行掃描,因此
  //數(shù)據(jù)刷新速率最低應(yīng)該為10Hz×4。最高可以為50MHz(HC164可以工作在50-175MHz)。
  //根據(jù)實(shí)際情況我們可以定為 762.939453125 = 50MHz/2**16,
  //因此接口處led,seg_value,dot數(shù)據(jù)的變化速率最大不能超過為50MHz/2**14
  // ---------------------------------------------------------------------------

module top_hc164_driver(
    clk,
    rst_n,
    led,
    seg_value,
    dot,
    hc_si,
    hc_cp
    );

  // ---------------------------------------------------------------------------
  //
  //  input signals
  //  led[3:0] :       led3-led0 對應(yīng)原理圖中D5,D4,D3,D2四位LED燈,高電平有效。
  //  seg_value[15:0] :四位共陰極數(shù)碼顯示的數(shù)據(jù),從高到低每4bit為數(shù)碼管一位。
  //  dot[3:0] :       四位共陰極數(shù)碼管顯示的小數(shù)點(diǎn)位,從高到低
  //  hc_si :          本模塊數(shù)據(jù)串行輸出,hc164數(shù)據(jù)串行輸入。
  //  hc_cp :          本模塊輸出,hc164時(shí)鐘輸入。
  //  
  // ---------------------------------------------------------------------------
  input           clk;
  input           rst_n;  
  input   [3 :0]  led;        
  input   [15:0]  seg_value;  
  input   [3 :0]  dot;
  output  reg     hc_si;                //HC164 Data input
  output  reg     hc_cp;                //HC164 Clock input active Rising edges

  reg     [5 :0]  tx_cnt;
  
//  wire  [15:0]  seg_value = 16'h1234;
//  wire  [3:0]   dot = 4'b0010; 
//  wire  [3:0]   led = 4'b1111;
  
  // ---------------------------------------------------------------------------
  //
  //  信號命名說明
  //  hc_data : 送到兩個(gè)hc164中16bit的數(shù)據(jù)(每個(gè)hc164有8bit),hc164 data input
  //  hc_data_44bit: hc_data的第四個(gè)4BIT數(shù)據(jù),
  //                 LED顯示信號,對應(yīng)原理圖中HC_Q15,HC_Q14,HC_Q13,HC_Q12四位,
  //                 用來點(diǎn)亮D5,D4,D3,D2四位LED燈,高電平有效。
  //  hc_data_34bit: hc_data的第三個(gè)4bit數(shù)據(jù),即hc_data[11:8];對應(yīng)原理圖中
  //                 HC_Q11,HC_Q10,HC_Q9,HC_Q8數(shù)碼管位選信號,低電平有效。
  //  hc_data_31bit: hc_data的第三個(gè)1bit數(shù)據(jù),即hc_data[2];對應(yīng)原理圖中HC_Q2,數(shù)
  //                 碼管小數(shù)點(diǎn)位,高電平有效。 
  //  hc_data[7:0]: 包括hc_data_31bit,這8bit用來做為數(shù)碼管段選信號,高電平有效
  //
  // ---------------------------------------------------------------------------
  reg   [6:0]   hex2led;        //hex-to-seven-segment decoder output 
  reg   [3:0]   hc_data_34bit;  
  reg           hc_data_31bit;    
  
  wire  [15:0]  hc_data = {led,
                          hc_data_34bit,
                          hex2led[6:2],
                          hc_data_31bit,
                          hex2led[1:0]
                          };
  // ---------------------------------------------------------------------------
  //
  //  之所以需要取反,是因?yàn)閷c_si賦值時(shí)從最低位開始,而原理圖中設(shè)計(jì)希望從最高位
  //  開始發(fā)送數(shù)據(jù)。
  //
  // ---------------------------------------------------------------------------
  wire  [15:0]  hc_data_inv = {
                          hc_data[0],
                          hc_data[1],
                          hc_data[2],
                          hc_data[3],
                          hc_data[4],
                          hc_data[5],
                          hc_data[6],
                          hc_data[7],
                          hc_data[8],
                          hc_data[9],
                          hc_data[10],
                          hc_data[11],
                          hc_data[12],
                          hc_data[13],
                          hc_data[14],
                          hc_data[15]
                          };

  reg [15:0]  clk_cnt;
  always @ ( posedge clk or negedge rst_n )
    if ( !rst_n ) clk_cnt <= 16'd0;
    else  clk_cnt <= clk_cnt + 1'b1;

  //  reg [9:0]  clk_cnt;
  //  always @ ( posedge clk or negedge rst_n )
  //    if ( !rst_n ) clk_cnt <= 10'd0;
  //    else  clk_cnt <= clk_cnt + 1'b1;      
  // ---------------------------------------------------------------------------
  // 
  //  數(shù)據(jù)管4位計(jì)數(shù)器,本計(jì)數(shù)器用來區(qū)分每位數(shù)值,位碼,以及每位的小數(shù)點(diǎn)等三個(gè)
  //  信息,每一位數(shù)值將通過hex2led模塊變換成數(shù)碼管位碼。
  //
  // ---------------------------------------------------------------------------
  reg [1:0] seg_led_num;
  always @ ( posedge clk or negedge rst_n )
    if (!rst_n ) seg_led_num <= 2'b00;
    else if ( clk_cnt == 16'hFFFF ) seg_led_num <= seg_led_num + 1'b1;

  reg   [3:0] hex;
  always @ ( * )
    case ( seg_led_num )
      2'b00: hex = seg_value[15:12];
      2'b01: hex = seg_value[11:8];
      2'b10: hex = seg_value[7:4];
      2'b11: hex = seg_value[3:0];
    endcase 
  
  // ---------------------------------------------------------------------------
  // hex-to-seven-segment decoder
  //
  // segment encoding
  //      11
  //      ---  
  //  10 |   | 7
  //      ---   <- 5
  //  1  |   | 4
  //      --- .  3
  //       2 
  //  Q[6:0] = p11 p10 p7 p5 _ p4 p2 p1 
  // ---------------------------------------------------------------------------
  always @ ( * )
    begin
      case (hex)                        //數(shù)值 
	    4'H1  : hex2led = 7'b0010_100;	  //1          
	    4'H2  : hex2led = 7'b1011_011;	  //2   
	    4'H3  : hex2led = 7'b1011_110;	  //3   
	    4'H4  : hex2led = 7'b0111_100;	  //4   
	    4'H5  : hex2led = 7'b1101_110;	  //5   
	    4'H6  : hex2led = 7'b1101_111;	  //6   
	    4'H7  : hex2led = 7'b1010_100;	  //7   
	    4'H8  : hex2led = 7'b1111_111;	  //8   
	    4'H9  : hex2led = 7'b1111_100;	  //9   
	    4'HA  : hex2led = 7'b1111_101;	  //A   
	    4'HB  : hex2led = 7'b0101_111;	  //b   
	    4'HC  : hex2led = 7'b1100_011;	  //C   
	    4'HD  : hex2led = 7'b0011_111;	  //d   
	    4'HE  : hex2led = 7'b1101_011;	  //E   
	    4'HF  : hex2led = 7'b1101_001;	  //F   
	    default : hex2led = 7'b1110_111;	//0   
    endcase
  end

//hex2led_common_cathode hex2led_inst(
//    .hex    ( hex ),
//    .led    ( hex2led ));
 
  always @ ( * )
    case ( seg_led_num )
      2'b00:hc_data_34bit[3:0] = 4'b0111;
      2'b01:hc_data_34bit[3:0] = 4'b1011;
      2'b10:hc_data_34bit[3:0] = 4'b1101;
      2'b11:hc_data_34bit[3:0] = 4'b1110;
    endcase  

  always @ ( * )
    case ( seg_led_num )
      2'b00:hc_data_31bit = dot[3];
      2'b01:hc_data_31bit = dot[2];
      2'b10:hc_data_31bit = dot[1];
      2'b11:hc_data_31bit = dot[0];
    endcase  
  
  // ---------------------------------------------------------------------------
  // 
  // HC164 的 hc_si 以及hc_cp信號的產(chǎn)生,通過一個(gè)6位的計(jì)數(shù)器來控制.hc_si從信號
  // hc_data_inv的最低位開始發(fā)送,原理圖中需要從最高位發(fā)送,因此在此之前需要對整
  // 個(gè)信號取反。
  //
  // ---------------------------------------------------------------------------  
  always @ ( posedge clk or negedge rst_n )
    if (!rst_n ) tx_cnt <= 6'd0;
    else if ( clk_cnt[15] ) tx_cnt <= 6'd0;      
    else if ((!clk_cnt[15]) && (tx_cnt <= 6'd32 )) tx_cnt <= tx_cnt + 1'b1;

  always @ ( posedge clk or negedge rst_n )
    if (!rst_n)  hc_cp <= 1'b0;
    else if ( clk_cnt[15] ) hc_cp <= 1'b0;
    else if ((!clk_cnt[15]) && (tx_cnt < 6'd32 )) hc_cp <= !hc_cp;
  
  always @ ( posedge clk or negedge rst_n )
    if (!rst_n )  hc_si <= 1'b1;
    else hc_si <= hc_data_inv[tx_cnt[4:1]];
    
//  assign  hc_si = hc_data_inv[tx_cnt[4:1]];
    
//  reg [5:0] tx_cnt;
//  always @ ( posedge clk or negedge rst_n )
//    if (!rst_n ) tx_cnt <= 6'd0;
//    else if ( clk_cnt[9] ) tx_cnt <= 6'd0;      
//    else if ( (!clk_cnt[9]) && (tx_cnt < 6'd32 )) tx_cnt <= tx_cnt + 1'b1;
//
//  always @ ( posedge clk or negedge rst_n )
//    if (!rst_n)  hc_cp <= 1'b0;
//    else if ( clk_cnt[9] ) hc_cp <= 1'b0;
//    else if ((!clk_cnt[9]) && (tx_cnt < 6'd32 )) hc_cp <= !hc_cp;
    
endmodule

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜桃av一区二区三区| 亚洲激情图片qvod| 激情偷乱视频一区二区三区| 91精品国产91久久久久久一区二区| 亚洲欧美日本韩国| 欧美丝袜自拍制服另类| 日韩不卡免费视频| 欧美精品一区视频| 国产**成人网毛片九色 | 国产精品女人毛片| 色呦呦一区二区三区| 一区二区三国产精华液| 欧美精品一二三四| 国产又粗又猛又爽又黄91精品| 国产日韩综合av| 色哟哟国产精品| 麻豆精品一区二区三区| 国产精品麻豆视频| 欧美精品久久久久久久多人混战| 蜜桃久久精品一区二区| 中国色在线观看另类| 欧美影院精品一区| 国产一区二区久久| 亚洲福利视频导航| 精品粉嫩超白一线天av| 91丨九色porny丨蝌蚪| 婷婷久久综合九色综合绿巨人| 日韩精品资源二区在线| 成人av先锋影音| 日韩电影一二三区| 国产精品女上位| 欧美一级二级三级蜜桃| www.亚洲免费av| 美女在线一区二区| 亚洲综合色区另类av| 26uuu久久综合| 欧美日韩日日夜夜| www.欧美.com| 国产在线一区观看| 日韩在线观看一区二区| 国产精品电影一区二区三区| 91精品黄色片免费大全| 91麻豆视频网站| 国产精品综合在线视频| 亚洲h动漫在线| 成人欧美一区二区三区1314| 日韩三级电影网址| 欧美日韩中文字幕一区二区| av午夜精品一区二区三区| 久久99精品国产麻豆不卡| 亚洲国产日韩a在线播放| 亚洲欧洲一区二区三区| 欧美精品一区二区三区蜜桃| 欧美日韩在线三级| 色哟哟一区二区在线观看| 国产精品69久久久久水密桃| 日欧美一区二区| 亚洲国产日日夜夜| 亚洲一区在线电影| 综合久久久久综合| 中文字幕一区二区三区视频| 久久午夜色播影院免费高清| 欧美一级淫片007| 欧美日韩国产大片| 欧美视频三区在线播放| 一本久道中文字幕精品亚洲嫩| 高清在线不卡av| 国产成人精品三级麻豆| 国精产品一区一区三区mba视频 | 在线观看视频一区二区欧美日韩| 不卡一卡二卡三乱码免费网站| 国产成人av一区二区| 精品亚洲国内自在自线福利| 日本女优在线视频一区二区| 日日欢夜夜爽一区| 免费在线观看精品| 久久超碰97中文字幕| 极品少妇一区二区三区精品视频 | 六月丁香婷婷色狠狠久久| 日日欢夜夜爽一区| 麻豆精品新av中文字幕| 国产在线播放一区| 丰满白嫩尤物一区二区| 成人av电影在线观看| 99精品热视频| 欧美网站一区二区| 91精选在线观看| 欧美r级在线观看| 久久影视一区二区| 国产婷婷精品av在线| 亚洲国产成人一区二区三区| 国产精品二三区| 伊人性伊人情综合网| 亚洲a一区二区| 麻豆精品久久久| 国产**成人网毛片九色| 色婷婷av一区| 91麻豆精品国产91久久久使用方法| 欧美一区二区国产| 国产三区在线成人av| 亚洲欧洲成人自拍| 亚洲成人免费在线| 在线欧美小视频| 欧美日韩卡一卡二| 久久日韩粉嫩一区二区三区| 久久久久久久精| 亚洲精品国产无套在线观| 三级影片在线观看欧美日韩一区二区| 日韩av一区二区三区四区| 国产大陆亚洲精品国产| 在线视频你懂得一区| 精品国产网站在线观看| 亚洲女性喷水在线观看一区| 石原莉奈在线亚洲三区| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 久久久久久久综合狠狠综合| 亚洲色图欧洲色图| 激情综合色播五月| 色av一区二区| 久久久久久久综合日本| 亚洲国产视频一区二区| 国产高清精品网站| 91麻豆精品国产自产在线观看一区| 国产午夜精品在线观看| 亚洲成av人片一区二区| 国产成人自拍在线| 欧美一区二区三区系列电影| 中文幕一区二区三区久久蜜桃| 日韩电影在线观看网站| 91猫先生在线| 国产欧美久久久精品影院| 日日夜夜免费精品视频| 99久久伊人精品| 亚洲精品一区二区三区精华液 | 国产成人激情av| 91麻豆精品国产自产在线观看一区| 国产精品天美传媒沈樵| 美女在线一区二区| 欧美日韩一二区| 一区免费观看视频| 国产成人啪午夜精品网站男同| 欧美老年两性高潮| 亚洲欧美另类小说视频| 国产suv一区二区三区88区| 欧美一区二区精品在线| 亚洲国产va精品久久久不卡综合| 大桥未久av一区二区三区中文| 日韩一区二区精品葵司在线| 亚洲成人精品在线观看| 色综合天天天天做夜夜夜夜做| 国产丝袜美腿一区二区三区| 麻豆免费看一区二区三区| 欧美精品在线视频| 亚洲与欧洲av电影| 色婷婷av一区二区三区gif| 中文字幕日韩一区二区| 成人综合日日夜夜| 久久久久国产一区二区三区四区| 免费av成人在线| 欧美一区二区黄| 美女性感视频久久| 日韩一区二区影院| 免费成人你懂的| 日韩天堂在线观看| 美女看a上一区| 精品国产一区二区精华| 精品一区二区三区在线播放视频 | 国产精品伦理一区二区| 国产91精品一区二区麻豆亚洲| 久久亚洲精品国产精品紫薇| 久久97超碰国产精品超碰| 精品欧美乱码久久久久久| 激情久久久久久久久久久久久久久久| 欧美一区二区三区视频| 蜜臀av国产精品久久久久| 日韩丝袜情趣美女图片| 精品夜夜嗨av一区二区三区| 337p日本欧洲亚洲大胆色噜噜| 黄色资源网久久资源365| 久久综合久久综合亚洲| 国产精品自拍毛片| 中文字幕亚洲不卡| 精品视频一区三区九区| 五月激情综合婷婷| 精品久久久久久久久久久久久久久久久| 免费成人美女在线观看.| www精品美女久久久tv| 成人av网址在线| 一区二区理论电影在线观看| 91精品国产综合久久久久久久久久| 久久精品国产在热久久| 久久先锋资源网| jizz一区二区| 亚洲成人av一区二区三区| 日韩精品在线一区| 成人av在线播放网站| 亚洲 欧美综合在线网络| 久久只精品国产| 色婷婷综合五月| 久久精品久久综合|