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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? wb_master_behavioral.v

?? 使用方法: 以太網(wǎng)編程,拷貝到硬盤
?? V
?? 第 1 頁 / 共 2 頁
字號:
/

`include "wb_model_defines.v"
`include "timescale.v"
module WB_MASTER_BEHAVIORAL
(
    CLK_I,
    RST_I,
    TAG_I,
    TAG_O,
    ACK_I,
    ADR_O,
    CYC_O,
    DAT_I,
    DAT_O,
    ERR_I,
    RTY_I,
    SEL_O,
    STB_O,
    WE_O,
    CAB_O
);

    input                    CLK_I;
    input                    RST_I;
    input    `WB_TAG_TYPE    TAG_I;
    output   `WB_TAG_TYPE    TAG_O;
    input                    ACK_I;
    output   `WB_ADDR_TYPE   ADR_O;
    output                   CYC_O;
    input    `WB_DATA_TYPE   DAT_I;
    output   `WB_DATA_TYPE   DAT_O;
    input                    ERR_I;
    input                    RTY_I;
    output   `WB_SEL_TYPE    SEL_O;
    output                   STB_O;
    output                   WE_O;
    output                   CAB_O;

// instantiate low level master module
WB_MASTER32 wbm_low_level
(
    .CLK_I(CLK_I),
    .RST_I(RST_I),
    .TAG_I(TAG_I),
    .TAG_O(TAG_O),
    .ACK_I(ACK_I),
    .ADR_O(ADR_O),
    .CYC_O(CYC_O),
    .DAT_I(DAT_I),
    .DAT_O(DAT_O),
    .ERR_I(ERR_I),
    .RTY_I(RTY_I),
    .SEL_O(SEL_O),
    .STB_O(STB_O),
    .WE_O(WE_O),
    .CAB_O(CAB_O)
) ;

// block read and write buffers definition
// single write buffer
reg `WRITE_STIM_TYPE  blk_write_data    [0:(`MAX_BLK_SIZE - 1)] ;
// read stimulus buffer - addresses, tags, selects etc.
reg `READ_STIM_TYPE   blk_read_data_in  [0:(`MAX_BLK_SIZE - 1)] ;
// read return buffer - data and tags received while performing block reads
reg `READ_RETURN_TYPE blk_read_data_out [0:(`MAX_BLK_SIZE - 1)] ;

// single write task
task wb_single_write ;
    input `WRITE_STIM_TYPE write_data ;
    input `WB_TRANSFER_FLAGS   write_flags ;
    inout `WRITE_RETURN_TYPE return ;
    reg in_use ;
    reg cab ;
    reg ok ;
    integer cyc_count ;
    integer rty_count ;
    reg retry ;
begin:main

    return`TB_ERROR_BIT = 1'b0 ;
    cab = 0 ;
    return`CYC_ACTUAL_TRANSFER = 0 ;
    rty_count = 0 ;

    // check if task was called before previous call finished
    if ( in_use === 1 )
    begin
        $display("*E, wb_single_write routine re-entered! Time %t ", $time) ;
        return`TB_ERROR_BIT = 1'b1 ;
        disable main ;
    end

    in_use = 1 ;

    retry = 1 ;

    while (retry === 1)
    begin
        // synchronize operation to clock
        @(posedge CLK_I) ;

        wbm_low_level.start_cycle(cab, 1'b1, ok) ;
        if ( ok !== 1 )
        begin
            $display("*E, Failed to initialize cycle! Routine wb_single_write, Time %t ", $time) ;
            return`TB_ERROR_BIT = 1'b1 ;
            disable main ;
        end

        // first insert initial wait states
        cyc_count = write_flags`INIT_WAITS ;
        while ( cyc_count > 0 )
        begin
            @(posedge CLK_I) ;
            cyc_count = cyc_count - 1 ;
        end

        wbm_low_level.wbm_write(write_data, return) ;

        if ( return`CYC_ERR === 0 && return`CYC_ACK === 0 && return`CYC_RTY === 1 && write_flags`WB_TRANSFER_AUTO_RTY === 1 && return`TB_ERROR_BIT === 0)
        begin
            if ( rty_count === `WB_TB_MAX_RTY )
            begin
                 $display("*E, maximum number of retries received - access will not be repeated anymore! Routine wb_single_write, Time %t ", $time) ;
                 retry = 0 ;
            end
            else
            begin
                retry     = 1 ;
                rty_count = rty_count + 1 ;
            end
        end
        else
            retry = 0 ;

        // if test bench error bit is set, there is no meaning in introducing subsequent wait states
        if ( return`TB_ERROR_BIT !== 0 )
        begin
            @(posedge CLK_I) ;
            wbm_low_level.end_cycle ;
            disable main ;
        end

        cyc_count = write_flags`SUBSEQ_WAITS ;
        while ( cyc_count > 0 )
        begin
            @(posedge CLK_I) ;
            cyc_count = cyc_count - 1 ;
        end

        wbm_low_level.end_cycle ;
    end

    in_use = 0 ;

end //main
endtask // wb_single_write

task wb_single_read ;
    input `READ_STIM_TYPE read_data ;
    input `WB_TRANSFER_FLAGS   read_flags ;
    inout `READ_RETURN_TYPE return ;
    reg in_use ;
    reg cab ;
    reg ok ;
    integer cyc_count ;
    integer rty_count ;
    reg retry ;
begin:main

    return`TB_ERROR_BIT = 1'b0 ;
    cab = 0 ;
    rty_count = 0 ;
    return`CYC_ACTUAL_TRANSFER = 0 ;

    // check if task was called before previous call finished
    if ( in_use === 1 )
    begin
        $display("*E, wb_single_read routine re-entered! Time %t ", $time) ;
        return`TB_ERROR_BIT = 1'b1 ;
        disable main ;
    end

    in_use = 1 ;

    retry = 1 ;

    while (retry === 1)
    begin
        // synchronize operation to clock
        @(posedge CLK_I) ;

        wbm_low_level.start_cycle(cab, 1'b0, ok) ;
        if ( ok !== 1 )
        begin
            $display("*E, Failed to initialize cycle! Routine wb_single_read, Time %t ", $time) ;
            return`TB_ERROR_BIT = 1'b1 ;
            disable main ;
        end

        // first insert initial wait states
        cyc_count = read_flags`INIT_WAITS ;
        while ( cyc_count > 0 )
        begin
            @(posedge CLK_I) ;
            cyc_count = cyc_count - 1 ;
        end

        wbm_low_level.wbm_read(read_data, return) ;

        if ( return`CYC_ERR === 0 && return`CYC_ACK === 0 && return`CYC_RTY === 1 && read_flags`WB_TRANSFER_AUTO_RTY === 1 && return`TB_ERROR_BIT === 0)
        begin
           if ( rty_count === `WB_TB_MAX_RTY )
            begin
                 $display("*E, maximum number of retries received - access will not be repeated anymore! Routine wb_single_read, Time %t ", $time) ;
                 retry = 0 ;
            end
            else
            begin
                retry     = 1 ;
                rty_count = rty_count + 1 ;
            end
        end
        else
        begin
            retry = 0 ;
        end

        // if test bench error bit is set, there is no meaning in introducing subsequent wait states
        if ( return`TB_ERROR_BIT !== 0 )
        begin
            @(posedge CLK_I) ;
            wbm_low_level.end_cycle ;
            disable main ;
        end

        cyc_count = read_flags`SUBSEQ_WAITS ;
        while ( cyc_count > 0 )
        begin
            @(posedge CLK_I) ;
            cyc_count = cyc_count - 1 ;
        end

        wbm_low_level.end_cycle ;
    end

    in_use = 0 ;

end //main
endtask // wb_single_read

task wb_RMW_read ;
    input `READ_STIM_TYPE read_data ;
    input `WB_TRANSFER_FLAGS   read_flags ;
    inout `READ_RETURN_TYPE return ;
    reg in_use ;
    reg cab ;
    reg ok ;
    integer cyc_count ;
    integer rty_count ;
    reg retry ;
begin:main

    return`TB_ERROR_BIT = 1'b0 ;
    cab = 0 ;
    rty_count = 0 ;
    return`CYC_ACTUAL_TRANSFER = 0 ;

    // check if task was called before previous call finished
    if ( in_use === 1 )
    begin
        $display("*E, wb_RMW_read routine re-entered! Time %t ", $time) ;
        return`TB_ERROR_BIT = 1'b1 ;
        disable main ;
    end

    in_use = 1 ;

    retry = 1 ;

    while (retry === 1)
    begin
        // synchronize operation to clock
        @(posedge CLK_I) ;

        wbm_low_level.start_cycle(cab, 1'b0, ok) ;
        if ( ok !== 1 )
        begin
            $display("*E, Failed to initialize cycle! Routine wb_RMW_read, Time %t ", $time) ;
            return`TB_ERROR_BIT = 1'b1 ;
            disable main ;
        end

        // first insert initial wait states
        cyc_count = read_flags`INIT_WAITS ;
        while ( cyc_count > 0 )
        begin
            @(posedge CLK_I) ;
            cyc_count = cyc_count - 1 ;
        end

        wbm_low_level.wbm_read(read_data, return) ;

        if ( return`CYC_ERR === 0 && return`CYC_ACK === 0 && return`CYC_RTY === 1 && read_flags`WB_TRANSFER_AUTO_RTY === 1 && return`TB_ERROR_BIT === 0)
        begin
           if ( rty_count === `WB_TB_MAX_RTY )
            begin
                 $display("*E, maximum number of retries received - access will not be repeated anymore! Routine wb_RMW_read, Time %t ", $time) ;
                 retry = 0 ;
            end
            else
            begin
                retry     = 1 ;
                rty_count = rty_count + 1 ;
            end
        end
        else
        begin
            retry = 0 ;
        end

        // if test bench error bit is set, there is no meaning in introducing subsequent wait states
        if ( return`TB_ERROR_BIT !== 0 )
        begin
            @(posedge CLK_I) ;
            wbm_low_level.end_cycle ;
            disable main ;
        end

        cyc_count = read_flags`SUBSEQ_WAITS ;
        while ( cyc_count > 0 )
        begin
            @(posedge CLK_I) ;
            cyc_count = cyc_count - 1 ;
        end

        if (retry === 1)
            wbm_low_level.end_cycle ;
        else
            wbm_low_level.modify_cycle ;
    end

    in_use = 0 ;

end //main
endtask // wb_RMW_read

task wb_RMW_write ;
    input `WRITE_STIM_TYPE write_data ;
    input `WB_TRANSFER_FLAGS   write_flags ;
    inout `WRITE_RETURN_TYPE return ;
    reg in_use ;
    reg cab ;
    reg ok ;
    integer cyc_count ;
    integer rty_count ;
    reg retry ;
begin:main

    return`TB_ERROR_BIT = 1'b0 ;
    cab = 0 ;
    return`CYC_ACTUAL_TRANSFER = 0 ;
    rty_count = 0 ;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人精品综合在线观看 | 亚洲综合免费观看高清完整版在线| 国产精品性做久久久久久| 欧美sm美女调教| 久久99精品久久久久久久久久久久 | 秋霞午夜鲁丝一区二区老狼| 日韩精品一区二区在线| 久久国产尿小便嘘嘘尿| 国产午夜精品福利| jiyouzz国产精品久久| 亚洲欧美激情视频在线观看一区二区三区| av一区二区三区四区| 亚洲免费在线电影| 欧美久久免费观看| 久久99国产精品麻豆| 中文天堂在线一区| 欧美在线视频日韩| 麻豆国产精品777777在线| 久久精品在这里| 色国产综合视频| 美女任你摸久久| 国产精品久久久久久久第一福利 | 欧美三区免费完整视频在线观看| 三级欧美在线一区| 国产免费久久精品| 欧美日韩中文另类| 国产乱码精品一品二品| 亚洲色图一区二区三区| 69久久夜色精品国产69蝌蚪网| 精品在线亚洲视频| 亚洲婷婷综合色高清在线| 欧美顶级少妇做爰| 国产91精品一区二区| 亚洲一区二区精品久久av| 精品久久久久久无| 日本高清无吗v一区| 激情深爱一区二区| 亚洲综合丁香婷婷六月香| 欧美sm美女调教| 欧美亚洲动漫制服丝袜| 美美哒免费高清在线观看视频一区二区 | 久久久精品免费网站| 91高清在线观看| 国产真实乱子伦精品视频| 亚洲高清不卡在线| 国产日韩欧美在线一区| 制服丝袜成人动漫| 在线影院国内精品| 成人午夜大片免费观看| 秋霞午夜av一区二区三区| 一区二区三区四区在线| 日本一区二区视频在线观看| 91精品国产综合久久精品麻豆| 成人小视频免费在线观看| 青青草成人在线观看| 亚洲一二三级电影| 最新中文字幕一区二区三区| 久久亚洲春色中文字幕久久久| 欧美性猛片xxxx免费看久爱| 本田岬高潮一区二区三区| 精品一区二区三区的国产在线播放| 亚洲综合色噜噜狠狠| 亚洲欧美自拍偷拍色图| 亚洲国产高清aⅴ视频| 2017欧美狠狠色| 欧美一区二区三区四区高清| 欧美日韩国产欧美日美国产精品| 91麻豆精品在线观看| 风流少妇一区二区| 国产一本一道久久香蕉| 国内久久精品视频| 久久97超碰国产精品超碰| 五月天欧美精品| 婷婷久久综合九色综合绿巨人| 亚洲精品成人少妇| 亚洲综合免费观看高清完整版| 亚洲欧美成人一区二区三区| 国产精品短视频| 中文字幕在线视频一区| 国产精品免费av| 亚洲特黄一级片| 亚洲欧美偷拍卡通变态| 亚洲欧美在线视频观看| 中文字幕综合网| 一区二区三区精品| 亚洲在线观看免费视频| 亚洲国产视频一区| 午夜精品福利在线| 奇米在线7777在线精品| 精品一区二区三区在线视频| 精品一区二区三区影院在线午夜| 久久综合综合久久综合| 国产乱理伦片在线观看夜一区 | www.亚洲色图| 色综合激情五月| 精品视频在线免费看| 在线成人小视频| 精品三级av在线| 国产日本一区二区| 亚洲欧美偷拍另类a∨色屁股| 亚洲综合一区在线| 看电视剧不卡顿的网站| 国产成人免费视频一区| 色婷婷亚洲婷婷| 欧美日本不卡视频| 亚洲精品一区二区三区四区高清| 国产免费观看久久| 亚洲国产一区在线观看| 久久av中文字幕片| 9i看片成人免费高清| 欧美日免费三级在线| 亚洲精品一区二区三区蜜桃下载 | 久久久亚洲欧洲日产国码αv| 国产精品进线69影院| 亚洲国产视频一区二区| 狠狠色丁香久久婷婷综| 成人av资源在线| 欧美精品自拍偷拍动漫精品| 国产日韩欧美一区二区三区综合 | 欧美日韩国产高清一区| 久久久精品国产99久久精品芒果 | 免费看日韩a级影片| eeuss鲁片一区二区三区在线看| 欧美日韩国产小视频| 中文字幕久久午夜不卡| 人人超碰91尤物精品国产| 91视频免费看| 精品久久人人做人人爰| 亚洲国产cao| 丁香天五香天堂综合| 538prom精品视频线放| 国产精品久久毛片a| 奇米影视一区二区三区小说| 97国产一区二区| 国产日韩欧美制服另类| 日韩精品1区2区3区| 日本国产一区二区| 国产日产精品1区| 日韩福利电影在线| 丝袜美腿亚洲综合| 99久久婷婷国产| 8v天堂国产在线一区二区| wwwwxxxxx欧美| 日韩国产欧美在线播放| 国产高清精品久久久久| 欧美系列在线观看| 国产日韩成人精品| 精品一区二区三区不卡| 欧洲av一区二区嗯嗯嗯啊| 欧美精品一区二区三区四区| 伊人婷婷欧美激情| 99riav一区二区三区| 精品国产污污免费网站入口| 一区二区三区在线不卡| 国产成人免费视频精品含羞草妖精| 欧美成人免费网站| 樱花影视一区二区| 大胆欧美人体老妇| 日韩午夜av一区| 首页国产丝袜综合| 色哟哟日韩精品| 日本一区二区三区视频视频| 日本女人一区二区三区| 欧美日韩成人综合在线一区二区| 国产日本一区二区| 极品瑜伽女神91| 7799精品视频| 国产精品嫩草久久久久| 国产传媒久久文化传媒| 欧美成人福利视频| 日产国产高清一区二区三区| 91福利在线免费观看| 久久久91精品国产一区二区精品| 免费观看91视频大全| 欧美午夜在线观看| 亚洲精品中文字幕在线观看| 在线观看免费亚洲| 亚洲欧美日韩一区| av一区二区三区在线| 国产精品无人区| 91视频一区二区三区| 自拍偷拍国产亚洲| av成人老司机| 亚洲欧美日韩中文播放 | 欧美日韩成人综合| 一区二区成人在线观看| 色综合天天综合给合国产| 国产精品免费免费| 欧美最猛性xxxxx直播| 亚洲精品国久久99热| 91成人国产精品| 一区二区视频在线| 91精品国产一区二区三区香蕉| 午夜激情久久久| 欧美电影在哪看比较好| 奇米色777欧美一区二区| 日韩欧美一区二区视频| 日韩电影免费在线| 91麻豆精品国产91久久久使用方法| 日本女人一区二区三区|