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

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

?? ddr_sig.v

?? DDR RAM控制器的VHDL源碼
?? V
字號:
// --------------------------------------------------------------------
// >>>>>>>>>>>>>>>>>>>>>>>>> COPYRIGHT NOTICE <<<<<<<<<<<<<<<<<<<<<<<<<
// --------------------------------------------------------------------
// Copyright (c) 2001 by Lattice Semiconductor Corporation
// --------------------------------------------------------------------
//
// Permission:
//
//   Lattice Semiconductor grants permission to use this code for use
//   in synthesis for any Lattice programmable logic product.  Other
//   use of this code, including the selling or duplication of any
//   portion is strictly prohibited.
//
// Disclaimer:
//
//   This VHDL or Verilog source code is intended as a design reference
//   which illustrates how these types of functions can be implemented.
//   It is the user's responsibility to verify their design for
//   consistency and functionality through the use of formal
//   verification methods.  Lattice Semiconductor provides no warranty
//   regarding the use or functionality of this code.
//
// --------------------------------------------------------------------
//           
//                     Lattice Semiconductor Corporation
//                     5555 NE Moore Court
//                     Hillsboro, OR 97214
//                     U.S.A
//
//                     TEL: 1-800-Lattice (USA and Canada)
//                          408-826-6000 (other locations)
//
//                     web: http://www.latticesemi.com/
//                     email: techsupport@latticesemi.com
//
// --------------------------------------------------------------------
//
// This is the signal module of the SDR SDRAM controller reference
// design which generates all signals required to interface with the
// SDR SDRAM.
//
// --------------------------------------------------------------------
//
// Revision History :
// --------------------------------------------------------------------
//   Ver  :| Author            :| Mod. Date :| Changes Made:
//   V0.1 :| Nagaraj Chekka    :| 07/28/03  :| Pre-Release
// --------------------------------------------------------------------

`timescale 1ns / 1ps

`define DDR_COMMAND_I  {ddr_csn_i, ddr_rasn_i, ddr_casn_i, ddr_wen_i}
`define DDR_COMMAND    {ddr_csn,   ddr_rasn,   ddr_casn,   ddr_wen}

module ddr_sig(
               clk,
               reset_n,
               addr,
               istate,
               cstate,
               ddr_cke,    // ddr clock enable
               ddr_csn,    // ddr chip select
               ddr_rasn,   // ddr row address
               ddr_casn,   // ddr column select
               ddr_wen,    // ddr write enable
               ddr_ba,     // ddr bank address
               ddr_add     // ddr address
               );

`include "ddr_par.v"

//---------------------------------------------------------------------
// inputs
//
input                     clk;
input                     reset_n;
input [RA_MSB:CA_LSB]     addr;
input [3:0]               istate;
input [3:0]               cstate;

//---------------------------------------------------------------------
// outputs
//
output                    ddr_cke;
output                    ddr_csn;
output                    ddr_rasn;
output                    ddr_casn;
output                    ddr_wen;
output [DDR_BA_WIDTH-1:0] ddr_ba;
output [DDR_A_WIDTH-1:0]  ddr_add;

reg                       ddr_cke /*synthesis dout="" */ ;
reg                       ddr_csn /*synthesis dout="" */;
reg                       ddr_rasn /*synthesis dout="" */;
reg                       ddr_casn /*synthesis dout="" */;
reg                       ddr_wen /*synthesis dout="" */;
reg [DDR_BA_WIDTH-1:0]    ddr_ba /*synthesis dout="" */;
reg [DDR_A_WIDTH-1:0]     ddr_add /*synthesis dout="" */;


reg                       ddr_cke_i;
reg                       ddr_csn_i;
reg                       ddr_rasn_i;
reg                       ddr_casn_i;
reg                       ddr_wen_i;
reg [DDR_BA_WIDTH-1:0]    ddr_ba_i;
reg [DDR_A_WIDTH-1:0]     ddr_add_i;


//---------------------------------------------------------------------
// DDR DDRAM Control Singals
//
always @(posedge clk or negedge reset_n) begin
   if (reset_n == 1'b0) begin
      `DDR_COMMAND_I    <= INHIBIT;
      ddr_cke_i         <= 1'b0;
      ddr_ba_i          <= 2'b11;
      ddr_add_i         <= 12'b1111_1111_1111;
   end else begin
      case (istate)
        i_IDLE: begin
           `DDR_COMMAND_I    <= NOP;
           ddr_cke_i         <= 1'b0;
           ddr_ba_i          <= 2'b11;
           ddr_add_i         <= 12'b1111_1111_1111;
        end      
        
        i_tRP,
        i_tRFC1,
        i_tRFC2,
        i_tMRD,
        i_NOP: begin
           `DDR_COMMAND_I    <= NOP;
           ddr_cke_i         <= 1;
           ddr_ba_i          <= 2'b11;
           ddr_add_i         <= 12'b1111_1111_1111;
        end
        i_PRE: begin
           `DDR_COMMAND_I    <= PRECHARGE;
           ddr_cke_i         <= 1;
           ddr_ba_i          <= 2'b11;
           ddr_add_i         <= 12'b1111_1111_1111;
        end
        i_AR1,
        i_AR2: begin
           `DDR_COMMAND_I    <= AUTO_REFRESH;
           ddr_cke_i         <= 1;
           ddr_ba_i          <= 2'b11;
           ddr_add_i         <= 12'b1111_1111_1111;
        end
        i_EMRS: begin
           `DDR_COMMAND_I    <= LOAD_MODE_REGISTER;
           ddr_cke_i         <= 1;
           ddr_ba_i          <= 2'b01; //Extended mode register
           ddr_add_i         <= {10'b0,DRIVE_STRENGTH,DLL_ENABLE};
        end
        
        i_MRS: begin
           `DDR_COMMAND_I    <= LOAD_MODE_REGISTER;
           ddr_cke_i         <= 1;
           ddr_ba_i          <= 2'b00;
           ddr_add_i         <= {
                                 5'b00010,
                                 MR_CAS_Latency,
                                 MR_Burst_Type,
                                 MR_Burst_Length
                                 };
           //$display ("MR_CAS_Latency=%b, MR_Burst_Type=%b, MR_Burst_Length=%b", MR_CAS_Latency, MR_Burst_Type, MR_Burst_Length);
           
        end

        i_ready: begin

           case (cstate)
             c_idle,
             c_tRCD,
             c_tRFC,
             c_cl,
             c_rdata,
             c_wdata:  begin
                `DDR_COMMAND_I    <= NOP;
                ddr_cke_i         <= 1;
                ddr_ba_i          <= 2'b11;
                ddr_add_i         <= 12'b1111_1111_1111;
             end
             c_ACTIVE: begin
                `DDR_COMMAND_I    <= ACTIVE;
                ddr_cke_i         <= 1;
                ddr_ba_i          <= addr[BA_MSB:BA_LSB];//bank
                ddr_add_i         <= addr[RA_MSB:RA_LSB];//row
             end
             c_READA:  begin
                `DDR_COMMAND_I    <= READ;
                ddr_cke_i         <= 1;
                ddr_ba_i          <= addr[BA_MSB:BA_LSB];//bank
                ddr_add_i         <= {
                                      addr[CA_MSB],//column
                                      1'b1, //enable auto precharge
                                      addr[CA_MSB:CA_LSB]//column
                                      };
             end
             c_WRITEA: begin
                `DDR_COMMAND_I    <= WRITE;
                ddr_cke_i         <= 1;
                ddr_ba_i          <= addr[BA_MSB:BA_LSB];//bank
                ddr_add_i         <= {
                                      addr[CA_MSB],//column (11)
                                      1'b1, //enable auto precharge (10)
                                      addr[CA_MSB:CA_LSB]//column (0-9)
                                      };
             end
           c_AR: begin
              `DDR_COMMAND_I    <= AUTO_REFRESH;
              ddr_cke_i         <= 1;
              ddr_ba_i          <= 2'b11;
              ddr_add_i         <= 12'b1111_1111_1111;
           end
             default:  begin
                `DDR_COMMAND_I    <= NOP;
                ddr_cke_i         <= 1;
                ddr_ba_i          <= 2'b11;
                ddr_add_i         <= 12'b1111_1111_1111;
             end
           endcase // case(cstate)
        end
        default: begin
           `DDR_COMMAND_I    <= NOP;
           ddr_cke_i         <= 1;
           ddr_ba_i          <= 2'b00;
           ddr_add_i         <= 12'b0000_0000_0000;
        end
      endcase
   end
end



always @(negedge clk or negedge reset_n) begin
   if (reset_n == 1'b0) begin
      `DDR_COMMAND    <= INHIBIT;
      ddr_cke         <= 1;
      ddr_ba          <= 2'b00;
      ddr_add         <= 12'b0000_0000_0000;
   end else begin
      `DDR_COMMAND    <= `DDR_COMMAND_I;
      ddr_cke         <= ddr_cke_i;
      ddr_ba          <= ddr_ba_i;
      ddr_add         <= ddr_add_i;
      
   end   
end
      
endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品电影一区亚洲| 欧美日韩国产高清一区二区 | 岛国精品在线观看| 欧美另类videos死尸| 中文字幕永久在线不卡| 日本网站在线观看一区二区三区 | ●精品国产综合乱码久久久久| 另类小说视频一区二区| 欧美探花视频资源| 国产精品网站在线| 国产馆精品极品| 欧美一区二区三区在线观看视频 | 欧美日本高清视频在线观看| 亚洲视频在线一区二区| 国产精品白丝jk白祙喷水网站| 在线电影院国产精品| 一区二区三区四区精品在线视频 | 亚洲欧美一区二区视频| 国产乱码字幕精品高清av | 日韩一区二区三区视频在线观看| 亚洲一区二区三区小说| 色综合久久天天| 综合久久综合久久| 成人激情免费视频| 国产精品久久久久久亚洲伦| 国产成人av资源| 国产午夜亚洲精品不卡| 国内精品视频666| 精品国产成人系列| 久久99国产精品久久| 日韩欧美激情四射| 日本特黄久久久高潮| 日韩视频一区二区| 激情综合网最新| 久久久影院官网| 成人免费视频caoporn| 亚洲欧洲三级电影| 色婷婷综合久久久| 亚洲va国产va欧美va观看| 欧美日韩aaa| 奇米色777欧美一区二区| 精品日本一线二线三线不卡| 极品美女销魂一区二区三区免费| 久久色在线观看| 成人av在线影院| 亚洲在线免费播放| 日韩一二在线观看| 大陆成人av片| 亚洲一区二区三区精品在线| 7777精品伊人久久久大香线蕉完整版 | 日韩激情视频网站| 337p日本欧洲亚洲大胆精品| 国产盗摄精品一区二区三区在线| 国产精品视频看| 欧美亚洲动漫制服丝袜| 午夜精品久久久久久久久| 日韩欧美久久久| 成人免费观看男女羞羞视频| 亚洲综合色丁香婷婷六月图片| 91精品国产丝袜白色高跟鞋| 国产一区二区三区蝌蚪| 亚洲男同性视频| 日韩精品一区二区三区视频 | 欧美浪妇xxxx高跟鞋交| 久久99精品久久久久久动态图| 国产精品国产三级国产三级人妇| 欧美亚男人的天堂| 国产美女精品在线| 亚洲国产精品久久久男人的天堂| 精品国产乱码久久久久久久| 91婷婷韩国欧美一区二区| 日本伊人色综合网| 亚洲啪啪综合av一区二区三区| 91精品视频网| 91在线视频在线| 日韩在线一区二区三区| 国产精品电影院| 欧美va亚洲va在线观看蝴蝶网| av电影天堂一区二区在线| 蜜桃视频一区二区三区在线观看| 亚洲欧美一区二区三区极速播放| 日韩精品一区二区在线| 91成人网在线| 高清国产一区二区三区| 蜜臀久久久久久久| 亚洲成人黄色影院| 亚洲色图一区二区三区| 国产人成亚洲第一网站在线播放 | 麻豆视频一区二区| 亚洲v日本v欧美v久久精品| 欧美国产精品专区| 精品国产一区二区三区久久久蜜月 | 亚洲一区二区综合| 自拍偷拍欧美精品| 久久久www免费人成精品| 91精品久久久久久久99蜜桃| 色8久久人人97超碰香蕉987| 懂色av一区二区三区免费看| 男人操女人的视频在线观看欧美| 亚洲国产成人av网| 一区二区三区中文在线观看| 亚洲天堂福利av| 国产精品久久午夜| 国产精品对白交换视频| 欧美国产精品v| 国产精品日日摸夜夜摸av| 久久精品在线免费观看| 久久久99精品免费观看不卡| 久久色成人在线| 久久久另类综合| 国产亚洲一二三区| 国产精品少妇自拍| 国产精品国产三级国产aⅴ入口| 国产日产欧产精品推荐色| 久久免费看少妇高潮| 精品99一区二区| 精品久久久久久亚洲综合网| 欧美大胆人体bbbb| 久久综合狠狠综合久久激情| 精品免费视频一区二区| 精品国产一区二区三区av性色 | 国精产品一区一区三区mba桃花| 美美哒免费高清在线观看视频一区二区 | 夜夜精品浪潮av一区二区三区| 亚洲乱码中文字幕综合| 亚洲伊人色欲综合网| 亚洲第一福利视频在线| 久久精品免费看| 成人一区二区三区视频在线观看| 99久久99久久综合| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 欧美性猛交xxxx乱大交退制版| 宅男在线国产精品| 精品国产免费一区二区三区香蕉| 国产女主播一区| 一区二区成人在线| 免费不卡在线观看| 岛国av在线一区| 欧美视频日韩视频| 久久蜜臀精品av| 亚洲免费观看高清完整版在线观看熊| 香蕉加勒比综合久久| 国产精品影视天天线| av不卡在线观看| 91麻豆精品国产91久久久久久 | 亚洲国产精品久久人人爱| 久久精品国内一区二区三区| 成人黄色网址在线观看| 色综合久久88色综合天天| 91精品国产黑色紧身裤美女| 欧美激情自拍偷拍| 日韩制服丝袜av| 成人av网址在线观看| 日韩一级片网址| 亚洲日本在线天堂| 国产在线精品不卡| 91福利国产精品| 欧美激情综合五月色丁香小说| 亚洲成人黄色小说| av在线不卡免费看| 精品久久久久一区二区国产| 一区二区三区四区国产精品| 国内欧美视频一区二区| 欧美三级电影一区| 国产网站一区二区三区| 日韩av一区二区三区| 91在线porny国产在线看| 久久久久综合网| 日本欧美在线观看| 色婷婷国产精品| 国产精品高潮呻吟| 国内精品国产三级国产a久久| 欧美人妇做爰xxxⅹ性高电影| 中文字幕亚洲成人| 国产成人av电影在线| 欧美一区二区在线观看| 亚洲自拍都市欧美小说| 一本色道久久加勒比精品| 精品少妇一区二区| 肉肉av福利一精品导航| 91官网在线免费观看| 亚洲欧美自拍偷拍| 成人深夜福利app| 欧美韩国日本不卡| 国产精品一级黄| 久久一留热品黄| 久久草av在线| 精品国产91亚洲一区二区三区婷婷| 午夜精品123| 欧美高清性hdvideosex| 亚洲一区二区三区中文字幕| 91丝袜高跟美女视频| 一区在线中文字幕| 色天使色偷偷av一区二区| 亚洲人成影院在线观看| 色哟哟一区二区| 亚洲精品国产成人久久av盗摄| 99re亚洲国产精品| 亚洲狼人国产精品| 欧美视频在线不卡|