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

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

?? command.v

?? SDRAM的vegilog代碼
?? V
?? 第 1 頁 / 共 2 頁
字號:
end


// logic that generates the OE signal for the data path module
// For normal burst write he duration of OE is dependent on the configured burst length.
// For page mode accesses(SC_PM=1) the OE signal is turned on at the start of the write command
// and is left on until a PRECHARGE(page burst terminate) is detected.
//
always @(posedge CLK or negedge RESET_N)
begin
        if (RESET_N == 0)
        begin
                oe_shift <= 0;
                oe1      <= 0;
                oe2      <= 0;
                OE       <= 0;
        end
        else
        begin
                if (SC_PM == 0)
                begin
                        if (do_writea1 == 1)
                        begin
                                if (SC_BL == 1)                       //  Set the shift register to the appropriate
                                        oe_shift <= 0;                // value based on burst length.
                                else if (SC_BL == 2)
                                        oe_shift <= 1;
                                else if (SC_BL == 4)
                                        oe_shift <= 7;
                                else if (SC_BL == 8)
                                        oe_shift <= 127;
                                oe1 <= 1;
                        end
                        else 
                        begin
                                oe_shift[6:0] <= oe_shift[7:1];       // Do the shift operation
                                oe_shift[7]   <= 0;
                                oe1  <= oe_shift[0];
                                oe2  <= oe1;
                                oe3  <= oe2;
                                oe4   <= oe3;
                                if (SC_RC == 2)
                                        OE <= oe3;
                                else
                                        OE <= oe4;
                        end
                end
                else
                begin
                        if (do_writea1 == 1)                                    // OE generation for page mode accesses
                                oe4   <= 1;
                        else if (do_precharge == 1 | do_reada == 1 | do_refresh)
                                oe4   <= 0;
                        OE <= oe4;
                end
                               
        end
end




// This always block tracks the time between the activate command and the
// subsequent WRITEA or READA command, RC.  The shift register is set using
// the configuration register setting SC_RC. The shift register is loaded with
// a single '1' with the position within the register dependent on SC_RC.
// When the '1' is shifted out of the register it sets so_rw which triggers
// a writea or reada command
//
always @(posedge CLK or negedge RESET_N)
begin
        if (RESET_N == 0)
        begin
                rw_shift <= 0;
                do_rw    <= 0;
        end
        
        else
        begin
                
                if ((do_reada == 1) | (do_writea == 1))
                begin
                        if (SC_RC == 1)                          // Set the shift register
                                do_rw <= 1;
                        else if (SC_RC == 2)
                                rw_shift <= 1;
                        else if (SC_RC == 3)
                                rw_shift <= 2;
                end
                else
                begin
                        rw_shift[2:0] <= rw_shift[3:1];          // perform the shift operation
                        rw_shift[3]   <= 0;
                        do_rw         <= rw_shift[0];
                end 
        end
end              

// This always block generates the command acknowledge, CM_ACK, signal.
// It also generates the acknowledge signal, REF_ACK, that acknowledges
// a refresh request that was generated by the internal refresh timer circuit.
always @(posedge CLK or negedge RESET_N) 
begin

        if (RESET_N == 0) 
        begin
                CM_ACK   <= 0;
                REF_ACK  <= 0;
        end
        
        else
        begin
                if (do_refresh == 1 & REF_REQ == 1)                   // Internal refresh timer refresh request
                        REF_ACK <= 1;
                else if ((do_refresh == 1) | (do_reada == 1) | (do_writea == 1) | (do_precharge == 1)   // externa  commands
                         | (do_load_mode))
                        CM_ACK <= 1;
                else
                begin
                        REF_ACK <= 0;
                        CM_ACK  <= 0;
                end
        end
end 
                    






// This always block generates the address, cs, cke, and command signals(ras,cas,wen)
// 
always @(posedge CLK ) begin
        if (RESET_N==0) begin
                SA    <= 0;
                BA    <= 0;
                CS_N  <= 1;
                RAS_N <= 1;
                CAS_N <= 1;
                WE_N  <= 1;
                CKE   <= 0;
        end
        else begin
                CKE <= 1;

// Generate SA 	
                if (do_writea == 1 | do_reada == 1)    // ACTIVATE command is being issued, so present the row address
                        SA <= rowaddr;
                else
                        SA <= coladdr;                 // else alway present column address
                if ((do_rw==1) | (do_precharge))
                        SA[10] <= !SC_PM;              // set SA[10] for autoprecharge read/write or for a precharge all command
                                                       // don't set it if the controller is in page mode.           
                if (do_precharge==1 | do_load_mode==1)
                        BA <= 0;                       // Set BA=0 if performing a precharge or load_mode command
                else
                        BA <= bankaddr[1:0];           // else set it with the appropriate address bits
		
                if (do_refresh==1 | do_precharge==1 | do_load_mode==1)
                        CS_N <= 0;                                    // Select both chip selects if performing
                else                                                  // refresh, precharge(all) or load_mode
                begin
                        CS_N[0] <= SADDR[`ASIZE-1];                   // else set the chip selects based off of the
                        CS_N[1] <= ~SADDR[`ASIZE-1];                  // msb address bit
                end


//Generate the appropriate logic levels on RAS_N, CAS_N, and WE_N
//depending on the issued command.
//		
                if (do_refresh==1) begin                        // Refresh: S=00, RAS=0, CAS=0, WE=1
                        RAS_N <= 0;
                        CAS_N <= 0;
                        WE_N  <= 1;
                end
                else if ((do_precharge==1) & ((oe4 == 1) | (rw_flag == 1))) begin      // burst terminate if write is active
                        RAS_N <= 1;
                        CAS_N <= 1;
                        WE_N  <= 0;
                end
                else if (do_precharge==1) begin                 // Precharge All: S=00, RAS=0, CAS=1, WE=0
                        RAS_N <= 0;
                        CAS_N <= 1;
                        WE_N  <= 0;
                end
                else if (do_load_mode==1) begin                 // Mode Write: S=00, RAS=0, CAS=0, WE=0
                        RAS_N <= 0;
                        CAS_N <= 0;
                        WE_N  <= 0;
                end
                else if (do_reada == 1 | do_writea == 1) begin  // Activate: S=01 or 10, RAS=0, CAS=1, WE=1
                        RAS_N <= 0;
                        CAS_N <= 1;
                        WE_N  <= 1;
                end
                else if (do_rw == 1) begin                      // Read/Write: S=01 or 10, RAS=1, CAS=0, WE=0 or 1
                        RAS_N <= 1;
                        CAS_N <= 0;
                        WE_N  <= rw_flag;
                end
                else begin                                      // No Operation: RAS=1, CAS=1, WE=1
                        RAS_N <= 1;
                        CAS_N <= 1;
                        WE_N  <= 1;
                end
        end 
end

endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩综合小视频| 亚洲国产视频网站| 一区二区三区蜜桃| 久久99国产精品成人| 色综合久久久久综合体桃花网| 日韩网站在线看片你懂的| 亚洲精品乱码久久久久久| 国产亚洲精品bt天堂精选| 成人动漫av在线| 亚洲三级理论片| 精品一区二区在线视频| 欧美无人高清视频在线观看| 国产精品乱人伦一区二区| 黄色成人免费在线| 日韩欧美国产综合一区 | 精品久久久久久最新网址| 亚洲高清视频的网址| 91亚洲国产成人精品一区二三| 国产无一区二区| 国产精品888| 久久影院午夜片一区| 九九热在线视频观看这里只有精品| 91精品国产一区二区三区| 亚洲国产精品一区二区久久恐怖片| 99精品视频中文字幕| 国产精品麻豆99久久久久久| 国产成人av电影| 国产精品天干天干在观线| 丁香婷婷综合网| 欧美国产激情二区三区| 成人动漫在线一区| 亚洲视频在线观看三级| 色综合色狠狠天天综合色| 亚洲视频每日更新| 色噜噜久久综合| 亚洲国产毛片aaaaa无费看| 欧美日韩精品久久久| 天天操天天干天天综合网| 8v天堂国产在线一区二区| 日本欧美在线看| 欧美精品一区二区三区在线 | 国产喂奶挤奶一区二区三区| 国内成+人亚洲+欧美+综合在线 | 国产精品一级黄| 国产精品美女久久久久久2018| av在线一区二区| 亚洲电影欧美电影有声小说| 日韩欧美亚洲一区二区| 国产成人夜色高潮福利影视| 亚洲三级免费观看| 欧美一区二区视频免费观看| 国产乱码精品1区2区3区| 国产精品久久久一本精品| 91国产成人在线| 免费精品99久久国产综合精品| 久久色在线观看| 色先锋久久av资源部| 毛片av一区二区| 日韩美女视频19| 日韩一区二区视频| 国产传媒一区在线| 亚洲高清免费观看高清完整版在线观看| 日本欧美一区二区三区| 国产喂奶挤奶一区二区三区| 在线观看日韩高清av| 韩国一区二区在线观看| 亚洲精选在线视频| 日韩欧美的一区| 91成人网在线| 国产成人av一区二区三区在线观看| 亚洲精品成人a在线观看| 精品国产污网站| 欧美系列亚洲系列| 国产成人在线影院| 日韩综合在线视频| 亚洲视频网在线直播| 久久夜色精品国产欧美乱极品| 91日韩在线专区| 国产成人一级电影| 另类小说欧美激情| 亚洲va欧美va天堂v国产综合| 国产拍欧美日韩视频二区| 91精品一区二区三区在线观看| 成人永久免费视频| 韩日av一区二区| 日韩电影免费在线| 亚洲国产精品综合小说图片区| 中文字幕av资源一区| 日韩欧美国产午夜精品| 欧美日韩国产综合视频在线观看| 成人av资源在线| 国产精品一二三| 老司机精品视频导航| 日韩国产在线观看一区| 亚洲精品中文在线观看| 国产精品天天看| 国产免费久久精品| 欧美激情在线看| 久久久久久久电影| 欧美精品一区二区久久婷婷| 在线播放亚洲一区| 7777精品伊人久久久大香线蕉超级流畅| 色妞www精品视频| 一本一本久久a久久精品综合麻豆| 高清国产午夜精品久久久久久| 久久99精品久久久久久国产越南 | 白白色 亚洲乱淫| 国产成人综合在线观看| 国产在线精品一区二区夜色| 六月丁香婷婷久久| 男男成人高潮片免费网站| 日日欢夜夜爽一区| 视频一区二区三区在线| 日本欧美一区二区| 精品一区二区三区视频| 另类小说视频一区二区| 国产一区二区影院| 丁香一区二区三区| av不卡在线播放| 一本一本大道香蕉久在线精品| 色综合久久综合| 欧美日产国产精品| 欧美一区二区成人| 久久久久久免费| 国产精品女主播在线观看| 亚洲天堂福利av| 亚洲综合自拍偷拍| 日韩av成人高清| 狠狠网亚洲精品| 99久久亚洲一区二区三区青草 | 精品国产乱码久久久久久牛牛| 欧美精品一区二区精品网| 国产精品无人区| 亚洲视频一区二区在线观看| 亚洲精品免费播放| 日日夜夜精品视频天天综合网| 亚洲色图制服诱惑| 中文字幕欧美日韩一区| 国产午夜精品一区二区| 国产精品影视在线观看| 国产91富婆露脸刺激对白| 成人精品视频一区二区三区尤物| 99国产欧美久久久精品| 欧美日韩国产综合久久| 精品国偷自产国产一区| 日本一区二区高清| 午夜精品久久久久久不卡8050| 麻豆免费精品视频| 91免费视频观看| 91精品欧美福利在线观看| 国产精品免费看片| 天天做天天摸天天爽国产一区| 国产伦精一区二区三区| 欧美三级三级三级| 中文字幕欧美区| 蜜臀av一区二区三区| 91精品办公室少妇高潮对白| 欧美大度的电影原声| 青椒成人免费视频| www国产成人| 亚洲一区免费视频| 成人永久免费视频| 欧美一区二区视频在线观看| 国产精品国产三级国产aⅴ中文 | 欧美日韩一区在线| 久久一区二区三区国产精品| 亚洲午夜在线视频| 丰满亚洲少妇av| 日韩精品一区二区三区蜜臀| 亚洲无线码一区二区三区| 成年人午夜久久久| 久久久精品国产99久久精品芒果| 日韩专区一卡二卡| 欧美午夜电影网| 亚洲精品第1页| 成人福利电影精品一区二区在线观看| 日韩午夜av一区| 日韩精品免费专区| 欧美老女人在线| 亚洲高清在线视频| 日本高清不卡视频| 国产精品成人在线观看| 国产成人精品免费| 国产亚洲午夜高清国产拍精品 | 日韩免费性生活视频播放| 亚洲三级免费电影| 成人av在线资源网| 国产女同互慰高潮91漫画| 麻豆精品一区二区综合av| 91精品国产一区二区人妖| 亚洲一区二区欧美日韩 | 国产高清精品在线| 久久女同性恋中文字幕| 激情综合网av| 精品国产青草久久久久福利| 青青国产91久久久久久| 91精品国产一区二区三区蜜臀 | 色婷婷综合久久久中文字幕| 欧美激情一区在线| 中文一区二区在线观看|