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

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

?? ddr.v

?? 256Mb_ddr 實現ddr_dimm操作
?? V
?? 第 1 頁 / 共 4 頁
字號:
                Pc_b3 = 1'b1;
                RP_chk3 = $time;
                
                // Activate to Precharge Bank 3
                if ($time - RAS_chk3 < tRAS) begin
                    $display ("At time %t ERROR: tRAS violation during Precharge", $time);
                end
                
                // tWR violation check for Write
                if ($time - WR_chk3 < tWR) begin
                    $display ("At time %t ERROR: tWR violation during Precharge", $time);
                end
            end

            // Prech_count is to make sure we have met part of the initialization sequence
            Prech_count = Prech_count + 1;

            // Pipeline for READ
            A10_precharge [cas_latency_x2] = Addr[10];
            Bank_precharge[cas_latency_x2] = Ba;
            Cmnd_precharge[cas_latency_x2] = 1'b1;
        end
    
        // Burst terminate
        if (Burst_term === 1'b1) begin
            // Display DEBUG Message
            if (DEBUG) begin
                $display ("At time %t BST  : Burst Terminate",$time);
            end

            if (Data_in_enable === 1'b1) begin
                // Illegal to burst terminate a Write
                $display ("At time %t ERROR: It's illegal to burst terminate a Write", $time);
                if (!no_halt) $stop (0);
            end else if (Read_precharge[0] === 1'b1 || Read_precharge[1] === 1'b1 ||
                // Illegal to burst terminate a Read with Auto Precharge
                Read_precharge[2] === 1'b1 || Read_precharge[3] === 1'b1) begin
                $display ("At time %t ERROR: It's illegal to burst terminate a Read with Auto Precharge", $time);
                if (!no_halt) $stop (0);
            end else begin
                // Burst Terminate Command Pipeline for Read
                Cmnd_bst[cas_latency_x2] = 1'b1;
            end

        end
        
        // Read Command
        if (Read_enable === 1'b1) begin
            if (!(power_up_done)) begin
                $display ("%m: at time %t ERROR: Power Up and Initialization Sequence not completed before executing Read Command", $time);
            end
            // Check for DLL reset before Read
            if (DLL_reset === 1 && DLL_done === 0) begin
                $display ("%m: at time %t ERROR: You need to wait 200 tCK after DLL Reset Enable to Read, Not %0d clocks.", $time, DLL_count);
            end
            // Display DEBUG Message
            if (DEBUG) begin
                $display ("At time %t READ : Bank = %h, Col = %h", $time, Ba, {Addr [11], Addr [9 : 0]});
            end

            // Terminate a Write
            if (Data_in_enable === 1'b1) begin
                Data_in_enable = 1'b0;
            end

            // Activate to Read without Auto Precharge
            if ((Addr [10] === 1'b0 && Ba === 2'b00 && $time - RCD_chk0 < tRCD) ||
                (Addr [10] === 1'b0 && Ba === 2'b01 && $time - RCD_chk1 < tRCD) ||
                (Addr [10] === 1'b0 && Ba === 2'b10 && $time - RCD_chk2 < tRCD) ||
                (Addr [10] === 1'b0 && Ba === 2'b11 && $time - RCD_chk3 < tRCD)) begin
                $display("At time %t ERROR: tRCD violation during Read", $time);
            end

            // Activate to Read with Auto Precharge
            if ((Addr [10] === 1'b1 && Ba === 2'b00 && $time - RAP_chk0 < tRAP) ||
                (Addr [10] === 1'b1 && Ba === 2'b01 && $time - RAP_chk1 < tRAP) ||
                (Addr [10] === 1'b1 && Ba === 2'b10 && $time - RAP_chk2 < tRAP) ||
                (Addr [10] === 1'b1 && Ba === 2'b11 && $time - RAP_chk3 < tRAP)) begin
                $display ("At time %t ERROR: tRAP violation during Read", $time);
            end

            // Interrupt a Read with Auto Precharge (same bank only)            if (Read_precharge [Ba] === 1'b1) begin                $display ("At time %t ERROR: It's illegal to interrupt a Read with Auto Precharge", $time);                if (!no_halt) $stop (0);                // Cancel Auto Precharge                if (Addr[10] === 1'b0) begin                    Read_precharge [Ba]= 1'b0;                end            end            // Activate to Read            if ((Ba === 2'b00 && Pc_b0 === 1'b1) || (Ba === 2'b01 && Pc_b1 === 1'b1) ||                (Ba === 2'b10 && Pc_b2 === 1'b1) || (Ba === 2'b11 && Pc_b3 === 1'b1)) begin                $display("At time %t ERROR: Bank is not Activated for Read", $time);                if (!no_halt) $stop (0);            end else begin                // CAS Latency pipeline                Read_cmnd[cas_latency_x2] = 1'b1;                Read_bank[cas_latency_x2] = Ba;                Read_cols[cas_latency_x2] = {Addr [ADDR_BITS - 1 : 11], Addr [9 : 0]};                // Auto Precharge                if (Addr[10] === 1'b1) begin                    Read_precharge [Ba]= 1'b1;                    Count_precharge [Ba]= 0;                end            end        end

        // Write Command
        if (Write_enable === 1'b1) begin
            if (!(power_up_done)) begin
                $display ("%m: at time %t ERROR: Power Up and Initialization Sequence not completed before executing Write Command", $time);
                if (!no_halt) $stop (0);
            end
            // display DEBUG message
            if (DEBUG) begin
                $display ("At time %t WRITE: Bank = %h, Col = %h", $time, Ba, {Addr [ADDR_BITS - 1 : 11], Addr [9 : 0]});
            end

            // Activate to Write
            if ((Ba === 2'b00 && $time - RCD_chk0 < tRCD) ||
                (Ba === 2'b01 && $time - RCD_chk1 < tRCD) ||
                (Ba === 2'b10 && $time - RCD_chk2 < tRCD) ||
                (Ba === 2'b11 && $time - RCD_chk3 < tRCD)) begin
                $display("At time %t ERROR: tRCD violation during Write to Bank %h", $time, Ba);
            end

            // Read to Write
            if (Read_cmnd[0] || Read_cmnd[1] || Read_cmnd[2] || Read_cmnd[3] || 
                Read_cmnd[4] || Read_cmnd[5] || Read_cmnd[6] || (Burst_counter < burst_length)) begin
                if (Data_out_enable || read_precharge_truncation[Ba]) begin
                    $display("At time %t ERROR: Read to Write violation", $time);
                end
            end
            
            // Interrupt a Write with Auto Precharge (same bank only)            if (Write_precharge [Ba] === 1'b1) begin                $display ("At time %t ERROR: it's illegal to interrupt a Write with Auto Precharge", $time);                if (!no_halt) $stop (0);                // Cancel Auto Precharge                if (Addr[10] === 1'b0) begin                    Write_precharge [Ba]= 1'b0;                end            end            // Activate to Write            if ((Ba === 2'b00 && Pc_b0 === 1'b1) || (Ba === 2'b01 && Pc_b1 === 1'b1) ||                (Ba === 2'b10 && Pc_b2 === 1'b1) || (Ba === 2'b11 && Pc_b3 === 1'b1)) begin                $display("At time %t ERROR: Bank is not Activated for Write", $time);                if (!no_halt) $stop (0);            end else begin                // Pipeline for Write                Write_cmnd [3] = 1'b1;                Write_bank [3] = Ba;                Write_cols [3] = {Addr [ADDR_BITS - 1 : 11], Addr [9 : 0]};                // Auto Precharge                if (Addr[10] === 1'b1) begin                    Write_precharge [Ba]= 1'b1;                    Count_precharge [Ba]= 0;                end            end        end
    end
    endtask

    task check_neg_dqs;
    begin
        if (Write_cmnd[2] || Write_cmnd[1] || Data_in_enable) begin
            for (i=0; i<DQS_BITS; i=i+1) begin
                if (expect_neg_dqs[i]) begin
                    $display ("At time %t ERROR: Negative DQS[%1d] transition required.", $time, i);
                end
                expect_neg_dqs[i] = 1'b1;
            end
        end else begin
            expect_pos_dqs = 0;
            expect_neg_dqs = 0;
        end
    end
    endtask

    task check_pos_dqs;
    begin
        if (Write_cmnd[2] || Write_cmnd[1] || Data_in_enable) begin
            for (i=0; i<DQS_BITS; i=i+1) begin
                if (expect_pos_dqs[i]) begin
                    $display ("At time %t ERROR: Positive DQS[%1d] transition required.", $time, i);
                end
                expect_pos_dqs[i] = 1'b1;
            end
        end else begin
            expect_pos_dqs = 0;
            expect_neg_dqs = 0;
        end
    end
    endtask

    // Main Logic
    always @ (posedge Sys_clk) begin
        Manual_Precharge_Pipeline;
        Burst_Terminate_Pipeline;
        Dq_Dqs_Drivers;
        Write_FIFO_DM_Mask_Logic;
        Burst_Decode;
        check_neg_dqs;
        Auto_Precharge_Calculation;
        DLL_Counter;
        Control_Logic;
    end

    always @ (negedge Sys_clk) begin
        Manual_Precharge_Pipeline;
        Burst_Terminate_Pipeline;
        Dq_Dqs_Drivers;
        Write_FIFO_DM_Mask_Logic;
        Burst_Decode;
        check_pos_dqs;
    end

    // Dqs Receiver
    always @ (posedge Dqs_in[0]) begin
        // Latch data at posedge Dqs
        dq_rise[7 : 0] = Dq_in[7 : 0];
        dm_rise[0] = Dm_in[0];
        expect_pos_dqs[0] = 0;
    end

    always @ (posedge Dqs_in[1]) begin
        // Latch data at posedge Dqs
        dq_rise[15 : 8] = Dq_in[15 : 8];
        dm_rise[1] = Dm_in [1];
        expect_pos_dqs[1] = 0;
    end

    always @ (posedge Dqs_in[2]) begin
        // Latch data at posedge Dqs
        dq_rise[23 : 16] = Dq_in[23 : 16];
        dm_rise[2] = Dm_in [2];
        expect_pos_dqs[2] = 0;
    end

    always @ (posedge Dqs_in[3]) begin
        // Latch data at posedge Dqs
        dq_rise[31 : 24] = Dq_in[31 : 24];
        dm_rise[3] = Dm_in [3];
        expect_pos_dqs[3] = 0;
    end

    always @ (negedge Dqs_in[0]) begin
        // Latch data at negedge Dqs
        dq_fall[7 : 0] = Dq_in[7 : 0];
        dm_fall[0] = Dm_in[0];
        dm_pair[1:0]  = {dm_rise[0], dm_fall[0]};
        expect_neg_dqs[0] = 0;
    end

    always @ (negedge Dqs_in[1]) begin
        // Latch data at negedge Dqs
        dq_fall[15: 8] = Dq_in[15 : 8];
        dm_fall[1] = Dm_in[1];
        dm_pair[3:2]  = {dm_rise[1], dm_fall[1]};
        expect_neg_dqs[1] = 0;
    end

    always @ (negedge Dqs_in[2]) begin
        // Latch data at negedge Dqs
        dq_fall[23: 16] = Dq_in[23 : 16];
        dm_fall[2] = Dm_in[2];
        dm_pair[5:4]  = {dm_rise[2], dm_fall[2]};
        expect_neg_dqs[2] = 0;
    end

    always @ (negedge Dqs_in[3]) begin
        // Latch data at negedge Dqs
        dq_fall[31: 24] = Dq_in[31 : 24];
        dm_fall[3] = Dm_in[3];
        dm_pair[7:6]  = {dm_rise[3], dm_fall[3]};
        expect_neg_dqs[3] = 0;
    end

    specify
                                              // SYMBOL UNITS DESCRIPTION
                                              // ------ ----- -----------
`ifdef sg5B                                   //              specparams for -5B (CL = 3)
        specparam tDSS             =     1.0; // tDSS   ns    DQS falling edge to CLK rising (setup time) = 0.2*tCK
        specparam tDSH             =     1.0; // tDSH   ns    DQS falling edge from CLK rising (hold time) = 0.2*tCK
        specparam tIH              =   0.750; // tIH    ns    Input Hold Time
        specparam tIS              =   0.750; // tIS    ns    Input Setup Time
        specparam tDQSH            =    1.75; // tDQSH  ns    DQS input High Pulse Width = 0.35*tCK
        specparam tDQSL            =    1.75; // tDQSL  ns    DQS input Low Pulse Width = 0.35*tCK
`else `ifdef sg6                              //              specparams for -6 (CL = 2.5)
        specparam tDSS             =     1.2; // tDSS   ns    DQS falling edge to CLK rising (setup time) = 0.2*tCK
        specparam tDSH             =     1.2; // tDSH   ns    DQS falling edge from CLK rising (hold time) = 0.2*tCK
        specparam tIH              =   0.750; // tIH    ns    Input Hold Time
        specparam tIS              =   0.750; // tIS    ns    Input Setup Time
        specparam tDQSH            =     2.1; // tDQSH  ns    DQS input High Pulse Width = 0.35*tCK
        specparam tDQSL            =     2.1; // tDQSL  ns    DQS input Low Pulse Width = 0.35*tCK
`else `ifdef sg6T                             //              specparams for -6 (CL = 2.5)
        specparam tDSS             =     1.2; // tDSS   ns    DQS falling edge to CLK rising (setup time) = 0.2*tCK
        specparam tDSH             =     1.2; // tDSH   ns    DQS falling edge from CLK rising (hold time) = 0.2*tCK
        specparam tIH              =   0.750; // tIH    ns    Input Hold Time
        specparam tIS              =   0.750; // tIS    ns    Input Setup Time
        specparam tDQSH            =     2.1; // tDQSH  ns    DQS input High Pulse Width = 0.35*tCK
        specparam tDQSL            =     2.1; // tDQSL  ns    DQS input Low Pulse Width = 0.35*tCK
`else `ifdef sg75                             //              specparams for -75E (CL = 2)
        specparam tDSS             =     1.5; // tDSS   ns    DQS falling edge to CLK rising (setup time) = 0.2*tCK
        specparam tDSH             =     1.5; // tDSH   ns    DQS falling edge from CLK rising (hold time) = 0.2*tCK
        specparam tIH              =   0.900; // tIH    ns    Input Hold Time
        specparam tIS              =   0.900; // tIS    ns    Input Setup Time
        specparam tDQSH            =   2.625; // tDQSH  ns    DQS input High Pulse Width = 0.35*tCK
        specparam tDQSL            =   2.625; // tDQSL  ns    DQS input Low Pulse Width = 0.35*tCK
`else `ifdef sg75E                            //              specparams for -75E (CL = 2)
        specparam tDSS             =     1.5; // tDSS   ns    DQS falling edge to CLK rising (setup time) = 0.2*tCK
        specparam tDSH             =     1.5; // tDSH   ns    DQS falling edge from CLK rising (hold time) = 0.2*tCK
        specparam tIH              =   0.900; // tIH    ns    Input Hold Time
        specparam tIS              =   0.900; // tIS    ns    Input Setup Time
        specparam tDQSH            =   2.625; // tDQSH  ns    DQS input High Pulse Width = 0.35*tCK
        specparam tDQSL            =   2.625; // tDQSL  ns    DQS input Low Pulse Width = 0.35*tCK
`else `define sg75Z                           //              specparams for -75Z (CL = 2)
        specparam tDSS             =     1.5; // tDSS   ns    DQS falling edge to CLK rising (setup time) = 0.2*tCK
        specparam tDSH             =     1.5; // tDSH   ns    DQS falling edge from CLK rising (hold time) = 0.2*tCK
        specparam tIH              =   0.900; // tIH    ns    Input Hold Time
        specparam tIS              =   0.900; // tIS    ns    Input Setup Time
        specparam tDQSH            =   2.625; // tDQSH  ns    DQS input High Pulse Width = 0.35*tCK
        specparam tDQSL            =   2.625; // tDQSL  ns    DQS input Low Pulse Width = 0.35*tCK
`endif `endif `endif `endif `endif
        $width    (posedge Dqs_in[0] &&& wdqs_valid, tDQSH);
        $width    (posedge Dqs_in[1] &&& wdqs_valid, tDQSH);
        $width    (negedge Dqs_in[0] &&& wdqs_valid, tDQSL);
        $width    (negedge Dqs_in[1] &&& wdqs_valid, tDQSL);
        $setuphold(posedge Clk,   Cke,   tIS, tIH);
        $setuphold(posedge Clk,   Cs_n,  tIS, tIH);
        $setuphold(posedge Clk,   Cas_n, tIS, tIH);
        $setuphold(posedge Clk,   Ras_n, tIS, tIH);
        $setuphold(posedge Clk,   We_n,  tIS, tIH);
        $setuphold(posedge Clk,   Addr,  tIS, tIH);
        $setuphold(posedge Clk,   Ba,    tIS, tIH);
        $setuphold(posedge Clk, negedge Dqs &&& wdqs_valid, tDSS, tDSH);
    endspecify

endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久免费看| 国产伦精一区二区三区| 蜜桃av噜噜一区二区三区小说| 国产精品一区在线观看你懂的| 色天使久久综合网天天| 久久久久久久av麻豆果冻| 亚洲综合在线视频| 精品一区二区三区在线播放| 色999日韩国产欧美一区二区| 久久久久九九视频| 亚洲精品视频自拍| 国产精品一区二区男女羞羞无遮挡| 欧美亚洲动漫精品| 中文字幕国产一区| 精品一区二区影视| 3d动漫精品啪啪一区二区竹菊| 亚洲美女免费视频| 国产精品一二三区在线| 欧美刺激脚交jootjob| 亚洲伊人伊色伊影伊综合网 | 久久综合久久综合久久| 亚洲午夜免费视频| 在线亚洲欧美专区二区| 亚洲女爱视频在线| 不卡电影一区二区三区| 久久午夜电影网| 国产一区二区三区四区五区入口 | 青青草97国产精品免费观看无弹窗版| 91在线观看免费视频| 国产精品美女久久久久久2018 | 国产区在线观看成人精品| 麻豆一区二区三| 日韩欧美国产wwwww| 美女性感视频久久| 日韩区在线观看| 久久99国产乱子伦精品免费| 在线91免费看| 秋霞影院一区二区| 日韩精品一区二区三区老鸭窝| 日本网站在线观看一区二区三区 | 一本大道av伊人久久综合| 综合激情网...| 在线观看区一区二| 五月综合激情日本mⅴ| 日韩一卡二卡三卡国产欧美| 麻豆视频观看网址久久| 久久综合九色综合久久久精品综合| 国产麻豆精品一区二区| 欧美激情一区在线| 91麻豆福利精品推荐| 亚洲妇女屁股眼交7| 日韩一区二区电影| 成人午夜视频在线| 一区二区三区精品在线| 91精品国产一区二区三区香蕉| 精品中文字幕一区二区小辣椒| 国产三级一区二区| 一本久道中文字幕精品亚洲嫩 | 欧美一卡2卡三卡4卡5免费| 精品一区二区在线视频| 国产精品情趣视频| 欧美日韩在线播放三区四区| 免费观看30秒视频久久| 欧美国产成人在线| 在线亚洲一区二区| 蜜桃传媒麻豆第一区在线观看| 久久精品夜夜夜夜久久| av电影在线观看完整版一区二区| 亚洲精品国久久99热| 日韩视频永久免费| 99riav久久精品riav| 青青草成人在线观看| 国产精品二区一区二区aⅴ污介绍| 欧美色偷偷大香| 国产福利一区二区三区视频| 午夜视频在线观看一区二区三区| 国产亚洲精品aa| 欧美日韩久久久一区| 丁香亚洲综合激情啪啪综合| 日韩国产欧美一区二区三区| 国产精品久久久久一区| 日韩免费电影一区| 色94色欧美sute亚洲线路一久| 黄一区二区三区| 香蕉成人伊视频在线观看| 中文字幕制服丝袜一区二区三区| 91.com在线观看| 在线免费观看日本一区| 成人免费观看av| 国内一区二区视频| 亚洲 欧美综合在线网络| 国产精品看片你懂得| 久久午夜羞羞影院免费观看| 欧美日韩三级一区| 91视频免费观看| 国产成人精品三级麻豆| 久久精品国产99国产| 亚洲va在线va天堂| 亚洲天堂a在线| 国产欧美一二三区| 久久亚洲私人国产精品va媚药| 91麻豆精品国产综合久久久久久| 在线区一区二视频| 99国产麻豆精品| 成人福利视频在线| 国产精品69毛片高清亚洲| 麻豆一区二区三区| 免费一级片91| 蜜桃传媒麻豆第一区在线观看| 天天综合色天天综合色h| 亚洲综合视频在线| 亚洲精品中文在线观看| 中文字幕在线观看一区| 最近日韩中文字幕| 亚洲欧洲一区二区在线播放| 日韩理论电影院| 亚洲六月丁香色婷婷综合久久| 亚洲天天做日日做天天谢日日欢| 亚洲欧洲日韩av| 中文字幕中文乱码欧美一区二区| 国产精品久久久久久久久动漫| 国产精品久久久久久亚洲伦 | 中文字幕欧美激情一区| 亚洲国产激情av| 国产精品国产精品国产专区不片| 欧美激情中文字幕| 中文字幕一区二区三区精华液| 亚洲天堂免费看| 亚洲无线码一区二区三区| 亚洲aaa精品| 国产在线一区二区| 国产成人综合精品三级| aaa国产一区| 欧美日韩在线播放| 亚洲精品一区二区三区香蕉| 欧美激情一区在线| 亚洲六月丁香色婷婷综合久久 | 久久久影院官网| 国产精品久久久久三级| 亚洲一区二区三区中文字幕 | 亚洲精品v日韩精品| 午夜精品久久久久影视| 奇米色一区二区| jlzzjlzz欧美大全| 欧美日韩久久一区二区| 久久婷婷国产综合精品青草| 成人欧美一区二区三区| 日日摸夜夜添夜夜添亚洲女人| 韩国欧美一区二区| 97久久精品人人做人人爽| 欧美肥妇free| 中文字幕亚洲一区二区av在线| 亚洲国产cao| 国产91精品一区二区麻豆亚洲| 色狠狠色噜噜噜综合网| 日韩精品一区二区三区老鸭窝| 国产精品私人影院| 日本在线播放一区二区三区| 成年人国产精品| 欧美一级久久久| 亚洲免费在线观看| 久久se这里有精品| 欧美在线观看视频在线| 国产午夜精品久久久久久久| 午夜久久久久久久久久一区二区| 国产成人无遮挡在线视频| 欧美日韩久久久| 亚洲欧美激情视频在线观看一区二区三区| 久久国产综合精品| 色网站国产精品| 国产精品私房写真福利视频| 久久精品国产亚洲aⅴ| 在线免费观看日本一区| 亚洲国产精品99久久久久久久久| 久久精品国产在热久久| 欧美无砖专区一中文字| 国产精品国产自产拍在线| 日本成人在线电影网| 欧洲av在线精品| 中文字幕在线一区| 丁香六月综合激情| 久久精品水蜜桃av综合天堂| 久久精品免费看| 91麻豆精品国产自产在线| 亚洲一区视频在线| 成人免费不卡视频| 久久久亚洲精品一区二区三区| 日本亚洲天堂网| 欧美日韩成人综合在线一区二区| 亚洲人精品一区| aaa国产一区| 国产精品进线69影院| 成年人网站91| 国产精品久久久久影院老司| 国产成人免费9x9x人网站视频| 久久视频一区二区| 国产高清亚洲一区| 国产精品免费av| 成人免费毛片嘿嘿连载视频| 中文字幕一区二区三区在线观看|