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

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

?? fifo.v

?? some example for verilog design
?? V
字號:
// Synchronous FIFO.  4 x 16 bit words.
//
module fifo (clk, rstp, din, writep, readp, dout, emptyp, fullp);
input		clk;
input		rstp;
input [15:0]	din;
input		readp;
input		writep;
output [15:0]	dout;
output		emptyp;
output		fullp;

// Defines sizes in terms of bits.
//
parameter	DEPTH = 2,		// 2 bits, e.g. 4 words in the FIFO.
		MAX_COUNT = 2'b11;	// topmost address in FIFO.

reg 		emptyp;
reg		fullp;

// Registered output.
reg [15:0]	dout;

// Define the FIFO pointers.  A FIFO is essentially a circular queue.
//
reg [(DEPTH-1):0]	tail;
reg [(DEPTH-1):0]	head;

// Define the FIFO counter.  Counts the number of entries in the FIFO which
// is how we figure out things like Empty and Full.
//
reg [(DEPTH-1):0]	count;

// Define our regsiter bank.  This is actually synthesizable!
//
reg [15:0] fifomem[0:MAX_COUNT];

// Dout is registered and gets the value that tail points to RIGHT NOW.
//
always @(posedge clk) begin
   if (rstp == 1) begin
      dout <= 16'h0000;
   end
   else begin
      dout <= fifomem[tail];
   end
end 
     
// Update FIFO memory.
always @(posedge clk) begin
   if (rstp == 1'b0 && writep == 1'b1 && fullp == 1'b0) begin
      fifomem[head] <= din;
   end
end
                  
// Update the head register.
//
always @(posedge clk) begin
   if (rstp == 1'b1) begin
      head <= 2'b00;
   end
   else begin
      if (writep == 1'b1 && fullp == 1'b0) begin
         // WRITE
         head <= head + 1;
      end
   end
end

// Update the tail register.
//
always @(posedge clk) begin
   if (rstp == 1'b1) begin
      tail <= 2'b00;
   end
   else begin
      if (readp == 1'b1 && emptyp == 1'b0) begin
         // READ               
         tail <= tail + 1;
      end
   end
end

// Update the count regsiter.
//
always @(posedge clk) begin
   if (rstp == 1'b1) begin
      count <= 2'b00;
   end
   else begin
      case ({readp, writep})
         2'b00: count <= count;
         2'b01: 
            // WRITE
            if (count != MAX_COUNT) 
               count <= count + 1;
         2'b10: 
            // READ
            if (count != 2'b00)
               count <= count - 1;
         2'b11:
            // Concurrent read and write.. no change in count
            count <= count;
      endcase
   end
end

         
// *** Update the flags
//
// First, update the empty flag.
//
always @(count) begin
   if (count == 2'b00)
      emptyp <= 1'b1;
   else
      emptyp <= 1'b0;
end


// Update the full flag
//
always @(count) begin
   if (count == MAX_COUNT)
      fullp <= 1'b1;
   else
      fullp <= 1'b0;
end

endmodule

// synopsys translate_off

`define TEST_FIFO
// synopsys translate_off
`ifdef TEST_FIFO
module test_fifo;

reg		clk;
reg		rstp;
reg [15:0]	din;
reg		readp;
reg		writep;
wire [15:0]	dout;
wire		emptyp;
wire		fullp;

reg [15:0]	value;

fifo U1 (
   .clk		(clk),
   .rstp	(rstp),
   .din		(din),
   .readp	(readp),
   .writep	(writep),
   .dout	(dout),
   .emptyp	(emptyp),
   .fullp	(fullp)
);

task read_word;
begin
   @(negedge clk);
   readp = 1;
   @(posedge clk) #5;
   $display ("Read %0h from FIFO", dout);
   readp = 0;
end
endtask
   
task write_word;
input [15:0]	value;
begin
   @(negedge clk);
   din = value;
   writep = 1;
   @(posedge clk);
   $display ("Write %0h to FIFO", din);
   #5;
   din = 16'hzzzz;
   writep = 0;
end
endtask

initial begin
   clk = 0;
   forever begin
      #10 clk = 1;
      #10 clk = 0;
   end
end

initial begin
   $shm_open ("./fifo.shm");
   $shm_probe (test_fifo, "AS");
   
   //test1;
   test2;
   
   $shm_close;
   $finish;
end

task test1;
begin
   din = 16'hzzzz;
   writep = 0;
   readp = 0;

   // Reset
   rstp = 1;
   #50;
   rstp = 0;
   #50;
   
   // ** Write 3 values.
   write_word (16'h1111);
   write_word (16'h2222);
   write_word (16'h3333);
   
   // ** Read 2 values
   read_word;
   read_word;
   
   // ** Write one more
   write_word (16'h4444);
   
   // ** Read a bunch of values
   repeat (6) begin
      read_word;
   end
   
   // *** Write a bunch more values
   write_word (16'h0001);
   write_word (16'h0002);
   write_word (16'h0003);
   write_word (16'h0004);
   write_word (16'h0005);
   write_word (16'h0006);
   write_word (16'h0007);
   write_word (16'h0008);

   // ** Read a bunch of values
   repeat (6) begin
      read_word;
   end
   
   $display ("Done TEST1.");
end
endtask

// TEST2
//
// This test will operate the FIFO in an orderly manner the way it normally works.
// 2 threads are forked; a reader and a writer.  The writer writes a counter to
// the FIFO and obeys the fullp flag and delays randomly.  The reader likewise
// obeys the emptyp flag and reads at random intervals.  The result should be that
// the reader reads the incrementing counter out of the FIFO.  The empty/full flags
// should bounce around depending on the random delays.  The writer repeats some
// fixed number of times and then terminates both threads and kills the sim.
//
task test2;
reg [15:0] writer_counter;
begin
   writer_counter = 16'h0001;
   din = 16'hzzzz;
   writep = 0;
   readp = 0;

   // Reset
   rstp = 1;
   #50;
   rstp = 0;
   #50;
   
   fork
      // Writer
      begin
         repeat (500) begin
            @(negedge clk);
            if (fullp == 1'b0) begin
               write_word (writer_counter);
               #5;
               writer_counter = writer_counter + 1;
            end
            else begin
               $display ("WRITER is waiting..");
            end
            // Delay a random amount of time between 0ns and 100ns
            #(50 + ($random % 50));
         end
         $display ("Done with WRITER fork..");
         $finish;
      end
      
      // Reader
      begin
         forever begin
            @(negedge clk);
            if (emptyp == 1'b0) begin
               read_word;
            end  
            else begin
               $display ("READER is waiting..");
            end
            // Delay a random amount of time between 0ns and 100ns
            #(50 + ($random % 50));
         end
      end
   join
end
endtask

always @(fullp)
   $display ("fullp = %0b", fullp);
   
always @(emptyp)
   $display ("emptyp = %0b", emptyp);

always @(U1.head)
   $display ("head = %0h", U1.head);

always @(U1.tail)
   $display ("tail = %0h", U1.tail);

endmodule
`endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美国产一区二区在线播放| 久久精品99国产精品| 自拍偷拍欧美精品| 欧美日韩亚洲综合一区二区三区| 久久久不卡网国产精品二区| 欧美国产日本韩| 亚洲一区视频在线观看视频| 粉嫩嫩av羞羞动漫久久久 | 97精品视频在线观看自产线路二| 一区二区国产视频| 亚洲一本大道在线| 欧美一区二区福利在线| 欧美一区二区在线看| 国产精品区一区二区三区| 欧美日韩一级片网站| 欧美军同video69gay| 国产米奇在线777精品观看| 精品在线观看免费| 久久看人人爽人人| 91美女片黄在线观看91美女| 欧美日韩国产高清一区二区| 91高清视频免费看| 色婷婷av一区二区三区大白胸| 国产成人在线免费| 欧美亚洲一区三区| 亚洲精品国产第一综合99久久 | 国产精品久久三区| 美女视频黄久久| 国产精品久久三| 99久久精品免费观看| 欧美日韩午夜影院| 视频一区在线播放| 中文在线资源观看网站视频免费不卡| 欧美一级理论片| 欧美系列一区二区| 亚洲精品一区在线观看| 一级特黄大欧美久久久| 国产91精品免费| 91精品国产色综合久久| 亚洲精品乱码久久久久久久久| 狠狠色丁香婷综合久久| 欧美喷潮久久久xxxxx| 综合中文字幕亚洲| 欧美午夜免费电影| 日韩欧美激情四射| 视频一区视频二区在线观看| av福利精品导航| 欧美成人免费网站| 在线视频你懂得一区二区三区| 国产jizzjizz一区二区| 日韩午夜精品视频| 亚洲午夜私人影院| 色综合久久中文综合久久97| 99国产精品99久久久久久| 色哟哟一区二区在线观看| 婷婷国产在线综合| 色综合久久88色综合天天 | 中文字幕一区二区不卡| 精品一区二区三区在线播放视频 | av在线不卡观看免费观看| 一区二区三区精密机械公司| 国v精品久久久网| 久久蜜桃av一区二区天堂| 免费国产亚洲视频| 欧美久久久久久久久久| 亚洲综合激情另类小说区| 成人午夜碰碰视频| 中日韩免费视频中文字幕| 国产成人h网站| 欧美日韩免费一区二区三区| 国产最新精品精品你懂的| 国产亚洲制服色| 在线看不卡av| 亚洲444eee在线观看| 尤物视频一区二区| 色欧美日韩亚洲| 欧美色成人综合| 日韩精品一区二区三区中文精品| 岛国一区二区在线观看| 欧美tickling挠脚心丨vk| 免费视频一区二区| 欧美一级日韩一级| 日本欧美一区二区在线观看| 91精品国产麻豆| 日本不卡一二三区黄网| 欧美一区二区视频观看视频| 美腿丝袜在线亚洲一区| 精品国产乱码久久久久久图片 | 91浏览器打开| 亚洲永久免费视频| 欧美激情在线看| 岛国av在线一区| 亚洲欧美在线另类| 色婷婷综合五月| 亚洲一区二三区| 678五月天丁香亚洲综合网| 日本不卡一区二区| 久久老女人爱爱| 91浏览器在线视频| 天天综合天天综合色| 精品国产青草久久久久福利| 国产成人综合在线观看| 亚洲美女电影在线| 欧美欧美午夜aⅴ在线观看| 精品一区二区三区在线播放| 中文字幕成人av| 欧洲av一区二区嗯嗯嗯啊| 国产精品污网站| 欧洲在线/亚洲| 麻豆成人av在线| 国产精品久久久久9999吃药| 欧美亚洲图片小说| 一本到不卡免费一区二区| 久久久久久免费毛片精品| 99在线精品视频| 强制捆绑调教一区二区| 国产精品天美传媒| 欧美日本国产一区| 国产成人午夜精品影院观看视频| 亚洲乱码中文字幕综合| 欧美三级视频在线| 欧美精品久久99| 蜜桃视频免费观看一区| 久久久久久久综合狠狠综合| 国产日产精品1区| 亚洲综合偷拍欧美一区色| 亚洲伊人伊色伊影伊综合网| 亚洲二区视频在线| 亚洲视频1区2区| 欧美少妇bbb| 国产一区二区三区电影在线观看 | 色婷婷av一区二区三区大白胸| 亚洲一级片在线观看| 亚洲精品一区二区三区在线观看 | 日韩欧美www| 色综合色综合色综合| 蜜桃视频在线一区| 亚洲柠檬福利资源导航| 欧美精品一区二区三区视频| 久久久久久久综合日本| 国产白丝网站精品污在线入口| 亚洲国产综合91精品麻豆| 国产三区在线成人av| 欧美猛男gaygay网站| 99久久99久久精品免费观看| 久久激情综合网| 亚洲va韩国va欧美va精品| 国产精品久久久久久久蜜臀| 欧美电影免费观看高清完整版| 欧美日韩中文字幕精品| 国内久久婷婷综合| 日韩电影在线免费观看| 亚洲美女视频一区| 国产精品理伦片| 26uuu色噜噜精品一区二区| 欧美高清激情brazzers| 欧美在线观看视频在线| a级高清视频欧美日韩| 国产一区二区三区免费观看| 久久久久久久一区| 日韩精品综合一本久道在线视频| 欧美中文字幕一二三区视频| av男人天堂一区| 成人免费视频视频| 国产精一区二区三区| 老司机精品视频在线| 午夜精品一区二区三区电影天堂| 亚洲欧美另类综合偷拍| 国产亚洲一区二区三区| 欧美r级电影在线观看| 91精品国产综合久久久蜜臀图片| 在线日韩av片| 久久av资源站| 毛片一区二区三区| 日韩不卡在线观看日韩不卡视频| 午夜一区二区三区在线观看| 亚洲一区二区三区在线播放| 国产aⅴ精品一区二区三区色成熟| 免费成人在线网站| 久久国产尿小便嘘嘘| 麻豆精品精品国产自在97香蕉 | 久久免费的精品国产v∧| 日韩视频在线永久播放| 日韩午夜在线观看| 日韩精品影音先锋| 精品成人a区在线观看| 精品国产91亚洲一区二区三区婷婷| 精品欧美久久久| 久久品道一品道久久精品| 久久久国际精品| 日本伊人色综合网| 欧美日韩在线播放三区| 日韩一区二区麻豆国产| 国产91清纯白嫩初高中在线观看| 国产亚洲精品aa午夜观看| 不卡的电影网站| 亚洲网友自拍偷拍| 色美美综合视频| 国产精品久久一卡二卡| 一本久久综合亚洲鲁鲁五月天|