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

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 3712|回復(fù): 0
收起左側(cè)

同步FIFO的Verilog實(shí)現(xiàn)

[復(fù)制鏈接]
ID:105323 發(fā)表于 2016-2-23 01:19 | 顯示全部樓層 |閱讀模式
轉(zhuǎn)了一篇?jiǎng)e人寫(xiě)的,沒(méi)看一眼代碼,因?yàn)樽畈幌矚g的就是看別人寫(xiě)的代碼。今天抽空自己寫(xiě)了一段小代碼,在ModelSim中仿真了,結(jié)果還是正確的。
module chipfifo(clk,rst,wr,din,rd,dout,full,empty,half_full);

input clk,rst;
input wr,rd;
input [7:0] din;
output [7:0] dout;
output full,empty,half_full;

reg [7:0] dout;
reg [4:0] cnt_rd;     //讀數(shù)據(jù)指示器
reg [4:0] cnt_wr;     //寫(xiě)數(shù)據(jù)指示器
reg [4:0] cnt_data;   //數(shù)據(jù)個(gè)數(shù)指示器
reg [7:0] fiforam[15:0];    //FIFO存儲(chǔ)數(shù)組

reg empty,full,half_full;

always @ (posedge clk or negedge rst)
begin
if(!rst)    //異步復(fù)位
begin
  cnt_rd<=5'd0;
  cnt_wr<=5'd0;
  cnt_data<=5'd0;
  full<=1'd0;
  empty<=1'd0;
  half_full<=1'd0;  
end
else
begin
  case({rd,wr})
  2'b01:     //只寫(xiě)操作
  begin
   if(!full)   //FIFO沒(méi)有寫(xiě)滿(mǎn),則執(zhí)行寫(xiě)操作
   begin
    if(cnt_data==5'd16)   //FIFO中已經(jīng)有15個(gè)數(shù)據(jù),再寫(xiě)就滿(mǎn)了
    begin
     fiforam[cnt_wr-1]<=din;
     cnt_data<=cnt_data;
     full<=1'd1;      
     cnt_wr<=4'd0;
    end
    else
    begin
     fiforam[cnt_wr-1]<=din;
     cnt_data<=cnt_data+5'd1;
     full<=1'd0;      
     if(cnt_wr==5'd16)
      cnt_wr<=4'd1;
     else
      cnt_wr<=cnt_wr+5'd1;
    end
   
    if(cnt_wr==5'd8)  //半滿(mǎn)標(biāo)志
     half_full<=1'd1;
    else
     half_full<=1'd0;
   
    empty<=1'd0;     //只寫(xiě)時(shí)空標(biāo)志為0
   end
   else
   begin
    cnt_rd<=cnt_rd;
    cnt_wr<=cnt_wr;
    cnt_data<=cnt_data;
    full<=full;
    empty<=empty;
    half_full<=half_full;  
   end
  end
  2'b10:  //只讀操作
  begin
   if(!empty)   //FIFO沒(méi)有讀空,則執(zhí)行讀操作
   begin
    if(cnt_data==5'd0)   //FIFO中只有1個(gè)數(shù)據(jù),再讀就空了
    begin
     dout<=fiforam[cnt_rd-1];
     cnt_data<=cnt_data;
     empty<=1'd1;            
     cnt_rd<=5'd0;
    end
    else
    begin
     dout<=fiforam[cnt_rd-1];
     cnt_data<=cnt_data-5'd1;
     empty<=1'd0;      
     if(cnt_rd==5'd16)
      cnt_rd<=5'd0;
     else
      cnt_rd<=cnt_rd+5'd1;
    end
    full<=1'd0;     //只寫(xiě)時(shí)空標(biāo)志為0
   end
   else
   begin
    cnt_rd<=cnt_rd;
    cnt_wr<=cnt_wr;
    cnt_data<=cnt_data;
    full<=full;
    empty<=empty;
    half_full<=half_full;
   end
  end
  2'b11:     //讀寫(xiě)同時(shí)進(jìn)行
  begin
   case({full,empty})
   2'b00:          //既沒(méi)有寫(xiě)滿(mǎn)也沒(méi)有讀空的情況
   begin
    dout<=fiforam[cnt_rd-1];
    if(cnt_rd==5'd16)   //如果指示器到最后了,則轉(zhuǎn)到開(kāi)始
     cnt_rd<=5'd1;
    else
     cnt_rd<=cnt_rd+5'd1;
     
    fiforam[cnt_wr-1]<=din;      
    if(cnt_wr==5'd16)
     cnt_wr<=5'd1;
    else
     cnt_wr<=cnt_wr+5'd1;   
   end
   2'b01:   //沒(méi)有寫(xiě)滿(mǎn),但已讀空的情況
   begin
    dout<=din;
   end
   2'b10:   //寫(xiě)滿(mǎn)的情況
   begin
    dout<=fiforam[cnt_rd-1];
    if(cnt_rd==5'd16)   //如果指示器到最后了,則轉(zhuǎn)到開(kāi)始
     cnt_rd<=4'd0;
    else
     cnt_rd<=cnt_rd+4'd1;
     
    fiforam[cnt_wr-1]<=din;      
    if(cnt_wr==5'd16)
     cnt_wr<=4'd0;
    else
     cnt_wr<=cnt_wr+4'd1;   
   end
   endcase
  end
  default:
  begin
   cnt_rd<=cnt_rd;
   cnt_wr<=cnt_wr;
   cnt_data<=cnt_data;
   full<=full;
   empty<=empty;
   half_full<=half_full;  
  end
  endcase
end
end

endmodule


回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 国产高清精品一区二区三区 | 夜夜爽夜夜操 | 91精品久久久久久久久久 | 在线日韩欧美 | av片在线播放 | 成人欧美一区二区三区在线播放 | 国产视频精品在线 | 网站国产| 久久这里只有精品首页 | 成人免费在线观看 | 久久aⅴ乱码一区二区三区 亚洲国产成人精品久久久国产成人一区 | 亚洲精品一区二区三区蜜桃久 | 国产色网站 | 国产一区二区视频免费在线观看 | 国产精品成人一区二区三区夜夜夜 | 99色综合| 精品中文字幕一区二区三区 | 奇米久久久 | 精品网| www.天天操| 一区二区三区中文字幕 | 欧美xxxx色视频在线观看免费 | 天天操欧美 | 在线视频91 | 日韩在线一区二区 | 国产1区2区3区 | 日韩精品久久一区二区三区 | 日韩视频在线观看一区二区 | 99久久久久久| 97人澡人人添人人爽欧美 | 丁香婷婷成人 | 中文字幕99 | 国产三级一区二区三区 | 亚洲一区二区三区乱码aⅴ 四虎在线视频 | 国产精品久久久久久吹潮 | 在线观看av免费 | 国产精品海角社区在线观看 | 久久久噜噜噜久久中文字幕色伊伊 | 免费xxxx大片国产在线 | 久久久久免费精品国产小说色大师 | 日韩一区二区三区在线 |