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

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

?? command.v

?? verilog語言 利用FPGA控制SDRAM
?? V
?? 第 1 頁 / 共 2 頁
字號:
/******************************************************************************
*
*  LOGIC CORE:          Command module			
*  MODULE NAME:         command()
*  COMPANY:             Northwest Logic Design, Inc.
*                       www.nwlogic.com
*
*  REVISION HISTORY:  
*
*    Revision 1.0  05/11/2000     Description: Initial Release.
*             1.1  07/10/2000     Description: change precharge to terminate
*                                              for full page accesses.
*
*  FUNCTIONAL DESCRIPTION:
*
*  This module is the command processor module for the SDR SDRAM controller.
*
*  Copyright Northwest Logic, Inc., 2000.  All rights reserved.  
******************************************************************************/
module command(
        CLK,
        RESET_N,
        SADDR,
        NOP,
        READA,
        WRITEA,
        REFRESH,
        PRECHARGE,
        LOAD_MODE,
        SC_CL,
        SC_RC,
        SC_RRD,
        SC_PM,
        SC_BL,
        REF_REQ,
        REF_ACK,
        CM_ACK,
        OE,
        SA,
        BA,
        CS_N,
        CKE,
        RAS_N,
        CAS_N,
        WE_N
        );

`include        "params.v"

input                           CLK;                    // System Clock
input                           RESET_N;                // System Reset
input   [`ASIZE-1:0]            SADDR;                  // Address
input                           NOP;                    // Decoded NOP command
input                           READA;                  // Decoded READA command
input                           WRITEA;                 // Decoded WRITEA command
input                           REFRESH;                // Decoded REFRESH command
input                           PRECHARGE;              // Decoded PRECHARGE command
input                           LOAD_MODE;              // Decoded LOAD_MODE command
input   [1:0]                   SC_CL;                  // Programmed CAS latency
input   [1:0]                   SC_RC;                  // Programmed RC delay
input   [3:0]                   SC_RRD;                 // Programmed RRD delay
input                           SC_PM;                  // programmed Page Mode
input   [3:0]                   SC_BL;                  // Programmed burst length
input                           REF_REQ;                // Hidden refresh request
output                          REF_ACK;                // Refresh request acknowledge
output                          CM_ACK;                 // Command acknowledge
output  [`DSIZE/8-1:0]          OE;                     // OE signal for data path module
output  [11:0]                  SA;                     // SDRAM address
output  [1:0]                   BA;                     // SDRAM bank address
output                          CS_N;                   // SDRAM chip selects
output                          CKE;                    // SDRAM clock enable
output                          RAS_N;                  // SDRAM RAS
output                          CAS_N;                  // SDRAM CAS
output                          WE_N;                   // SDRAM WE_N

            
reg                             CM_ACK;
reg                             REF_ACK;
reg     [`DSIZE/8-1:0]          OE;
reg     [11:0]                  SA;
reg     [1:0]                   BA;
reg                             CS_N;
reg                             CKE;
reg                             RAS_N;
reg                             CAS_N;
reg                             WE_N;



// Internal signals
reg                             do_nop;
reg                             do_reada;
reg                             do_writea;
reg                             do_writea1;
reg                             do_refresh;
reg                             do_precharge;
reg                             do_load_mode;
reg                             command_done;
reg     [7:0]                   command_delay;
reg     [3:0]                   rw_shift;
reg                             do_act;
reg                             rw_flag;
reg                             do_rw;
reg     [7:0]                   oe_shift;
reg                             oe1;
reg                             oe2;
reg                             oe3;
reg                             oe4;
reg     [3:0]                   rp_shift;
reg                             rp_done;

wire    [`ROWSIZE - 1:0]        rowaddr;
wire    [`COLSIZE - 1:0]        coladdr;
wire    [`BANKSIZE - 1:0]       bankaddr;

assign   rowaddr   = SADDR[`ROWSTART + `ROWSIZE - 1: `ROWSTART];          // assignment of the row address bits from SADDR
assign   coladdr   = SADDR[`COLSTART + `COLSIZE - 1:`COLSTART];           // assignment of the column address bits
assign   bankaddr  = SADDR[`BANKSTART + `BANKSIZE - 1:`BANKSTART];        // assignment of the bank address bits



// This always block monitors the individual command lines and issues a command
// to the next stage if there currently another command already running.
//
always @(posedge CLK or negedge RESET_N)
begin
        if (RESET_N == 0) 
        begin
                do_nop          <= 0;
                do_reada        <= 0;
                do_writea       <= 0;
                do_refresh      <= 0;
                do_precharge    <= 0;
                do_load_mode    <= 0;
                command_done    <= 0;
                command_delay   <= 0;
                rw_flag         <= 0;
                rp_shift        <= 0;
                rp_done         <= 0;
        end
        
        else
        begin

//  Issue the appropriate command if the sdram is not currently busy     
                if ((REF_REQ == 1 | REFRESH == 1) & command_done == 0 & do_refresh == 0 & rp_done == 0         // Refresh
                        & do_reada == 0 & do_writea == 0)
                        do_refresh <= 1;                                   
                else
                        do_refresh <= 0;
                       

                if ((READA == 1) & (command_done == 0) & (do_reada == 0) & (rp_done == 0) & (REF_REQ == 0))    // READA
                        do_reada <= 1;
                else
                        do_reada <= 0;
                    
                if ((WRITEA == 1) & (command_done == 0) & (do_writea == 0) & (rp_done == 0) & (REF_REQ == 0))  // WRITEA
                begin
                        do_writea <= 1;
                        do_writea1 <= 1;
                end
                else
                begin
                        do_writea <= 0;
                        do_writea1 <= 0;
                end
                if ((PRECHARGE == 1) & (command_done == 0) & (do_precharge == 0))                              // PRECHARGE
                        do_precharge <= 1;
                else
                        do_precharge <= 0;
 
                if ((LOAD_MODE == 1) & (command_done == 0) & (do_load_mode == 0))                              // LOADMODE
                        do_load_mode <= 1;
                else
                        do_load_mode <= 0;
                                               
// set command_delay shift register and command_done flag
// The command delay shift register is a timer that is used to ensure that
// the SDRAM devices have had sufficient time to finish the last command.

                if ((do_refresh == 1) | (do_reada == 1) | (do_writea == 1) | (do_precharge == 1)
                     | (do_load_mode))
                begin
                        command_delay <= 8'b11111111;
                        command_done  <= 1;
                        rw_flag <= do_reada;                                                  

                end
                
                else
                begin
                        command_done        <= command_delay[0];                // the command_delay shift operation
                        command_delay[6:0]  <= command_delay[7:1];                                
                        command_delay[7]    <= 0;
                end 
                
 
 // start additional timer that is used for the refresh, writea, reada commands               
                if (command_delay[0] == 0 & command_done == 1)
                begin
                        rp_shift <= 4'b1111;
                        rp_done <= 1;
                end
                else
                begin
                        rp_done         <= rp_shift[0];
                        rp_shift[2:0]   <= rp_shift[3:1];
                        rp_shift[3]     <= 0;
                end
        end
end


// logic that generates the OE signal for the data path module

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲色图欧洲色图婷婷| 一区二区免费视频| 欧美老女人在线| 欧美亚洲国产一区在线观看网站| 成人avav影音| 99国产精品国产精品久久| 成人动漫av在线| 91丝袜美女网| 欧美日韩国产小视频| 欧美日韩久久一区| 日韩欧美国产电影| 久久综合色8888| 国产精品色在线| 亚洲成在人线在线播放| 久久精品国产第一区二区三区| 韩国欧美国产1区| 成人免费看黄yyy456| 色婷婷精品大视频在线蜜桃视频| 精品视频在线视频| 欧美成人女星排名| 国产精品电影院| 视频在线观看一区| 国产一区二区三区观看| 91视频www| 日韩欧美中文字幕一区| 国产精品私房写真福利视频| 亚洲丰满少妇videoshd| 极品销魂美女一区二区三区| 成人av网站免费观看| 欧美日韩不卡在线| 国产午夜精品一区二区三区嫩草 | 91亚洲资源网| 欧美三级韩国三级日本一级| www久久久久| 亚洲精品久久7777| 久久99精品久久久久久| 91首页免费视频| 2023国产一二三区日本精品2022| 亚洲欧洲在线观看av| 日本不卡不码高清免费观看| 99re成人精品视频| 日韩欧美不卡一区| 一区二区在线观看不卡| 国产成人在线视频免费播放| 欧美群妇大交群中文字幕| 国产精品亲子乱子伦xxxx裸| 麻豆精品在线播放| 色欧美88888久久久久久影院| 久久午夜色播影院免费高清| 日韩激情一二三区| 99热99精品| 国产91清纯白嫩初高中在线观看| 成人性生交大片免费看视频在线 | 久久蜜桃av一区二区天堂 | 国产亚洲福利社区一区| 亚洲美女视频一区| 国产精品一区二区黑丝 | 免费看日韩a级影片| 91麻豆国产自产在线观看| 久久综合久色欧美综合狠狠| 日本色综合中文字幕| 色综合天天做天天爱| 中文一区二区完整视频在线观看| 老司机免费视频一区二区| 欧美挠脚心视频网站| 亚洲综合色成人| 日本韩国欧美三级| 亚洲激情欧美激情| 91蝌蚪porny九色| 日韩美女视频一区二区| 9色porny自拍视频一区二区| 亚洲欧洲精品一区二区三区| 丁香六月久久综合狠狠色| 日韩一级黄色大片| 麻豆成人综合网| 精品福利视频一区二区三区| 狠狠色丁香久久婷婷综| 欧美精品一区二区三区在线播放| 久久不见久久见免费视频7| 日韩欧美久久久| 国产在线不卡视频| 精品国产乱码久久久久久久久| 麻豆精品视频在线观看视频| 51精品国自产在线| 五月激情综合网| 欧美电影免费提供在线观看| 午夜精品爽啪视频| 日韩一级成人av| 国产一区二三区好的| 久久丝袜美腿综合| 波多野结衣的一区二区三区| 一区二区在线观看视频| 欧美疯狂做受xxxx富婆| 九色|91porny| 国产欧美一区在线| 91精品1区2区| 日韩精品三区四区| 久久久精品黄色| 国产精品一二三在| 国产精品久久久久国产精品日日| 91女人视频在线观看| 日韩中文字幕1| 久久综合久色欧美综合狠狠| 99久免费精品视频在线观看 | 91国偷自产一区二区使用方法| 亚洲免费av观看| 69堂精品视频| 国产不卡高清在线观看视频| 亚洲精品五月天| 欧美mv日韩mv国产网站app| 不卡一区二区在线| 亚洲一区二区成人在线观看| 精品美女在线播放| 91丨九色丨尤物| 国产在线日韩欧美| 亚洲午夜电影网| 国产精品毛片高清在线完整版| 欧美性做爰猛烈叫床潮| 国产精品一区二区三区乱码| 最新热久久免费视频| 91麻豆精品国产| 色噜噜狠狠一区二区三区果冻| 国产制服丝袜一区| 五月天视频一区| 亚洲人午夜精品天堂一二香蕉| 亚洲精品在线网站| 欧美卡1卡2卡| 91久久精品网| 91在线精品一区二区三区| 韩国成人精品a∨在线观看| 亚洲电影欧美电影有声小说| 中文字幕国产一区| 精品乱码亚洲一区二区不卡| 欧美日韩一二区| 99精品1区2区| 成人国产亚洲欧美成人综合网 | 国产三级久久久| 欧美一区二区三区不卡| 在线国产亚洲欧美| 色综合色综合色综合| 顶级嫩模精品视频在线看| 激情文学综合网| 久久99国产精品久久99果冻传媒| 天天色综合成人网| 亚洲国产一二三| 亚洲高清中文字幕| 性欧美疯狂xxxxbbbb| 亚洲一区二区三区在线| 亚洲视频一二三区| 亚洲三级在线免费| 亚洲精品成人悠悠色影视| 亚洲人快播电影网| 国产精品久久三区| 国产精品色哟哟网站| 国产拍揄自揄精品视频麻豆| 久久久不卡影院| 国产精品免费av| 亚洲女人的天堂| 天天做天天摸天天爽国产一区| 亚洲高清免费观看 | 欧美一区二区三区公司| 日韩视频国产视频| 精品国产精品网麻豆系列| 欧美精品一区二区三区一线天视频 | 五月天婷婷综合| 日韩av中文字幕一区二区| 日韩av高清在线观看| 久久99国产精品久久99| 成人午夜电影小说| 在线亚洲欧美专区二区| 7777精品伊人久久久大香线蕉完整版 | 亚洲国产一区二区在线播放| 丝袜美腿高跟呻吟高潮一区| 伦理电影国产精品| 国产成人精品午夜视频免费| 91视频91自| 91精品欧美福利在线观看 | 国产999精品久久久久久| 成人精品国产一区二区4080| 色域天天综合网| 欧美一区二区成人| 欧美国产精品v| 五月综合激情婷婷六月色窝| 国产精一品亚洲二区在线视频| 色综合天天综合色综合av | 欧美三级电影在线看| 欧美大片在线观看一区二区| 国产精品美女久久久久久久久| 亚洲午夜久久久久久久久久久| 精品无人码麻豆乱码1区2区 | 国产精品女主播av| 亚洲在线一区二区三区| 国产一区二区女| 欧美三级欧美一级| 国产精品日韩成人| 蜜臀av一区二区| 91国产精品成人| 国产福利一区二区三区视频在线 | 成人黄色大片在线观看| 在线精品视频免费播放|