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

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

?? key_gen.v

?? 本系統由服務器軟件控制平臺和fpga硬件處理系統組成
?? V
字號:
//generate search key
//-----------------------------------------------------------------------------
// Title      : 
// Project    : 
//-----------------------------------------------------------------------------
// File       : key_gen.v
// Author     : 
// Date       : 07-10-29
//-----------------------------------------------------------------------------
// Description: 
//
//-----------------------------------------------------------------------------

`timescale 1ns/10ps

module key_gen(
sys_clk,
sys_rst_n,
pre_sop_key,
pre_eop_key,
pre_dat_key, 
pre_mod_key,
pre_dvld_key,
key_pb_pre,
key_sop_drop,
key_eop_drop,
key_dat_drop,
key_mod_drop,
key_dvld_drop,
drop_pb_key,
key_sok_ci,
key_eok_ci,
key_key_ci,
key_kvld_ci
);

/*-------------------------------------------------------------------*\
                          Parameter Description
\*-------------------------------------------------------------------*/

parameter D = 2;

/*-------------------------------------------------------------------*\
                            Port Description
\*-------------------------------------------------------------------*/ 

//global signal
input                sys_clk;
input                sys_rst_n;

//interface with pre
input                pre_sop_key;
input                pre_eop_key;
input     [31:0]     pre_dat_key;
input     [1:0]      pre_mod_key;
input                pre_dvld_key;
output               key_pb_pre;

//interface with drop
output               key_sop_drop;
output               key_eop_drop;
output   [31:0]      key_dat_drop;
output    [1:0]      key_mod_drop;
output               key_dvld_drop;
input                drop_pb_key;

//interface with cam_if
output               key_sok_ci;
output               key_eok_ci;
output   [31:0]      key_key_ci;
output               key_kvld_ci;
/*-------------------------------------------------------------------*\
                          Reg/Wire Description
\*-------------------------------------------------------------------*/
reg            key_pb_pre;
reg            key_sop_drop; 
reg            key_eop_drop; 
reg  [31:0]    key_dat_drop; 
reg   [1:0]    key_mod_drop; 
reg            key_dvld_drop;  
reg   [2:0]    eth_cnt;
reg   [7:0]    ip_cnt;
reg   [3:0]    ip_hlen;
reg            tu_flag;
reg   [5:0]    tu_cnt;
reg            key_sok_ci;
reg            key_eok_ci;
reg   [7:0]    ip_tos;
reg   [15:0]   tmp_sd;
reg   [31:0]   key_key_ci;
reg            key_kvld_ci;
/*-------------------------------------------------------------------*\
                               Main Codes
\*-------------------------------------------------------------------*/                           

//send push back to pre
always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      key_pb_pre <= #D 1'b0;
   else
      key_pb_pre <= #D drop_pb_key;
end

//send packe t topacket and drop
always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      begin
        key_sop_drop  <= #D 1'b0;
        key_eop_drop  <= #D 1'b0;
        key_dat_drop  <= #D 32'b0;
        key_mod_drop  <= #D 2'b0;
        key_dvld_drop <= #D 1'b0;
      end
   else
      begin
        key_sop_drop  <= #D pre_sop_key;
        key_eop_drop  <= #D pre_eop_key;
        key_dat_drop  <= #D pre_dat_key;
        key_mod_drop  <= #D pre_mod_key;
        key_dvld_drop <= #D pre_dvld_key;
      end
end

//generate key
//ethnet,ip and tcp/udp count for extraction
always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      eth_cnt <= #D 3'h0;
   else if(pre_sop_key && pre_dvld_key)
      eth_cnt <= #D 3'h1;
   else if(&eth_cnt)
      eth_cnt <= #D eth_cnt;
   else if(pre_dvld_key)
      eth_cnt <= #D eth_cnt + 3'h1;
end

always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      ip_cnt <= #D 8'h80;
   else if(pre_dvld_key && eth_cnt == 3'h2)
      ip_cnt <= #D 8'h1;
   else if(ip_cnt[7])
      ip_cnt <= #D ip_cnt;
   else if(pre_dvld_key)
      ip_cnt <= #D ip_cnt << 1;
end

always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      ip_hlen <= #D 4'h0;
   else if(ip_cnt[0] && pre_dvld_key)
      ip_hlen <= #D 4'h5;
   else if(pre_dvld_key && |ip_hlen)
      ip_hlen <= #D ip_hlen - 4'h1;
end

always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      tu_flag <= #D 1'b0;
   else if(pre_eop_key && pre_dvld_key)
      tu_flag <= #D 1'b0;
   else if(ip_cnt[2] && pre_dvld_key && pre_dat_key[7:0]== 8'h6)
      tu_flag <= #D 1'b1;
end

always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      tu_cnt <= #D 6'b10_0000;
   else if(ip_hlen == 4'h2 && pre_dvld_key)
      tu_cnt <= #D 6'b00_0001;
   else if(tu_cnt[5])
      tu_cnt <= #D tu_cnt;
   else if(pre_dvld_key)
      tu_cnt <= #D tu_cnt << 1;
end

//key send to packet and key fifo
//sok
always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      key_sok_ci <= #D 1'b0;
   else if(ip_cnt[2] && pre_dvld_key)
      key_sok_ci <= #D 1'b1;
   else
      key_sok_ci <= #D 1'b0;
end

//eok
always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      key_eok_ci <= #D 1'b0;
   else if(~tu_flag && tu_cnt[2] && pre_dvld_key)
      key_eok_ci <= #D 1'b1;
   else if(tu_flag && tu_cnt[3] && pre_dvld_key)
      key_eok_ci <= #D 1'b1;
   else
      key_eok_ci <= #D 1'b0;
end

//key
always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      ip_tos <= #D 8'b0;
   else if(ip_cnt[0] && pre_dvld_key)
      ip_tos <= #D pre_dat_key[7:0];
end
reg   [31:0]  sip;
reg   [31:0]  dip;
always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      sip <= #D 32'b0;
   else if(ip_cnt[4] && pre_dvld_key)
      sip <= #D {tmp_sd,pre_dat_key[31:16]};
end

always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      dip <= #D 32'b0;
   else if(ip_cnt[5] && pre_dvld_key)
      dip <= #D {tmp_sd,pre_dat_key[31:16]};
end

always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      tmp_sd <= #D 16'h0;
   else if(ip_cnt[3] && pre_dvld_key)
      tmp_sd <= #D pre_dat_key[15:0];
   else if(ip_cnt[4] && pre_dvld_key)
      tmp_sd <= #D pre_dat_key[15:0];
   else if(tu_cnt[0] && pre_dvld_key)
      tmp_sd <= #D pre_dat_key[15:0];
end

always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      key_key_ci <= #D 32'b0;
   else if(ip_cnt[2] && pre_dvld_key)
      key_key_ci <= #D 32'b0;
   else if(ip_cnt[4] && pre_dvld_key)
      key_key_ci <= #D {tmp_sd,pre_dat_key[31:16]};  //sip
   else if(ip_cnt[5] && pre_dvld_key)
      key_key_ci <= #D {tmp_sd,pre_dat_key[31:16]};  //dip
   else if(tu_cnt[1] && pre_dvld_key)
      key_key_ci <= #D {tmp_sd,pre_dat_key[31:16]};  //sport + dport
   else if(tu_flag && tu_cnt[3] && pre_dvld_key)
      key_key_ci <= #D 32'b0;
   else
      key_key_ci <= #D 32'b0;
end

//always @ (posedge sys_clk or negedge sys_rst_n)   //used for debug
//begin
//   if(!sys_rst_n)
//      key_key_ci <= #D 32'b0;
//   else if(tu_flag && tu_cnt[3] && pre_dvld_key)
//      key_key_ci <= #D {16'b1,16'd0};
//   else
//      key_key_ci <= #D 32'b0;
//end

//kvld
always @ (posedge sys_clk or negedge sys_rst_n)
begin
   if(!sys_rst_n)
      key_kvld_ci <= #D 1'b0;
   else if((ip_cnt[2] || ip_cnt[4] || ip_cnt[5] || tu_cnt[1] ||
            tu_flag && tu_cnt[3] || ~tu_flag && tu_cnt[2]) && pre_dvld_key)
      key_kvld_ci <= #D 1'b1;
   else
      key_kvld_ci <= #D 1'b0;
end

endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩理论片一区二区| 欧美三级在线看| 国产亚洲欧洲997久久综合| 国产精品 欧美精品| 久久毛片高清国产| 国产成人精品亚洲777人妖| 精品久久五月天| 国产精品911| 亚洲欧洲性图库| 欧美影院一区二区三区| 奇米在线7777在线精品| 亚洲精品一区二区三区在线观看| 国模冰冰炮一区二区| 国产精品午夜在线| 欧美在线色视频| 久久福利视频一区二区| 国产三级一区二区三区| 日本伦理一区二区| 午夜不卡在线视频| 久久精品人人做| 在线观看91精品国产入口| 蜜桃久久精品一区二区| 亚洲国产高清不卡| 精品视频在线免费| 国产成人自拍网| 亚洲黄色片在线观看| 日韩精品一区二区三区swag| 成人aa视频在线观看| 午夜激情综合网| 国产欧美综合在线观看第十页| 色婷婷狠狠综合| 久久精品国产免费看久久精品| 国产精品视频免费看| 欧美夫妻性生活| 成人av免费在线播放| 免费成人在线网站| 一区二区三区资源| 国产日韩影视精品| 欧美一区二区三区在线视频| 成人午夜精品在线| 毛片av中文字幕一区二区| 18欧美亚洲精品| 久久亚洲一区二区三区明星换脸| 欧美性视频一区二区三区| 国产精品18久久久久久久久久久久 | 国产蜜臀97一区二区三区| 欧美三级视频在线观看| 成人av资源网站| 国产乱人伦偷精品视频免下载| 亚洲成人精品一区二区| 国产精品成人在线观看| 久久久综合精品| 欧美成人三级在线| 欧美高清精品3d| 欧美日韩一级二级三级| 91农村精品一区二区在线| 国产精品18久久久久久久网站| 免费成人在线播放| 日韩精品色哟哟| 亚洲午夜免费视频| 一区二区三区在线视频播放| 国产精品久久777777| 欧美国产精品一区二区三区| 久久久不卡影院| 欧美sm极限捆绑bd| 日韩欧美的一区| 日韩欧美色电影| 欧美一区二区在线免费观看| 欧美日韩黄视频| 欧美日韩一区在线| 欧美午夜寂寞影院| 欧美日韩在线播放| 欧美精品亚洲二区| 51午夜精品国产| 欧美一区二区三区人| 制服丝袜中文字幕亚洲| 欧美精品vⅰdeose4hd| 欧美日韩你懂得| 欧美三级中文字| 91超碰这里只有精品国产| 欧美老女人第四色| 777奇米成人网| 日韩美女在线视频| 久久综合给合久久狠狠狠97色69| 久久五月婷婷丁香社区| 久久久不卡影院| 综合欧美一区二区三区| 亚洲天堂久久久久久久| 亚洲一区二区在线免费看| 亚洲国产sm捆绑调教视频| 午夜一区二区三区视频| 美女视频一区二区| 国产在线播放一区二区三区| 国产麻豆91精品| 成人激情综合网站| 欧美日韩综合在线| 日韩欧美自拍偷拍| 国产日韩欧美a| 亚洲狼人国产精品| 日韩和欧美一区二区| 久久99精品国产.久久久久| 国产精品一区不卡| 99国产精品99久久久久久| 欧美日韩综合不卡| 26uuu国产电影一区二区| 国产精品久久久久久久久快鸭| 亚洲嫩草精品久久| 日本不卡高清视频| jlzzjlzz欧美大全| 911精品国产一区二区在线| 精品久久人人做人人爰| 一区在线播放视频| 麻豆91免费看| 成人免费视频一区二区| 欧美狂野另类xxxxoooo| 久久精品视频免费| 午夜在线成人av| 国产精品18久久久久久vr| 色婷婷av一区二区三区之一色屋| 日韩情涩欧美日韩视频| 亚洲欧美视频在线观看视频| 免费成人在线网站| 色天使色偷偷av一区二区| 日韩天堂在线观看| 亚洲精品视频一区二区| 韩国精品久久久| 欧美日韩高清在线| 国产精品传媒入口麻豆| 欧美人妇做爰xxxⅹ性高电影| 懂色一区二区三区免费观看| 欧美日本一道本在线视频| 久久免费电影网| 日韩中文字幕av电影| 成人动漫av在线| 精品国产一区二区三区久久久蜜月 | 91麻豆精品视频| 久久久夜色精品亚洲| 五月婷婷另类国产| 99视频精品全部免费在线| 久久久久久久久久看片| 视频一区在线播放| 在线观看av一区二区| 中文字幕一区二区不卡| 国产乱码精品一区二区三区五月婷| 欧美日韩国产区一| 亚洲色欲色欲www在线观看| 国产一区二区不卡| 日韩一区二区三区免费观看| 亚洲一区二区偷拍精品| 91女厕偷拍女厕偷拍高清| 国产精品视频第一区| 国产精品1区2区3区在线观看| 精品三级av在线| 日韩高清一区二区| 欧美日韩国产大片| 午夜一区二区三区在线观看| 一本色道久久综合狠狠躁的推荐| 中文字幕av一区二区三区高| 黑人巨大精品欧美黑白配亚洲| 日韩欧美一二区| 久久99精品久久久久久| 精品成人一区二区三区四区| 麻豆精品久久久| 日韩一区二区三区视频| 蜜臀av一区二区| 91精品免费在线观看| 日韩 欧美一区二区三区| 制服丝袜在线91| 美女性感视频久久| 日韩精品影音先锋| 国产精品白丝av| 国产欧美日韩麻豆91| 不卡大黄网站免费看| 亚洲精品成人在线| 在线观看亚洲精品视频| 亚洲一区免费视频| 3atv一区二区三区| 蜜臀久久99精品久久久久久9| 久久综合网色—综合色88| 国产精品99久| 亚洲天堂网中文字| 欧美老女人在线| 久久狠狠亚洲综合| 国产亚洲va综合人人澡精品| 国产91精品欧美| 亚洲人午夜精品天堂一二香蕉| 在线观看亚洲一区| 亚洲成人福利片| 欧美精品一区二区高清在线观看| 狠狠色狠狠色合久久伊人| 国产欧美一区在线| 欧美三级在线视频| 极品少妇xxxx精品少妇偷拍| 中文在线资源观看网站视频免费不卡| 成人aa视频在线观看| 亚洲成av人片在线观看| 亚洲精品一线二线三线| eeuss鲁一区二区三区| 日韩电影在线免费看| 国产欧美一区二区三区在线看蜜臀 |