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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? fifo.v

?? 同步FIFO( Verilog HDL )
?? V
字號:
Example F-1 Synthesizable FIFO Model
////////////////////////////////////////////////////////////////////
// FileName:  "Fifo.v"
// Author  :  Venkata Ramana Kalapatapu
// Company :  Sand Microelectronics Inc.
//           (now a part of Synopsys, Inc.),
// Profile :  Sand develops Simulation Models, Synthesizable Cores and
//           Performance Analysis Tools for Processors, buses and
//           memory products.  Sand's products include models for
//           industry-standard components and custom-developed models
//           for specific simulation environments.
//
////////////////////////////////////////////////////////////////////
`define  FWIDTH     32           // Width of the FIFO.
`define  FDEPTH     4            // Depth of the FIFO.
`define  FCWIDTH    2            // Counter Width of the FIFO 2 to power
                                 // FCWIDTH = FDEPTH.
module FIFO(  Clk,
              RstN,
              Data_In,
              FClrN,
              FInN,
              FOutN,
              F_Data,
              F_FullN,
              F_LastN,
              F_SLastN,
              F_FirstN,
              F_EmptyN
           );
input                       Clk;      // CLK signal.
input                       RstN;     // Low Asserted Reset signal.
input [(`FWIDTH-1):0]       Data_In;  // Data into FIFO.
input                       FInN;     // Write into FIFO Signal.
input                       FClrN;    // Clear signal to FIFO.
input                       FOutN;    // Read from FIFO signal.
output [(`FWIDTH-1):0]      F_Data;   // FIFO data out.
output                      F_FullN;  // FIFO full indicating signal.
output                      F_EmptyN; // FIFO empty indicating signal.
output                      F_LastN;  // FIFO Last but one signal.
output                      F_SLastN; // FIFO SLast but one signal.
output                      F_FirstN; // Signal indicating only one
                                      // word in FIFO.
reg                F_FullN;
reg                F_EmptyN;
reg                F_LastN;
reg                F_SLastN;
reg                F_FirstN;
reg    [`FCWIDTH:0]      fcounter; //counter indicates num of data in FIFO
reg    [(`FCWIDTH-1):0]   rd_ptr;      // Current read pointer.
reg    [(`FCWIDTH-1):0]   wr_ptr;      // Current write pointer.
wire   [(`FWIDTH-1):0]    FIFODataOut; // Data out from FIFO MemBlk
wire   [(`FWIDTH-1):0]    FIFODataIn;  // Data into FIFO MemBlk
wire   ReadN  = FOutN;
wire   WriteN = FInN;
assign F_Data     = FIFODataOut;
assign FIFODataIn = Data_In;
    FIFO_MEM_BLK memblk(.clk(Clk),
                        .writeN(WriteN),
                        .rd_addr(rd_ptr),
                        .wr_addr(wr_ptr),
                        .data_in(FIFODataIn),
                        .data_out(FIFODataOut)
                       );
    // Control circuitry for FIFO. If reset or clr signal is asserted,
    // all the counters are set to 0. If write only the write counter
    // is incremented else if read only read counter is incremented
    // else if both, read and write counters are incremented.
    // fcounter indicates the num of items in the FIFO. Write only
    // increments the fcounter, read only decrements the counter, and
    // read && write doesn't change the counter value.
    always @(posedge Clk or negedge RstN)
    begin
       if(!RstN) begin
           fcounter    <= 0;
           rd_ptr      <= 0;
           wr_ptr      <= 0;
       end
       else begin
           if(!FClrN ) begin
               fcounter    <= 0;
               rd_ptr      <= 0;
               wr_ptr      <= 0;
           end
           else begin
               if(!WriteN && F_FullN)
                   wr_ptr <= wr_ptr + 1;
               if(!ReadN && F_EmptyN)
                   rd_ptr <= rd_ptr + 1;
               if(!WriteN && ReadN && F_FullN)
                   fcounter <= fcounter + 1;
               else if(WriteN && !ReadN && F_EmptyN)
                   fcounter <= fcounter - 1;
          end
       end
    end
    // All the FIFO status signals depends on the value of fcounter.
    // If the fcounter is equal to fdepth, indicates FIFO is full.
    // If the fcounter is equal to zero, indicates the FIFO is empty.
    // F_EmptyN signal indicates FIFO Empty Status. By default it is
    // asserted, indicating the FIFO is empty. After the First Data is
    // put into the FIFO the signal is deasserted.
    always @(posedge Clk or negedge RstN)
    begin
       if(!RstN)
          F_EmptyN <= 1'b0;
       else begin
          if(FClrN==1'b1) begin
             if(F_EmptyN==1'b0 && WriteN==1'b0)
                 F_EmptyN <= 1'b1;
             else if(F_FirstN==1'b0 && ReadN==1'b0 && WriteN==1'b1)
                 F_EmptyN <= 1'b0;
          end
          else
             F_EmptyN <= 1'b0;
       end
    end
    // F_FirstN signal indicates that there is only one datum sitting
    // in the FIFO. When the FIFO is empty and a write to FIFO occurs,
    // this signal gets asserted.
    always @(posedge Clk or negedge RstN)
    begin
       if(!RstN)
          F_FirstN <= 1'b1;
       else begin
          if(FClrN==1'b1) begin
             if((F_EmptyN==1'b0 && WriteN==1'b0) ||
                (fcounter==2 && ReadN==1'b0 && WriteN==1'b1))
                 F_FirstN <= 1'b0;
             else if (F_FirstN==1'b0 && (WriteN ^ ReadN))
                 F_FirstN <= 1'b1;
          end
          else begin
             F_FirstN <= 1'b1;
          end
       end
    end
    // F_SLastN indicates that there is space for only two data words
    //in the FIFO.
    always @(posedge Clk or negedge RstN)
    begin
       if(!RstN)
          F_SLastN <= 1'b1;
       else begin
          if(FClrN==1'b1) begin
             if( (F_LastN==1'b0 && ReadN==1'b0 && WriteN==1'b1) ||
                 (fcounter == (`FDEPTH-3) && WriteN==1'b0 && ReadN==1'b1))
                 F_SLastN <= 1'b0;
             else if(F_SLastN==1'b0 && (ReadN ^ WriteN) )
                 F_SLastN <= 1'b1;
          end
          else
             F_SLastN <= 1'b1;
       end
    end
    // F_LastN indicates that there is one space for only one data
    // word in the FIFO.
    always @(posedge Clk or negedge RstN)
    begin
       if(!RstN)
          F_LastN <= 1'b1;
       else begin
          if(FClrN==1'b1) begin
             if ((F_FullN==1'b0 && ReadN==1'b0)  ||
                 (fcounter == (`FDEPTH-2) && WriteN==1'b0 && ReadN==1'b1))
                 F_LastN <= 1'b0;
             else if(F_LastN==1'b0 && (ReadN ^ WriteN) )
                 F_LastN <= 1'b1;
          end
          else
             F_LastN <= 1'b1;
       end
    end
    // F_FullN indicates that the FIFO is full.
    always @(posedge Clk or negedge RstN)
    begin
       if(!RstN)
           F_FullN <= 1'b1;
       else begin
           if(FClrN==1'b1)  begin
               if (F_LastN==1'b0 && WriteN==1'b0 && ReadN==1'b1)
                    F_FullN <= 1'b0;
               else if(F_FullN==1'b0 && ReadN==1'b0)
                    F_FullN <= 1'b1;
           end
           else
               F_FullN <= 1'b1;
       end
    end
endmodule
///////////////////////////////////////////////////////////////////
//
//
//   Configurable memory block for fifo. The width of the mem
//   block is configured via FWIDTH. All the data into fifo is done
//   synchronous to block.
//
//   Author : Venkata Ramana Kalapatapu
//
///////////////////////////////////////////////////////////////////
module FIFO_MEM_BLK( clk,
                     writeN,
                     wr_addr,
                     rd_addr,
                     data_in,
                     data_out
                   );
input                    clk;       // input clk.
input  writeN;  // Write Signal to put data into fifo.
input  [(`FCWIDTH-1):0]  wr_addr;   // Write Address.
input  [(`FCWIDTH-1):0]  rd_addr;   // Read Address.
input  [(`FWIDTH-1):0]   data_in;   // DataIn in to Memory Block
output [(`FWIDTH-1):0]   data_out;  // Data Out from the Memory
                                    // Block(FIFO)
wire   [(`FWIDTH-1):0] data_out;
reg    [(`FWIDTH-1):0] FIFO[0:(`FDEPTH-1)];
assign data_out  = FIFO[rd_addr];
always @(posedge clk)
begin
   if(writeN==1'b0)
      FIFO[wr_addr] <= data_in;
end
endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
5858s免费视频成人| 国产精品美女久久久久aⅴ国产馆| 日韩欧美国产精品一区| 国产精品女主播av| 久久超碰97中文字幕| 91亚洲精品一区二区乱码| 26uuu精品一区二区| 性做久久久久久免费观看| 国产69精品久久久久777| 91精品国产综合久久蜜臀 | jlzzjlzz欧美大全| 欧美一区二区三区视频在线观看 | 久久青草国产手机看片福利盒子| 亚洲视频一区二区在线观看| 国产精品12区| 精品99久久久久久| 日本伊人精品一区二区三区观看方式| 99国内精品久久| 国产精品嫩草影院com| 国精品**一区二区三区在线蜜桃| 欧美猛男gaygay网站| 亚洲欧美日本在线| 97成人超碰视| 国产精品看片你懂得| 国产成人免费网站| 久久一日本道色综合| 国产在线精品一区二区夜色| 日韩亚洲欧美在线| 日韩高清在线一区| 欧美日韩国产a| 日韩成人精品在线观看| 欧美日韩激情一区| 日本伊人色综合网| 精品日韩成人av| 免费xxxx性欧美18vr| 日韩免费一区二区三区在线播放| 奇米精品一区二区三区四区| 91精品国产综合久久久久久久久久| 无吗不卡中文字幕| 在线综合+亚洲+欧美中文字幕| 午夜视频一区二区| 欧美一区二区三区在线看| 男女性色大片免费观看一区二区 | 国产精品美女久久久久久久网站| 国产高清不卡二三区| 中文在线资源观看网站视频免费不卡| 国产精品99久久久久久似苏梦涵| 欧美国产精品专区| 91社区在线播放| 午夜av一区二区三区| 精品理论电影在线观看 | 久久精品国产秦先生| 久久久综合精品| 99国产精品久久| 午夜久久久久久久久久一区二区| 欧美一区日韩一区| 国产成人精品免费看| 亚洲欧洲制服丝袜| 日韩一区二区三区四区| 国产成人免费av在线| 亚洲无人区一区| 欧美电影免费提供在线观看| 成人av资源下载| 午夜免费久久看| 中文子幕无线码一区tr| 7777精品伊人久久久大香线蕉完整版| 国产一区亚洲一区| 亚洲视频电影在线| 欧美mv日韩mv国产网站| 91麻豆福利精品推荐| 天天免费综合色| 中文字幕第一区二区| 欧美日韩精品欧美日韩精品一 | 亚洲人成网站在线| 欧美日韩国产一区| 播五月开心婷婷综合| 秋霞午夜av一区二区三区| 国产精品伦理一区二区| 亚洲在线成人精品| 国产精品天干天干在观线| 成人精品在线视频观看| 午夜国产不卡在线观看视频| 在线观看91精品国产麻豆| 国产精品综合一区二区三区| 亚洲成人第一页| 中文字幕在线不卡一区| 色偷偷88欧美精品久久久| 另类小说视频一区二区| 午夜精品视频在线观看| 国产农村妇女毛片精品久久麻豆| 这里只有精品电影| 一本到一区二区三区| 黑人精品欧美一区二区蜜桃| 亚洲国产欧美日韩另类综合 | 成人影视亚洲图片在线| 免费久久99精品国产| 亚洲图片欧美一区| 亚洲欧美在线高清| 久久久不卡影院| 精品国偷自产国产一区| 91精彩视频在线| 一道本成人在线| 99精品视频在线观看| 国产成人在线视频网址| 蓝色福利精品导航| 日日嗨av一区二区三区四区| 亚洲精品免费看| 中文字幕一区二区三区四区| 久久久精品2019中文字幕之3| 日韩欧美自拍偷拍| 91麻豆精品国产综合久久久久久| 欧美视频在线观看一区| 日本久久一区二区| 在线免费观看日韩欧美| 91黄色激情网站| 在线视频欧美区| 欧美亚洲国产bt| 欧洲av在线精品| 欧美日韩一区二区不卡| 欧美精品少妇一区二区三区| 欧美综合欧美视频| 精品婷婷伊人一区三区三| 欧美群妇大交群中文字幕| 欧美日韩你懂的| 制服丝袜av成人在线看| 日韩一级二级三级精品视频| 精品电影一区二区三区| 国产欧美日韩综合| 亚洲欧洲国产专区| 一区二区在线观看免费视频播放| 亚洲日本在线观看| 亚洲午夜三级在线| 免费观看一级特黄欧美大片| 老司机精品视频线观看86| 激情综合一区二区三区| 国产91精品一区二区| 91免费看`日韩一区二区| 欧美系列日韩一区| 精品精品欲导航| 欧美国产日本韩| 亚洲mv在线观看| 久久福利视频一区二区| 不卡的电影网站| 欧美日韩国产成人在线免费| 精品国产区一区| 国产精品成人免费在线| 日韩av电影免费观看高清完整版 | 94色蜜桃网一区二区三区| 在线观看视频一区二区| 精品女同一区二区| 亚洲欧美国产毛片在线| 麻豆视频观看网址久久| 北条麻妃一区二区三区| 欧美巨大另类极品videosbest| 日韩欧美第一区| 亚洲色欲色欲www| 蜜臀99久久精品久久久久久软件| 国产一区二区免费看| 91久久精品一区二区| 久久久久久99精品| 天堂蜜桃91精品| www.在线欧美| 欧美大片一区二区| 亚洲色欲色欲www| 国产激情一区二区三区桃花岛亚洲| 色综合久久综合网97色综合| 精品国产乱码久久久久久久久| 亚洲日本欧美天堂| 国模一区二区三区白浆| 欧洲精品一区二区| 欧美激情自拍偷拍| 男人的j进女人的j一区| 色av综合在线| 国产亚洲女人久久久久毛片| 亚洲在线视频免费观看| 成人av一区二区三区| 精品国精品国产| 午夜视频一区二区| 91国偷自产一区二区开放时间| 国产视频一区二区三区在线观看| 亚洲aⅴ怡春院| 99精品国产一区二区三区不卡 | 欧美精品 国产精品| 亚洲私人黄色宅男| 国产经典欧美精品| 久久综合精品国产一区二区三区| 婷婷综合五月天| 日本韩国欧美国产| 亚洲四区在线观看| 99麻豆久久久国产精品免费| 精品国产三级电影在线观看| 日本在线不卡视频一二三区| 欧美挠脚心视频网站| 亚洲福利国产精品| 欧美在线视频日韩| 亚洲自拍偷拍av| 欧美系列一区二区| 亚洲成a人v欧美综合天堂| 欧美亚洲日本一区| 天天综合网 天天综合色|