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

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

?? ddr2.v

?? DDR2 的控制器
?? V
?? 第 1 頁 / 共 5 頁
字號:
                                write_precharge_bank[bank] = 1'b1;
                            end
                            col = ((addr>>1) & -1*(1<<AP)) | (addr & {AP{1'b1}});
                            if (col >= 1<<COL_BITS) begin
                                $display ("%m: at time %t WARNING: col = %h does not exist.  Maximum col = %h", $time, col, (1<<COL_BITS)-1);
                            end
                            if (DEBUG) $display ("%m: at time %t INFO: %s bank %d col %h, auto precharge %d", $time, cmd_string[cmd], bank, col, addr[AP]);
                            wr_pipeline[2*write_latency + 1]  = 1;
                            ba_pipeline[2*write_latency + 1]  = bank;
                            row_pipeline[2*write_latency + 1] = active_row[bank];
                            col_pipeline[2*write_latency + 1] = col;
                            ck_bank_write[bank] <= ck_cntr;
                            ck_write <= ck_cntr;
                        end
                    end
                    READ : begin
                        if (!dll_locked)
                            $display ("%m: at time %t WARNING: %s prior to DLL locked.  Failing to wait for synchronization to occur may result in a violation of the tAC or tDQSCK parameters.", $time, cmd_string[cmd]);
                        if (!init_done) begin
                            $display ("%m: at time %t ERROR: %s Failure.  Initialization sequence is not complete.", $time, cmd_string[cmd]);
                            if (STOP_ON_ERROR) $stop(0);
                        end else if (!active_bank[bank]) begin
                            $display ("%m: at time %t ERROR: %s Failure.  Bank %d must be Activated.", $time, cmd_string[cmd], bank);
                            if (STOP_ON_ERROR) $stop(0);
                        end else if (auto_precharge_bank[bank]) begin
                            $display ("%m: at time %t ERROR: %s Failure.  Auto Precharge is scheduled to bank %d.", $time, cmd_string[cmd], bank);
                            if (STOP_ON_ERROR) $stop(0);
                        end else if ((ck_cntr - ck_read < burst_length/2) && (ck_cntr - ck_read)%2) begin
                            $display ("%m: at time %t ERROR: %s Failure.  Illegal burst interruption.", $time, cmd_string[cmd]);
                            if (STOP_ON_ERROR) $stop(0);
                        end else begin
                            if (addr[AP]) begin
                                auto_precharge_bank[bank] = 1'b1;
                                read_precharge_bank[bank] = 1'b1;
                            end
                            col = ((addr>>1) & -1*(1<<AP)) | (addr & {AP{1'b1}});
                            if (col >= 1<<COL_BITS) begin
                                $display ("%m: at time %t WARNING: col = %h does not exist.  Maximum col = %h", $time, col, (1<<COL_BITS)-1);
                            end
                            if (DEBUG) $display ("%m: at time %t INFO: %s bank %d col %h, auto precharge %d", $time, cmd_string[cmd], bank, col, addr[AP]);
                            rd_pipeline[2*read_latency - 1]  = 1;
                            ba_pipeline[2*read_latency - 1]  = bank;
                            row_pipeline[2*read_latency - 1] = active_row[bank];
                            col_pipeline[2*read_latency - 1] = col;
                            ck_bank_read[bank] <= ck_cntr;
                            ck_read <= ck_cntr;
                        end
                    end
                    NOP: begin
                        if (in_power_down) begin
                            if (DEBUG) $display ("%m: at time %t INFO: Power Down Exit", $time);
                            in_power_down = 0;
                            if (|active_bank & low_power) begin // slow exit active power down
                                ck_slow_exit_pd <= ck_cntr;
                            end
                            ck_power_down <= ck_cntr;
                        end
                        if (in_self_refresh) begin
                            if ($time - tm_cke < TISXR)
                                $display ("%m: at time %t ERROR: tISXR violation during Self Refresh Exit", $time);
                            if (DEBUG) $display ("%m: at time %t INFO: Self Refresh Exit", $time);
                            in_self_refresh = 0;
                            ck_dll_reset <= ck_cntr;
                            ck_self_refresh <= ck_cntr;
                            tm_self_refresh <= $time;
                            tm_refresh <= $time;
                        end
                    end
                endcase
                if ((prev_cke !== 1) && (cmd !== NOP)) begin
                    $display ("%m: at time %t ERROR: NOP or Deselect is required when CKE goes active.", $time);
                end
                if (!init_done) begin
                    case (init_step)
                        0 : begin
//sk                            if ($time < 200000000) 
				if ($time < 200000)
                                $display ("%m at time %t WARNING: 200 us is required before CKE goes active.", $time);
//                          if (cmd_chk + 200000000 > $time)
//                              $display("%m: at time %t WARNING: NOP or DESELECT is required for 200 us before CKE is brought high", $time);
                            init_step = init_step + 1;
                        end
                        1 : if (dll_en)        init_step = init_step + 1;
                        2 : begin
                            if (&init_mode_reg && dll_reset) begin
                                active_bank = {`BANKS{1'b1}};   // require Precharge All or bank Precharges
                                ref_cntr = 0;                   // require refresh
                                init_step = init_step + 1;
                            end
                        end
                        3 : if (ref_cntr == 2) begin
                            ck_write = 0;                       // allow dummy write
                            init_step = init_step + 1;
                        end
                        4 : if (!dll_reset)    init_step = init_step + 1;
                        5 : if (ocd == 3'b111) init_step = init_step + 1;
                        6 : begin
                            if (ocd == 3'b000) begin
                                if (ck_write == 0)
                                    $display ("%m at time %t WARNING: Dummy Write is required during the Initialization Sequence.", $time);
                                if (DEBUG) $display ("%m: at time %t INFO: Initialization Sequence is complete", $time);
                                init_done = 1;
                            end
                        end
                    endcase
                end
            end else if (prev_cke) begin
                if ((!init_done) && (init_step > 1)) begin
                    $display ("%m: at time %t ERROR: CKE must remain active until the initialization sequence is complete.", $time);
                    if (STOP_ON_ERROR) $stop(0);
                end
                case (cmd)
                    REFRESH : begin
                        for (j=0; j<NOP; j=j+1) begin
                            chk_err(1'b0, bank, j, SELF_REF);
                        end
                        chk_err(1'b0, bank, PWR_DOWN, SELF_REF);
                        chk_err(1'b0, bank, SELF_REF, SELF_REF);
                        if (|active_bank) begin
                            $display ("%m: at time %t ERROR: Self Refresh Failure.  All banks must be Precharged.", $time);
                            if (STOP_ON_ERROR) $stop(0);
                            init_done = 0;
                        end else if (odt_en && odt_state) begin
                            $display ("%m: at time %t ERROR: ODT must be off prior to entering Self Refresh", $time);
                            if (STOP_ON_ERROR) $stop(0);
                            init_done = 0;
                        end else begin
                            if (DEBUG) $display ("%m: at time %t INFO: Self Refresh Enter", $time);
                            in_self_refresh = 1;
                            dll_locked = 0;
                        end
                    end
                    NOP : begin
                        // entering slow_exit or precharge power down and tANPD has not been satisfied
                        if (low_power || (active_bank == 0) && (ck_cntr - ck_odt < TANPD))
                            $display ("%m: at time %t WARNING: tANPD violation during %s.  Synchronous or asynchronous change in termination resistance is possible.", $time, cmd_string[PWR_DOWN]);
                        for (j=0; j<NOP; j=j+1) begin
                            chk_err(1'b0, bank, j, PWR_DOWN);
                        end
                        chk_err(1'b0, bank, PWR_DOWN, PWR_DOWN);
                        chk_err(1'b0, bank, SELF_REF, PWR_DOWN);

                        if (|auto_precharge_bank) begin
                            $display ("%m: at time %t ERROR: Power Down Failure.  Auto Precharge is scheduled.", $time);
                            if (STOP_ON_ERROR) $stop(0);
                            init_done = 0;
                        end else if (init_done) begin
                            if (DEBUG) begin
                                if (|active_bank) begin
                                    $display ("%m: at time %t INFO: Active Power Down Enter", $time);
                                end else begin
                                    $display ("%m: at time %t INFO: Precharge Power Down Enter", $time);
                                end
                            end
                            in_power_down = 1;
                        end
                    end
                    default : begin
                        $display ("%m: at time %t ERROR: NOP, Deselect, or Refresh is required when CKE goes inactive.", $time);
                        init_done = 0;
                    end
                endcase
                if (!init_done) begin
                    if (DEBUG) $display ("%m: at time %t INFO: Reset has occurred.", $time);
                    reset_task;
                end
            end
            prev_cke  = cke;
        end
    endtask

    task data_task;
        reg [BA_BITS-1:0] bank;
        reg [ROW_BITS-1:0] row;
        reg [COL_BITS-1:0] col;
        integer i;
        integer j;
        begin

            if (ck_in) begin
                for (i=0; i<32; i=i+1) begin
                    if (data_in_valid && dll_locked && ($time - tm_dqs_neg[i] < $rtoi(TDSS*tck_avg)))
                        $display ("%m: at time %t ERROR: tDSS violation on %s bit %d", $time, dqs_string[i/16], i%16);
                    if (check_write_dqs_high[i])
                        $display ("%m: at time %t ERROR: %s bit %d latching edge required during the preceding clock period.", $time, dqs_string[i/16], i%16);
                end
                check_write_dqs_high <= 0;
            end else if (!ck_in) begin
                for (i=0; i<32; i=i+1) begin
                    if (dll_locked && data_in_valid) begin
                        tm_tdqss = abs_value(tm_ck_pos - tm_dqss_pos[i]);
                        if ((tm_tdqss < tck_avg/2.0) && (tm_tdqss > TDQSS*tck_avg))
                            $display ("%m: at time %t ERROR: tDQSS violation on %s bit %d", $time, dqs_string[i/16], i%16); 
                    end
                    if (check_write_dqs_low[i])
                        $display ("%m: at time %t ERROR: %s bit %d latching edge required during the preceding clock period", $time, dqs_string[i/16], i%16);
                end
                check_write_preamble <= 0;
                check_write_postamble <= 0;
                check_write_dqs_low <= 0;
            end

            if (wr_pipeline[0] || rd_pipeline[0]) begin
                bank = ba_pipeline[0];
                row = row_pipeline[0];
                col = col_pipeline[0];
                burst_cntr = 0;
                memory_read(bank, row, col, memory_data);
            end

            // burst counter
            if (burst_cntr < burst_length) begin
                burst_position = col ^ burst_cntr;
                if (!burst_order) begin
                    burst_position[BO_BITS-1:0] = col + burst_cntr;
                end
                burst_cntr = burst_cntr + 1;
            end

            // write dqs counter
            if (wr_pipeline[WDQS_PRE + 1]) begin
                wdqs_cntr = WDQS_PRE + burst_length + WDQS_PST - 1;
            end
            // write dqs
            if ((wdqs_cntr == burst_length + WDQS_PST) && (wdq_cntr == 0)) begin //write preamble
                check_write_preamble <= ({DQS_BITS{dqs_n_en}}<<16) | {DQS_BITS{1'b1}};
            end
            if (wdqs_cntr > 1) begin  // write data
                if ((wdqs_cntr - WDQS_PST)%2) begin
                    check_write_dqs_high <= ({DQS_BITS{dqs_n_en}}<<16) | {DQS_BITS{1'b1}};
                end else begin
                    c

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品性做久久久久久| 国产亚洲欧美激情| 色综合一个色综合亚洲| 成人动漫在线一区| 成人高清在线视频| 91丨九色丨蝌蚪丨老版| 97精品国产97久久久久久久久久久久| 国产精品夜夜嗨| 成人性生交大片免费看在线播放 | 午夜国产不卡在线观看视频| 伊人性伊人情综合网| 樱花影视一区二区| 亚洲国产精品一区二区久久| 免费观看日韩av| 亚洲动漫第一页| 日韩av在线免费观看不卡| 久久国产免费看| 国产精品2024| 日本乱人伦一区| 91精品国产综合久久久蜜臀粉嫩| 91精品国产综合久久精品图片| 91精品国产欧美一区二区18| 日韩精品最新网址| 国产精品三级久久久久三级| 一区二区三区在线影院| 三级欧美韩日大片在线看| 久久国产日韩欧美精品| 成人激情av网| 欧美高清视频一二三区 | 91国偷自产一区二区三区观看 | 韩国av一区二区三区四区| 夫妻av一区二区| 在线欧美小视频| 亚洲精品一区二区三区四区高清| 国产女主播一区| 亚洲已满18点击进入久久| 精品制服美女久久| 色婷婷av一区二区三区软件| 日韩免费看的电影| 亚洲精品免费电影| 国产精品一区二区久激情瑜伽| 91日韩精品一区| 精品日韩欧美一区二区| 夜夜爽夜夜爽精品视频| 国产综合色在线| 在线观看日韩一区| 国产欧美日韩视频一区二区| 天堂成人国产精品一区| 99久久精品国产精品久久 | 国产一区二区看久久| 日本高清无吗v一区| 国产亚洲一二三区| 日本在线不卡视频| 欧美色倩网站大全免费| 中文字幕一区二区三区乱码在线| 免费成人av资源网| 欧美精品九九99久久| 亚洲欧美偷拍卡通变态| 国产麻豆日韩欧美久久| 日韩三级精品电影久久久 | 26uuu亚洲综合色| 天堂午夜影视日韩欧美一区二区| 99re6这里只有精品视频在线观看| 久久一区二区三区国产精品| 亚洲大片精品永久免费| 欧美在线观看一二区| 亚洲青青青在线视频| 99久久久国产精品| 国产精品的网站| 国产成人午夜视频| 久久综合久久综合久久| 久久黄色级2电影| 欧美精品一区二区三区很污很色的| 丝袜亚洲精品中文字幕一区| 欧美老女人在线| 首页国产欧美久久| 91精品蜜臀在线一区尤物| 日日噜噜夜夜狠狠视频欧美人 | 中文字幕一区二区三区在线不卡 | 色播五月激情综合网| 亚洲欧美激情一区二区| 91精品1区2区| 亚洲va韩国va欧美va精品| 欧美日韩精品欧美日韩精品| 免费在线观看视频一区| 日韩欧美国产成人一区二区| 国内精品嫩模私拍在线| 欧美激情中文不卡| 国产在线视视频有精品| 视频一区欧美日韩| 日本韩国精品在线| 日韩美女视频一区| 欧美无人高清视频在线观看| 亚洲成a人v欧美综合天堂下载| 欧美乱妇15p| 精品中文av资源站在线观看| 久久精品视频在线看| 99久久久无码国产精品| 亚洲一区视频在线观看视频| 91精品国产手机| 国产成a人亚洲| 亚洲一区在线观看免费观看电影高清| 欧美另类一区二区三区| 国产高清久久久久| 夜夜嗨av一区二区三区网页| 日韩欧美国产一区在线观看| 国产精品一线二线三线| 色哦色哦哦色天天综合| 婷婷综合另类小说色区| 久久精品亚洲麻豆av一区二区| 91在线观看高清| 视频一区视频二区在线观看| 国产亚洲精品aa| 欧美日韩一级视频| 国产又黄又大久久| 亚洲成av人影院| 中文字幕欧美区| 欧美妇女性影城| av午夜一区麻豆| 国产一区二区三区四区五区美女 | 成人动漫一区二区| 日韩国产欧美在线播放| 国产精品电影一区二区三区| 精品欧美乱码久久久久久1区2区| 一本一道综合狠狠老| 韩国v欧美v亚洲v日本v| 亚洲国产日韩在线一区模特| 国产精品无人区| www一区二区| 欧美区在线观看| 99久久精品99国产精品| 国产伦精品一区二区三区在线观看| 亚洲一级二级三级| 亚洲欧美日韩一区二区三区在线观看| 久久久欧美精品sm网站| 在线电影欧美成精品| 在线免费一区三区| 91在线观看一区二区| 国产精品一区三区| 国产精品综合一区二区三区| 久久99热国产| 美女一区二区三区在线观看| 亚洲国产一区二区在线播放| 亚洲免费观看高清完整版在线观看| 国产欧美一区二区精品性色超碰| 欧美xxx久久| 精品99一区二区三区| 日韩精品中文字幕一区| 日韩精品一区二区三区视频播放| 在线播放视频一区| 欧美丰满一区二区免费视频| 欧美日韩专区在线| 欧美日韩精品福利| 欧美一二区视频| 精品88久久久久88久久久| 久久亚洲影视婷婷| 中文字幕+乱码+中文字幕一区| 久久精品一区二区三区不卡| 国产欧美日韩在线视频| 国产精品国产自产拍高清av| 中文字幕在线不卡视频| 综合久久一区二区三区| 一区二区三区在线播| 亚洲高清一区二区三区| 麻豆国产欧美日韩综合精品二区| 看电影不卡的网站| 国产高清久久久| 在线视频欧美精品| 91精品视频网| 久久久久国产精品人| 亚洲欧洲性图库| 婷婷六月综合网| 国产一区二区伦理| 99久久99久久久精品齐齐| 欧美中文字幕一区| 欧美电视剧在线观看完整版| 亚洲国产精品成人综合色在线婷婷| 1024成人网| 秋霞午夜鲁丝一区二区老狼| 国产福利91精品| 欧洲精品一区二区| 精品久久久久香蕉网| 成人欧美一区二区三区白人 | 麻豆精品国产传媒mv男同 | av一区二区三区黑人| 欧美日韩在线观看一区二区| 精品电影一区二区| 亚洲精品视频一区| 精品影视av免费| 99这里都是精品| 日韩精品资源二区在线| 亚洲精品高清在线观看| 精一区二区三区| 欧美午夜精品久久久| 国产欧美日韩亚州综合| 丝袜国产日韩另类美女| 99精品欧美一区二区三区小说| 日韩三级视频在线看| 亚洲精品美国一| 成人高清在线视频|