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

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

?? conf_if.v

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

`timescale 1ns/10ps

module conf_if(
sys_clk,
sys_rst_n,
ppc_ce_n_conf,
ppc_we_n_conf,
ppc_re_n_conf,
ppc_clr_n_conf,
ppc_addr_conf,
ppc_wdat_conf,
conf_rdat_ppc,
conf_wr_cal,   
conf_rd_cal,    
conf_clr_cal,   
cal_rdat_conf,
conf_wr_ci,
conf_rd_ci,
conf_clr_ci,
ci_rdat_conf,
conf_wr_drop,   
conf_rd_drop,    
conf_clr_drop,
drop_rdat_conf,
conf_wr_fs,
conf_rd_fs,
conf_clr_fs,
fs_rdat_conf,
conf_wr_mac,
conf_rd_mac,
conf_clr_mac,
mac_rdat_conf,
conf_wdat,
conf_addr
);


/*-------------------------------------------------------------------*\
                          Parameter Description
\*-------------------------------------------------------------------*/
parameter D = 2;

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

//   Global Signals
input		            sys_clk;
input		            sys_rst_n;
                    
input               ppc_ce_n_conf;    //ppc  chip enable signal to conf
input               ppc_we_n_conf;    //ppc  write enable signal to conf
input               ppc_re_n_conf;    //ppc  read enable signal to conf
input               ppc_clr_n_conf;   //ppc  clear singal to conf
input  [7:0]        ppc_addr_conf;    //ppc  write address to conf
input  [15:0]       ppc_wdat_conf;    //ppc  write data to conf
output [15:0]       conf_rdat_ppc;    //conf read data to ppc

//interface with len_cal
output              conf_wr_cal;     
output              conf_rd_cal;    
output              conf_clr_cal;   
input   [15:0]      cal_rdat_conf;

output              conf_wr_ci;
output              conf_rd_ci;
output              conf_clr_ci;
input    [15:0]     ci_rdat_conf;

output              conf_wr_drop;   
output              conf_rd_drop;    
output              conf_clr_drop;   
input    [15:0]     drop_rdat_conf;

output              conf_wr_fs;   
output              conf_rd_fs;    
output              conf_clr_fs;   
input    [15:0]     fs_rdat_conf;

output              conf_wr_mac;   
output              conf_rd_mac;    
output              conf_clr_mac;   
input    [15:0]     mac_rdat_conf;

output   [15:0]     conf_wdat;
output   [3:0]      conf_addr;
/*-------------------------------------------------------------------*\
                          Reg/Wire Description
\*-------------------------------------------------------------------*/
reg              f1_ppc_ce_n;
reg              f1_ppc_we_n; 
reg              f1_ppc_re_n; 
reg              f1_ppc_clr_n;
reg  [7:0]       f1_ppc_addr; 
reg  [15:0]      f1_ppc_wdat; 
reg              f2_ppc_ce_n;
reg              f2_ppc_we_n; 
reg              f2_ppc_re_n; 
reg              f2_ppc_clr_n;
reg  [7:0]       f2_ppc_addr; 
reg  [15:0]      f2_ppc_wdat; 
wire             wr_en_tmp0;
reg              wr_en_tmp1;
wire             write_op;
reg              conf_wr_cal;
reg              conf_wr_ci;
reg              conf_wr_drop;
reg              conf_wr_fs; 
reg              conf_wr_mac; 
reg  [3:0]       conf_addr;
reg  [15:0]      conf_wdat;
reg              clear_tmp0;
reg              clear_tmp1;
reg              clear_op;
reg  [7:0]       clear_addr;
reg              conf_clr_cal;
reg              conf_clr_ci;
reg              conf_clr_drop; 
reg              conf_clr_fs;  
reg              conf_clr_mac;
wire             rd_en_tmp0;
reg              rd_en_tmp1;
wire             read_op;
reg              conf_rd_cal;
reg              conf_rd_ci;
reg              conf_rd_drop;
reg              conf_rd_fs;
reg              conf_rd_mac;
reg              f1_read_op;
reg              f2_read_op;
reg              f3_read_op;
reg              f4_read_op;
reg   [15:0]     conf_rdat_ppc;
/*-------------------------------------------------------------------*\
                               Main Codes
\*-------------------------------------------------------------------*/

always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n )
    begin
        f1_ppc_ce_n  <= #D 1'b1;
        f1_ppc_we_n  <= #D 1'b1;
        f1_ppc_re_n  <= #D 1'b0;
        f1_ppc_clr_n <= #D 1'b1;
        f1_ppc_addr  <= #D 8'b0;
        f1_ppc_wdat  <= #D 16'b0;
    end
    else
    begin
        f1_ppc_ce_n  <= #D ppc_ce_n_conf;
        f1_ppc_we_n  <= #D ppc_we_n_conf;
        f1_ppc_re_n  <= #D ppc_re_n_conf;
        f1_ppc_clr_n <= #D ppc_clr_n_conf;
        f1_ppc_addr  <= #D ppc_addr_conf;
        f1_ppc_wdat  <= #D ppc_wdat_conf;
    end
end

always @( posedge sys_clk or negedge sys_rst_n)
begin
    if( !sys_rst_n )
    begin
        f2_ppc_ce_n  <= #D 1'b1;
        f2_ppc_we_n  <= #D 1'b1;
        f2_ppc_re_n  <= #D 1'b0;
        f2_ppc_clr_n <= #D 1'b1;
        f2_ppc_addr  <= #D 8'b0;
        f2_ppc_wdat  <= #D 16'b0;
    end
    else
    begin
        f2_ppc_ce_n  <= #D f1_ppc_ce_n;
        f2_ppc_we_n  <= #D f1_ppc_we_n;
        f2_ppc_re_n  <= #D f1_ppc_re_n;
        f2_ppc_clr_n <= #D f1_ppc_clr_n;
        f2_ppc_addr  <= #D f1_ppc_addr;
        f2_ppc_wdat  <= #D f1_ppc_wdat;
    end   
end

/*---------------------------------------------*\
                Write Operation
\*---------------------------------------------*/

assign  wr_en_tmp0 = ~f2_ppc_ce_n && ~f2_ppc_we_n;

always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n ) 
        wr_en_tmp1 <= #D 1'b0;
    else
        wr_en_tmp1 <= #D wr_en_tmp0;
end

assign  write_op = wr_en_tmp0 && ~wr_en_tmp1;

always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n )
    begin 
        conf_wr_cal   <= #D 1'b0;
        conf_wr_ci    <= #D 1'b0;
        conf_wr_drop  <= #D 1'b0;
        conf_wr_fs    <= #D 1'b0;
        conf_wr_mac   <= #D 1'b0;
    end
    else
    begin
        conf_wr_cal   <= #D write_op && f2_ppc_addr[7:4]==4'h0;
        conf_wr_ci    <= #D write_op && f2_ppc_addr[7:4]==4'h1;
        conf_wr_drop  <= #D write_op && f2_ppc_addr[7:4]==4'h2;
        conf_wr_fs    <= #D write_op && f2_ppc_addr[7:4]==4'h3;
        conf_wr_mac   <= #D write_op && f2_ppc_addr[7:4]==4'h4;
    end
end

always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n ) 
        conf_addr <= #D 4'b0;
    else if( read_op || write_op )
        conf_addr <= #D f2_ppc_addr[3:0];
    else if( clear_op )
        conf_addr <= #D clear_addr[3:0];
end

always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n ) 
        conf_wdat <= #D 15'b0;
    else if( write_op )
        conf_wdat <= #D f2_ppc_wdat[15:0];
end

/*---------------------------------------------*\
                      Clear 
\*---------------------------------------------*/ 

always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n ) 
    begin
        clear_tmp0 <= #D 1'b0;
        clear_tmp1 <= #D 1'b0;
    end
    else
    begin
        clear_tmp0 <= #D ~f2_ppc_clr_n && ~f2_ppc_ce_n;
        clear_tmp1 <= #D clear_tmp0;
    end
end

always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n ) 
        clear_op <= #D 1'b0;
    else if( clear_tmp0 && ~clear_tmp1 )
        clear_op <= #D 1'b1;
    else
        clear_op <= #D 1'b0;
end

always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n ) 
        clear_addr[7:0] <= #D 8'b0;
    else if( clear_tmp0 && ~clear_tmp1)
        clear_addr[7:0] <= #D f2_ppc_wdat[7:0];
end

always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n )
    begin 
        conf_clr_cal   <= #D 1'b0;
        conf_clr_ci    <= #D 1'b0;
        conf_clr_drop  <= #D 1'b0;
        conf_clr_fs    <= #D 1'b0;
        conf_clr_mac   <= #D 1'b0;
    end
    else
    begin
        conf_clr_cal   <= #D clear_op && clear_addr[7:4]==4'h0;
        conf_clr_ci    <= #D clear_op && clear_addr[7:4]==4'h1;
        conf_clr_drop  <= #D clear_op && clear_addr[7:4]==4'h2;
        conf_clr_fs    <= #D clear_op && clear_addr[7:4]==4'h3;
        conf_clr_mac   <= #D clear_op && clear_addr[7:4]==4'h4;
    end
end

/*---------------------------------------------*\
                 Read Operation
\*---------------------------------------------*/ 

assign  rd_en_tmp0 = ~f2_ppc_ce_n && ~f2_ppc_re_n;

always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n ) 
        rd_en_tmp1 <= #D 1'b0;
    else
        rd_en_tmp1 <= #D rd_en_tmp0;
end

assign  read_op = rd_en_tmp0 && ~rd_en_tmp1;

always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n )
    begin 
        conf_rd_cal   <= #D 1'b0;
        conf_rd_ci    <= #D 1'b0;
        conf_rd_drop  <= #D 1'b0;
        conf_rd_fs    <= #D 1'b0;
        conf_rd_mac   <= #D 1'b0;
    end
    else
    begin
        conf_rd_cal   <= #D read_op && f2_ppc_addr[7:4]==4'h0;
        conf_rd_ci    <= #D read_op && f2_ppc_addr[7:4]==4'h1;
        conf_rd_drop  <= #D read_op && f2_ppc_addr[7:4]==4'h2;
        conf_rd_fs    <= #D read_op && f2_ppc_addr[7:4]==4'h3;
        conf_rd_mac   <= #D read_op && f2_ppc_addr[7:4]==4'h4;
    end
end                      
                    
always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n ) 
    begin
        f1_read_op <= #D 1'b0;
        f2_read_op <= #D 1'b0;
        f3_read_op <= #D 1'b0;
        f4_read_op <= #D 1'b0;
    end
    else
    begin
        f1_read_op <= #D read_op;
        f2_read_op <= #D f1_read_op;
        f3_read_op <= #D f2_read_op;
        f4_read_op <= #D f3_read_op;
    end
end

always @( posedge sys_clk or negedge sys_rst_n )
begin
    if( !sys_rst_n ) 
        conf_rdat_ppc <= #D 16'b0;
    else if( f4_read_op )
    begin
        case( f2_ppc_addr[7:4] )
        4'h0   : conf_rdat_ppc <= #D cal_rdat_conf;
        4'h1   : conf_rdat_ppc <= #D ci_rdat_conf;
        4'h2   : conf_rdat_ppc <= #D drop_rdat_conf;
        4'h3   : conf_rdat_ppc <= #D fs_rdat_conf;
        4'h4   : conf_rdat_ppc <= #D mac_rdat_conf;
        default: conf_rdat_ppc <= #D 16'b0;
        endcase
    end
end

endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
97久久人人超碰| 精品国产麻豆免费人成网站| 成人精品国产免费网站| 精品一区二区三区视频| 蜜臂av日日欢夜夜爽一区| 日韩中文字幕91| 三级一区在线视频先锋| 亚洲mv在线观看| 日日噜噜夜夜狠狠视频欧美人| 亚洲国产日韩在线一区模特| 一区二区欧美国产| 一区二区三区久久| 五月天激情综合网| 日韩av一区二区三区四区| 免费看黄色91| 国产综合久久久久影院| 国产黄人亚洲片| 盗摄精品av一区二区三区| 不卡大黄网站免费看| 国产91精品久久久久久久网曝门| 国产精品白丝av| 成人av免费观看| 91久久精品国产91性色tv| 欧美日韩二区三区| 91精品国产丝袜白色高跟鞋| 精品久久久久久亚洲综合网 | 成人欧美一区二区三区黑人麻豆| 中文字幕一区二区三区不卡在线| 亚洲精品国产精华液| 日韩精品一级二级| 狠狠色丁香久久婷婷综合_中| 国产91丝袜在线播放0| 91麻豆自制传媒国产之光| 精品1区2区3区| 日韩午夜精品电影| 欧美精彩视频一区二区三区| 一区二区三区美女| 精品一区二区三区不卡| 高清免费成人av| 欧美性欧美巨大黑白大战| 日韩精品最新网址| 中文子幕无线码一区tr| 亚洲免费观看高清在线观看| 日本在线不卡一区| 不卡的av电影| 欧美一区二区三区在线观看| 国产精品美女视频| 日韩精品午夜视频| 不卡的av电影在线观看| 日韩一区二区三区电影在线观看 | 91精品国产入口| 国产欧美精品一区二区色综合朱莉 | 2021中文字幕一区亚洲| 亚洲精品va在线观看| 九九视频精品免费| 在线精品观看国产| 国产日韩欧美在线一区| 天天色天天操综合| 国产传媒久久文化传媒| 51精品秘密在线观看| 一区在线观看视频| 日本美女一区二区| 91色乱码一区二区三区| 久久色在线视频| 奇米一区二区三区av| 91在线云播放| 久久久91精品国产一区二区三区| 无码av免费一区二区三区试看| 成人免费av资源| 精品久久久久久综合日本欧美| 亚洲国产人成综合网站| 成人av资源在线观看| 日韩精品在线一区| 图片区小说区区亚洲影院| 99久久99精品久久久久久 | 香蕉影视欧美成人| 99久久精品久久久久久清纯| 久久久久久久久97黄色工厂| 日产国产欧美视频一区精品| 在线观看成人免费视频| 国产精品久久一卡二卡| 国模娜娜一区二区三区| 欧美一区二区二区| 亚洲第一久久影院| 在线视频国内一区二区| 国产精品久久久久aaaa樱花| 国产伦精品一区二区三区视频青涩 | 午夜亚洲福利老司机| 高清在线成人网| 久久久精品人体av艺术| 麻豆精品国产传媒mv男同 | 亚洲精品国产成人久久av盗摄| 成人免费视频国产在线观看| 久久久久久久久久久久电影 | 欧美久久久久免费| 午夜欧美大尺度福利影院在线看| 色综合视频在线观看| 亚洲免费av高清| 欧美综合在线视频| 一级女性全黄久久生活片免费| 色综合视频一区二区三区高清| 亚洲欧美一区二区三区国产精品| 成人av在线网站| 亚洲婷婷综合久久一本伊一区| 成人黄色免费短视频| 久久久久久99精品| 成人小视频在线观看| 国产精品免费网站在线观看| 成人黄页毛片网站| 亚洲欧美一区二区三区孕妇| 91蜜桃传媒精品久久久一区二区 | 99久久精品情趣| 最新热久久免费视频| 在线视频一区二区三区| 亚洲国产精品麻豆| 日韩一区二区免费在线电影| 麻豆免费看一区二区三区| 欧美tk丨vk视频| 国产精品一卡二卡| 亚洲欧洲av另类| 欧美亚洲愉拍一区二区| 人妖欧美一区二区| 久久这里只有精品6| 成av人片一区二区| 亚洲国产日产av| 欧美成人猛片aaaaaaa| 国产凹凸在线观看一区二区| 中文字幕一区二区三中文字幕 | 一区二区三区毛片| 欧美一区二区三区视频免费播放| 国产一区二区三区免费在线观看| 国产精品视频线看| 欧美在线播放高清精品| 蜜臀av亚洲一区中文字幕| 国产亚洲短视频| 91麻豆国产自产在线观看| 婷婷激情综合网| 国产欧美久久久精品影院| 色偷偷久久一区二区三区| 麻豆精品视频在线观看视频| 国产精品天干天干在观线| 欧美日免费三级在线| 韩国v欧美v日本v亚洲v| 亚洲女厕所小便bbb| 精品欧美久久久| 色狠狠综合天天综合综合| 美腿丝袜在线亚洲一区| 国产精品护士白丝一区av| 91.麻豆视频| 成人在线视频一区| 五月婷婷久久丁香| 久久久综合精品| 欧美影视一区在线| 国产精品123区| 天堂蜜桃91精品| 亚洲欧美在线aaa| 日韩一区二区三区电影在线观看| www.欧美.com| 久久99精品国产91久久来源| 亚洲欧美一区二区在线观看| 精品久久久久香蕉网| 欧美色图第一页| 成人性视频免费网站| 免费久久精品视频| 亚洲一线二线三线视频| 久久精品这里都是精品| 91精品啪在线观看国产60岁| 一本大道久久精品懂色aⅴ| 国产精品一区久久久久| 日韩**一区毛片| 亚洲午夜在线电影| 国产精品白丝在线| 久久综合色天天久久综合图片| 欧美日韩国产区一| 色一情一乱一乱一91av| 成人三级在线视频| 国产自产高清不卡| 秋霞成人午夜伦在线观看| 亚洲一区二区在线免费观看视频| 国产精品欧美一区二区三区| 精品日韩一区二区三区免费视频| 欧美日韩国产综合视频在线观看| gogo大胆日本视频一区| 国产精品888| 国产一区二区不卡老阿姨| 男男视频亚洲欧美| 亚洲成人午夜电影| 亚洲一区在线观看免费观看电影高清 | 国产精品短视频| 久久久精品影视| 久久久亚洲欧洲日产国码αv| 欧美一区二区三区在线| 欧美剧在线免费观看网站| 欧美无乱码久久久免费午夜一区| 色欲综合视频天天天| 一本色道久久综合亚洲91| 91亚洲男人天堂| 91免费版在线看| 91女人视频在线观看| 91在线视频观看|