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

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

?? framer.v

?? 一百多個例子很好的verilog 學習資料
?? V
字號:
//
// Simple example of a "framer".  In this case, an MPEG framer where
// data is sent in 188-byte frames which begin with a special SYNC character
// defined as 47 hex.  Framing must, of course, handle cases where 47s
// happen to also be embedded in the data.  Framer must be able to find
// the period SYNC characters while not be thrown off by spurious SYNCs.
//
// This circuit uses a modulo-188 counter that serves as a timestamp.
// Every received SYNC character causes the current modulo-188 counter
// to be pushed onto a little queue.  The idea is that the timestamps
// should all be the same if the data was perfectly framed.  If spurious
// false SYNC characters fall in the data, then some of the timestamps
// will be different.  This is OK as long as there is a clear majority.
//
// This circuit is something I started to actually have to do, but then
// I ended up not using it.  It is not tested, so use it only for ideas
// and not as a proven circuit!!
//
// tom coonan, 12/1999
//
module framer (clk, resetb, din, dinstb, dout, doutsync, doutstb, locked);
input		clk;
input		resetb;
input [7:0]	din;
input		dinstb;
output [7:0]	dout;
output		doutsync;
output		doutstb;
output		locked;

parameter SYNC = 8'h47;

reg [7:0]	dout;
reg		doutsync;
reg		doutstb;
reg		locked;

/* Internals */

// Free-running Modulo-188 counter
reg [7:0]	cnt188;

// Modulo-188 value when SYNCs are expected once locked.
reg [7:0]	syncindex;

// 6 deep queue of timestamps of every time a SYNC character is received.
// the timestamp is the value of the modulo-188 counter when a SYNC is received.
//
reg [7:0]	t0;	// Oldest timestamp
reg [7:0]	t1;
reg [7:0]	t2;
reg [7:0]	t3;
reg [7:0]	t4;
reg [7:0]	t5;	// Newest timestamp

// Modulo-188 free-running counter.
//
always @(posedge clk or negedge resetb) begin
   if (~resetb) begin
      cnt188 <= 0;
   end
   else begin
      if (dinstb) begin
         if (cnt188 == 187) begin
            cnt188 <= 0;
         end
         else begin
            cnt188 <= cnt188 + 1;
         end
      end
   end
end

// Timestamp queue.
//
always @(posedge clk or negedge resetb) begin
   if (~resetb) begin
      t0 <= 8'hff;  // Let's use FF as an invalid indicator, otherwise
      t1 <= 8'hff;  // we'd potentially get a premature lock..
      t2 <= 8'hff;
      t3 <= 8'hff;
      t4 <= 8'hff;
      t5 <= 8'hff;
   end
   else begin
      if (dinstb && (din == SYNC)) begin
         // Add new timestamp into our queue.
         t0 <= t1;   
         t1 <= t2;   
         t2 <= t3;   
         t3 <= t4;   
         t4 <= t5;   
         t5 <= cnt188;   
      end
   end
end

// Comparators.
wire t0equal = (t0 == cnt188) && (t0 != 8'hFF);
wire t1equal = (t1 == cnt188) && (t1 != 8'hFF);
wire t2equal = (t2 == cnt188) && (t2 != 8'hFF);
wire t3equal = (t3 == cnt188) && (t3 != 8'hFF);
wire t4equal = (t4 == cnt188) && (t4 != 8'hFF);
wire t5equal = (t5 == cnt188) && (t5 != 8'hFF);

// Count number of matches in all the prior timestamps and current modulo-188 time.
wire [3:0] numequal = t0equal + t1equal + t2equal + t3equal + t4equal + t5equal;

// Main sequential process.
//
always @(posedge clk or negedge resetb) begin
   if (~resetb) begin
      locked   <= 0;
      dout     <= 0;
      doutstb  <= 0;
      doutsync <= 0;
      syncindex <= 0;
   end
   else begin
      doutstb  <= 0;  // defaults..
      doutsync <= 0;
      if (dinstb) begin
         dout    <= din;
         doutstb <= 1;
         if (locked) begin
            if (cnt188 == syncindex) begin
               // We expect the data input to be a SYNC.  If it is not, we will
               // immediately drop lock.
               //
               if (din == SYNC) begin
                  $display (".. Received expected SYNC ..");
                  doutsync <= 1;
               end
               else begin
                  locked   <= 0;
                  $display (".. Did not receive expected SYNC, dropping lock! ");
               end
            end
         end
         else begin
            // The following line is the criteria for declaring LOCK.  It
            // says that when a SYNC is recieved we look at the current
            // timestamp, and if this timestamp is present in at least
            // 4 other times in the queue, than this SYNC is an actual SYNC.
            //
            if ((din == SYNC) && (numequal > 3)) begin
               doutsync <= 1;
               locked   <= 1;
               syncindex <= cnt188;
               $display (".. Received SYNC (cnt188=%0h) and declaring LOCK!", cnt188);
            end
         end
      end
   end
end

endmodule

// synopsys translate_off
module test;

reg		clk;
reg		resetb;
reg [7:0]	din;
reg		dinstb;
wire [7:0]	dout;
wire		doutsync;
wire		doutstb;
wire		locked;

// Instantiate the framer
framer framer (
   .clk(clk),
   .resetb(resetb),
   .din(din),
   .dinstb(dinstb),
   .dout(dout),
   .doutsync(doutsync),
   .doutstb(doutstb),
   .locked(locked)
);

initial begin
   fork
      monitor_cycles(100000); // just in case..
      genreset;
      genclock;
      begin
         gendata (20);
         $display ("Done sending good framed data, now sending trash..");
         genradomdata (188*3);  // 3 frames worth of trash.. should drop lock.
         $display ("Done sending trash.  Killing simulation.");
         $finish;
      end
      monitor_framer_output;
   join
end

// Generate VCD file for viewing.
initial begin
   $dumpfile ("framer.vcd");
   $dumpvars (0,test);   
end

// Just a generic task for watching total cycles.
task monitor_cycles;
   input	maxcycles;
   integer	maxcycles;
   integer	cycles;
   begin
      forever begin
         @(posedge clk);
         cycles = cycles + 1;
         if (cycles > maxcycles) begin
            $finish;
         end
      end
   end
endtask

// Watch output of framer.  Expect to see the pattern 1,2,3,4 after each SYNC.
// This is the pattern that will be injected into framer.
//
task monitor_framer_output;
   integer	cnt;
   integer	numerrors;
   begin
      numerrors = 0;
      forever begin
         @(posedge doutstb);
         #1;
         if (doutsync) begin
            $display ("Framer says SYNC..");
            cnt = 1;
            repeat (4) begin
               @(posedge doutstb);
               #1
               $display ("   and %h..", dout);
               if (dout != cnt) begin
                  numerrors = numerrors + 1;
                  $display ("!! Unexpected data from framer !! (%0d errors)", numerrors);
               end
               cnt = cnt + 1;
            end
         end
      end
   end
endtask

task genreset;
   begin
      resetb = 0;
      repeat (2) @(posedge clk);
      @(negedge clk);
      resetb = 1;
   end
endtask

task genclock;
   begin
      clk = 0;
      forever begin
         #10 clk = ~clk;
      end
   end
endtask

// Input framed data into the framer.  First 4 bytes of each frame should be
// a simple counting sequence that can then be checked at its output.
//
task gendata;
   input	numframes;
   
   integer	numframes;
   
   integer	cnt;
   begin
      cnt = $random;  // Start randomly in the frame sequence..
      repeat (numframes*188) begin
         repeat (3) @(posedge clk);
         if (cnt == 0) begin
            din = 8'h47;
            $display ("SYNC..");
         end
         else begin
            if (cnt < 5) begin
               din = cnt;
            end
            else begin
               din = $random;
               if (din == 8'h47) begin
                  $display ("   .. Non-SYNC 0x47 embedded in frame data !");
               end
            end
         end
      
         dinstb = 1;
         @(posedge clk);
         dinstb = 0;
         cnt = (cnt + 1) % 188;
      end
   end
endtask

// This will inject trash (no good framing) into framer.  Use this to show
// that it actually drops lock.
//
task genradomdata;
   input	numbytes;
   integer	numbytes;
   begin
      repeat (numbytes) begin
         repeat (3) @(posedge clk);
         din = $random;
         dinstb = 1;
         @(posedge clk);
         dinstb = 0;
      end
   end
endtask

endmodule
// synopsys translate_on

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区精品视频在线| 麻豆精品一区二区三区| 处破女av一区二区| 国产日韩欧美在线一区| 成人在线综合网| 1024成人网| 欧美日韩精品免费观看视频| 日韩国产欧美视频| 欧美成人a∨高清免费观看| 国产乱码精品一区二区三区五月婷| 欧美电影免费观看高清完整版 | 国产精品影视天天线| 日韩欧美一区在线| 国内精品在线播放| 国产精品视频第一区| 色狠狠色噜噜噜综合网| 午夜伦欧美伦电影理论片| 久久亚洲捆绑美女| 粉嫩一区二区三区在线看| 亚洲激情五月婷婷| 91精品国产综合久久久久| 国产乱子轮精品视频| 亚洲色图.com| 日韩欧美一区在线| 97久久精品人人做人人爽| 无吗不卡中文字幕| 日本一区二区高清| 欧美日韩精品免费观看视频| 国产精品亚洲专一区二区三区 | 欧美亚洲综合网| 日韩高清在线一区| 国产欧美1区2区3区| 欧美日韩亚洲丝袜制服| 国产福利一区二区| 亚洲成人自拍一区| 国产精品女主播在线观看| 51久久夜色精品国产麻豆| 国产成人a级片| 日韩影院在线观看| ...中文天堂在线一区| 日韩一区二区三区四区五区六区| 不卡的av网站| 激情文学综合插| 首页综合国产亚洲丝袜| 亚洲欧美综合网| 久久影音资源网| 欧美一级欧美三级| 欧美影院一区二区| 99精品国产99久久久久久白柏| 久久精品国产亚洲一区二区三区| 一区二区在线电影| 亚洲欧美在线视频观看| 激情久久久久久久久久久久久久久久| 亚洲高清一区二区三区| 久久久.com| 日韩欧美色综合| 欧美剧情片在线观看| 9久草视频在线视频精品| 韩国精品久久久| 青青草国产成人av片免费| 亚洲一区二区三区四区在线免费观看| 中文字幕欧美日韩一区| 精品久久久久久久久久久久久久久 | 一区二区高清免费观看影视大全| 911精品国产一区二区在线| 91网页版在线| 成人黄页毛片网站| 亚洲一区二区三区中文字幕| 久久综合给合久久狠狠狠97色69| 欧美日韩高清一区二区| 不卡电影一区二区三区| 国产乱淫av一区二区三区| 美女视频一区二区三区| 五月天国产精品| 水野朝阳av一区二区三区| 亚洲bdsm女犯bdsm网站| 亚洲激情中文1区| 亚洲午夜精品一区二区三区他趣| 亚洲综合久久久久| 一区二区高清视频在线观看| 一区二区高清免费观看影视大全| 亚洲综合色网站| 亚洲123区在线观看| 午夜日韩在线观看| 热久久久久久久| 粉嫩欧美一区二区三区高清影视| 国产一区二区三区最好精华液| 九一九一国产精品| 激情小说亚洲一区| 高清日韩电视剧大全免费| 成人激情午夜影院| 99在线精品一区二区三区| 色天天综合色天天久久| 国产欧美一区视频| 亚洲欧洲日韩av| 久久综合给合久久狠狠狠97色69| 亚洲精品在线观看视频| 中文字幕第一区二区| 18成人在线视频| 亚洲电影一级黄| 久久97超碰色| av在线播放一区二区三区| 欧美亚洲高清一区| 欧美刺激午夜性久久久久久久| 久久久久久久久久美女| 亚洲人快播电影网| 天天综合色天天| 国产麻豆视频精品| 91国内精品野花午夜精品| 日韩一区二区麻豆国产| 久久精品人人做人人爽97| 一级女性全黄久久生活片免费| 日韩经典一区二区| 成人免费观看视频| 欧美男同性恋视频网站| 久久综合视频网| 亚洲综合一区二区精品导航| 奇米影视一区二区三区| 成人avav影音| 日韩视频一区二区三区在线播放 | 高清久久久久久| 99精品久久久久久| 日韩欧美国产一区在线观看| 国产情人综合久久777777| 亚洲高清一区二区三区| 国产91丝袜在线18| 在线成人av网站| 成人性视频网站| 亚洲国产精品传媒在线观看| 中文字幕 久热精品 视频在线| 亚洲一级片在线观看| 国产乱码精品一区二区三区忘忧草 | 九九视频精品免费| 日本不卡一二三| 91视视频在线观看入口直接观看www | 中文字幕一区二| 婷婷综合五月天| 国产一区二区不卡在线| 欧美性色综合网| 中文字幕精品—区二区四季| 日韩精彩视频在线观看| 91视频在线观看| 久久久亚洲精华液精华液精华液| 亚洲bdsm女犯bdsm网站| 99久久99久久精品国产片果冻| 亚洲精品在线免费播放| 日韩精品五月天| 欧美优质美女网站| 中文字幕欧美三区| 国产麻豆成人精品| 欧美一区二区三区四区久久| 亚洲精品老司机| 99久久精品免费| 国产亚洲欧美在线| 国产精品自拍在线| 久久综合色婷婷| 极品少妇xxxx精品少妇偷拍| 欧美日韩国产在线观看| 亚洲一区二区三区激情| 91免费版在线看| 亚洲国产高清在线观看视频| 亚洲视频每日更新| 不卡一区在线观看| 色综合天天综合在线视频| 国产偷国产偷精品高清尤物| 激情文学综合网| 26uuu国产日韩综合| 久久精品国产亚洲a| 欧美一区二区三区视频| 免费在线观看一区| 欧美一区三区四区| 美女高潮久久久| 精品福利在线导航| 国产激情视频一区二区三区欧美| 久久免费电影网| 国产成a人亚洲精| 国产精品久久久久久久久久久免费看 | 久久久久久电影| 韩国午夜理伦三级不卡影院| 337p粉嫩大胆噜噜噜噜噜91av | 在线免费观看日本欧美| 亚洲欧美日韩久久| 欧亚一区二区三区| 日本午夜一区二区| 亚洲一区二区精品视频| 香蕉加勒比综合久久| 91在线观看成人| 亚洲国产视频一区| 91精品国产美女浴室洗澡无遮挡| 奇米777欧美一区二区| 亚洲精品在线观看网站| 成av人片一区二区| 亚洲在线免费播放| 日韩欧美精品在线视频| 国产 欧美在线| 亚洲一区视频在线| 337p日本欧洲亚洲大胆色噜噜| 成人不卡免费av| 午夜视频在线观看一区| 久久影院午夜论|