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

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

?? wb_master_behavioral.v

?? FPGA數字電子系統設計與開發實例導航(源程序)
?? 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 ;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品成人网| 欧美日产国产精品| 国产在线视频一区二区| 亚洲国产精品嫩草影院| 亚洲美女电影在线| 亚洲欧美国产77777| 亚洲视频一二三区| 亚洲美女在线国产| 亚洲综合一区在线| 亚洲韩国精品一区| 婷婷久久综合九色综合绿巨人| 一区二区三区中文在线观看| 亚洲另类在线制服丝袜| 亚洲同性gay激情无套| 亚洲天堂a在线| 亚洲午夜精品久久久久久久久| 一区二区欧美视频| 亚洲高清免费在线| 奇米影视在线99精品| 国产最新精品精品你懂的| 福利视频网站一区二区三区| 成人精品免费网站| 99精品热视频| 欧美精品777| 久久午夜色播影院免费高清 | 1000部国产精品成人观看| 国产精品美女久久久久久久| 又紧又大又爽精品一区二区| 天天做天天摸天天爽国产一区| 麻豆传媒一区二区三区| 国产成人在线看| 在线视频你懂得一区二区三区| 欧美绝品在线观看成人午夜影视| 欧美一区二区人人喊爽| 欧美激情在线看| 亚洲福中文字幕伊人影院| 看电视剧不卡顿的网站| 99久久精品免费看国产| 欧美一级免费观看| 亚洲欧洲av在线| 久久国产精品99久久久久久老狼| 成人av午夜电影| 日韩欧美一区在线观看| 亚洲视频一二区| 国产盗摄视频一区二区三区| 欧美日韩国产一级二级| 国产精品乱人伦一区二区| 奇米精品一区二区三区四区 | 91视频观看免费| 精品国产乱码久久久久久图片| 国产精品全国免费观看高清| 蜜桃av一区二区三区电影| 97se亚洲国产综合自在线 | 国产成人在线观看免费网站| 在线免费观看视频一区| 欧美国产1区2区| 久久精品72免费观看| 91精品福利在线| 国产精品成人在线观看| 国产美女一区二区三区| 日韩一区二区电影网| 亚洲一区二区不卡免费| 91免费在线看| 日韩一区在线看| 成人高清视频在线| 日本一区二区三区dvd视频在线| 偷拍一区二区三区四区| 欧美综合在线视频| 亚洲精品免费在线观看| 成人免费观看av| 国产精品丝袜91| 国产成人av电影在线观看| 日韩欧美精品三级| 美女爽到高潮91| 91精品国产欧美一区二区18| 午夜精品成人在线视频| 欧美日韩国产综合一区二区三区| 亚洲一区二区视频| 欧洲激情一区二区| 亚洲国产精品一区二区久久恐怖片 | 色网综合在线观看| 亚洲男同性视频| 日本韩国欧美一区二区三区| 综合欧美一区二区三区| 色综合色狠狠综合色| 一区二区欧美国产| 欧美日韩一区二区三区高清| 婷婷综合五月天| 精品精品国产高清a毛片牛牛| 91久久精品一区二区| 欧美怡红院视频| 国产福利精品一区| 一区二区三区国产精品| va亚洲va日韩不卡在线观看| 日本一区二区三区四区在线视频 | 欧美性大战久久| 亚洲国产精品综合小说图片区| 欧美日韩一区久久| 蜜臀99久久精品久久久久久软件 | 国产色综合久久| 99在线视频精品| 亚洲午夜三级在线| 欧美变态tickling挠脚心| 国产mv日韩mv欧美| 亚洲欧洲制服丝袜| 成人午夜看片网址| 色综合色综合色综合色综合色综合| 精品粉嫩aⅴ一区二区三区四区| 国产麻豆视频一区| 一区二区三区欧美日| 91精品久久久久久久99蜜桃 | 欧美国产一区二区在线观看| jlzzjlzz亚洲日本少妇| 日韩精品一二三| 国产精品美女一区二区三区| 欧美日韩一卡二卡| 国产精品一区二区三区乱码 | 欧美日韩夫妻久久| 国产主播一区二区| 亚洲高清在线精品| 国产精品系列在线| 欧美丰满少妇xxxbbb| 成人精品小蝌蚪| 激情综合五月天| 午夜电影网一区| 亚洲欧美日韩系列| 久久综合色之久久综合| 欧美日韩国产成人在线免费| 国产精品自在欧美一区| 日本午夜一本久久久综合| 最新久久zyz资源站| 精品成人a区在线观看| 欧美色涩在线第一页| 99精品久久久久久| 国产一区二区三区免费| 日韩成人一级片| 亚洲在线观看免费视频| 国产精品久久一级| 国产亚洲欧美一级| 欧美va天堂va视频va在线| 欧美日韩黄色一区二区| 欧美中文字幕一区| 欧美综合视频在线观看| 色婷婷久久综合| 色综合久久久久网| 99国产精品久久久久久久久久 | 蜜桃精品视频在线| 日韩国产精品久久| 视频一区欧美日韩| 三级久久三级久久| 午夜a成v人精品| 丝袜诱惑制服诱惑色一区在线观看| 亚洲三级在线播放| 亚洲欧洲制服丝袜| 一区二区在线观看不卡| 又紧又大又爽精品一区二区| 亚洲视频免费在线观看| 中文字幕综合网| 亚洲一区在线看| 日韩精品成人一区二区三区| 亚洲国产美国国产综合一区二区| 一区二区三区四区不卡在线| 亚洲欧美另类小说视频| 亚洲伦理在线免费看| 亚洲一区二区三区自拍| 日本午夜一本久久久综合| 久久99久久99| 国产成人日日夜夜| 色综合网站在线| 欧美视频三区在线播放| 日韩西西人体444www| 久久综合久色欧美综合狠狠| 日本一区二区三区国色天香| 国产精品国产三级国产a| 一区二区三区四区在线播放| 婷婷中文字幕一区三区| 国产资源精品在线观看| 91丨porny丨在线| 欧美日韩一区视频| 久久色在线观看| 亚洲天堂2016| 久久国产综合精品| 成人激情免费视频| 欧美伊人久久大香线蕉综合69 | 亚洲不卡av一区二区三区| 日韩成人免费电影| 盗摄精品av一区二区三区| 色999日韩国产欧美一区二区| 欧美高清视频一二三区| 国产欧美日本一区视频| 亚洲成人av福利| 成人福利在线看| 欧美精品自拍偷拍| 国产精品亲子伦对白| 亚洲h动漫在线| 国产成人免费在线| 337p亚洲精品色噜噜噜| 中文字幕在线不卡一区二区三区| 午夜精品在线视频一区| 丁香婷婷综合五月|