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

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

?? sdcnt.v

?? 高速AD采集卡應用程序及SDRAM控制器
?? V
?? 第 1 頁 / 共 3 頁
字號:


`include "inc.h"


//*******************************************************************************
//  S Y N T H E S I Z A B L E      S D R A M     C O N T R O L L E R    C O R E
//
//  This core adheres to the GNU Public License  
// 
//  This is a synthesizable Synchronous DRAM controller Core.  As it stands,
//  it is ready to work with 8Mbyte SDRAMs, organized as 2M x 32 at 100MHz
//  and 125MHz. For example: Samsung KM432S2030CT,  Fujitsu MB81F643242B.
//
//  The core has been carefully coded so as to be "platform-independent".  
//  It has been successfully compiled and simulated under three separate
//  FPGA/CPLD platforms:
//      Xilinx Foundation Base Express V2.1i
//      Altera Max+PlusII V9.21
//      Lattice ispExpert V7.0
//  
//  The interface to the host (i.e. microprocessor, DSP, etc) is synchronous
//  and supports only one transfer at a time.  That is, burst-mode transfers
//  are not yet supported.  In many ways, the interface to this core is much
//  like that of a typical SRAM.  The hand-shaking between the host and the 
//  SDRAM core is done through the "sdram_busy_l" signal generated by the 
//  core.  Whenever this signal is active low, the host must hold the address,
//  data (if doing a write), size and the controls (cs, rd/wr).  
//
//  Connection Diagram:
//  SDRAM side:
//  sd_wr_l                     connect to -WR pin of SDRAM
//  sd_cs_l                     connect to -CS pin of SDRAM
//  sd_ras_l                    connect to -RAS pin of SDRAM
//  sd_cas_l                    connect to -CAS pin of SDRAM
//  sd_dqm[3:0]                 connect to the DQM3,DQM2,DQM1,DQM0 pins
//  sd_ba[1:0]                  connect to BA1, BA0 pins of SDRAM
//  sd_addx[10:0]               connect to the Address bus [10:0]
//  sd_data[31:0]               connect to the data bus [31:0]
//  
//   
//  HOST side:
//  mp_addx[22:0]               connect to the address bus of the host. 
//                              23 bit address bus give access to 8Mbyte
//                              of the SDRAM, as byte, half-word (16bit)
//                              or word (32bit)
//  mp_data_in[31:0]            Unidirectional bus connected to the data out
//                              of the host. To use this, enable 
//                              "databus_is_unidirectional" in INC.H
//  mp_data_out[31:0]           Unidirectional bus connected to the data in 
//                              of the host.  To use this, enable
//                              "databus_is_unidirectional" in INC.H
//  mp_data[31:0]               Bi-directional bus connected to the host's
//                              data bus.  To use the bi-directionla bus,
//                              disable "databus_is_unidirectional" in INC.H
//  mp_rd_l                     Connect to the -RD output of the host
//  mp_wr_l                     Connect to the -WR output of the host
//  mp_cs_l                     Connect to the -CS of the host
//  mp_size[1:0]                Connect to the size output of the host
//                              if there is one.  When set to 0
//                              all trasnfers are 32 bits, when set to 1
//                              all transfers are 8 bits, and when set to
//                              2 all xfers are 16 bits.  If you want the
//                              data to be lower order aligned, turn on
//                              "align_data_bus" option in INC.H
//  sdram_busy_l                Connect this to the wait or hold equivalent
//                              input of the host.  The host, must hold the
//                              bus if it samples this signal as low.
//  sdram_mode_set_l            When a write occurs with this set low,
//                              the SDRAM's mode set register will be programmed
//                              with the data supplied on the data_bus[10:0].
//
//
//  Author:  Jeung Joon Lee  joon.lee@quantum.com,  cmosexod@ix.netcom.com
//  
//*******************************************************************************
//
//  Hierarchy:
//
//  SDRAM.V         Top Level Module
//  HOSTCONT.V      Controls the interfacing between the micro and the SDRAM
//  SDRAMCNT.V      This is the SDRAM controller.  All data passed to and from
//                  is with the HOSTCONT.
//  optional
//  MICRO.V         This is the built in SDRAM tester.  This module generates 
//                  a number of test logics which is used to test the SDRAM
//                  It is basically a Micro bus generator. 
//  
/*
*/ 



module sdcnt(	
		// system level stuff
			sys_rst_l,
			sys_clk,
		
		// SDRAM connections
			sd_wr_l,
		//    sd_cs_l,
			sd_ras_l,
			sd_cas_l,
			sd_dqm,
			
		// Host Controller connections
	    	//do_mode_set,
	  		do_read,
            do_write,
            //doing_refresh,
            sd_addx_mux,
            sd_addx10_mux,
            //sd_rd_ena,
           // sd_wr_ena,
      // modereg_cas_latency,
           // modereg_burst_length,
            //mp_data_mux,
			//decoded_dqm,
            do_write_ack,
            do_read_ack,
				doing_precharge,
				doing_refresh,
          //  do_modeset_ack,
           // pwrup,	 
				sd_busy_l,
				sddata_ena,

			// debug
            next_state
			//autorefresh_cntr,
			//autorefresh_cntr_l,
			//cntr_limit

		);

//parameter N1 = 4;

// ****************************************
//
//   I/O  DEFINITION
//
// ****************************************


// System level stuff
input	        sys_rst_l;
input	        sys_clk;

// SDRAM connections
output	        sd_wr_l;
//output	        sd_cs_l;
output	        sd_ras_l;
output	        sd_cas_l;
output	 [3:0]  sd_dqm;

// Host Controller connections
//input           do_mode_set;///////????????
input           do_read;
input           do_write;
//output          doing_refresh;
output  [1:0]   sd_addx_mux;
output  [1:0]   sd_addx10_mux;
//output          sd_rd_ena;
//output          sd_wr_ena;
//input   [2:0]   modereg_cas_latency;
//input   [2:0]   modereg_burst_length;
//output          mp_data_mux;
//input	[3:0]	decoded_dqm;
output          do_write_ack;
output          do_read_ack;
//output          do_modeset_ack;
//output			pwrup; 

// Debug
output  [4:0]   next_state;
//output	[3:0]	autorefresh_cntr;
//output			autorefresh_cntr_l;
//output	[1:0]	cntr_limit;
output sd_busy_l;
output doing_precharge;
output doing_refresh;
output sddata_ena;

// ****************************************
//
// Memory Elements 
//
// ****************************************
//
reg     [4:0]	next_state;
reg     [10:0]   refresh_timer;
reg 	        sd_wr_l;
//reg		        sd_cs_l;
reg		        sd_ras_l;
reg		        sd_cas_l;
reg     [3:0]   sd_dqm;
reg     [1:0]   sd_addx_mux;
reg     [1:0]   sd_addx10_mux;
//reg             sd_wr_ena;
reg		        pwrup;			// this variable holds the power up condition
reg     [1:0]  refresh_cntr;   // this is the refresh counter
reg				refresh_cntr_l;	// this is the refresh counter reset signal
reg     [8:0]   burst_length_cntr;
reg             burst_cntr_ena;
//reg             sd_rd_ena;      // read latch gate, active high
reg     [1:0]  cntr_limit;
//reg     [3:0]   modereg_burst_count;
reg     [2:0]   refresh_state;
//reg             mp_data_mux;
wire            do_refresh;     // this bit indicates autorefresh is due
reg             doing_refresh;  // this bit indicates that the state machine is 
                                // doing refresh.
reg     [3:0]   autorefresh_cntr;
reg             autorefresh_cntr_l;
reg             do_write_ack;
reg             do_read_ack;
//reg             do_modeset_ack;
reg             do_refresh_ack;

//reg  [12:0]  counter_wait;//counter used in initialization process to generate 100us delay
                        
reg  [13:0]  counter_wait;
//wire            Trc_expired, Ref_expired;	

//assign Trc_expired = (autorefresh_cntr == 4'h6); 			  
//assign Ref_expired = (refresh_cntr == cntr_limit);			 
reg doing_precharge;
reg sddata_ena;
assign sd_busy_l=~(do_write|do_read|doing_refresh);


//-----------------------------------------------------------------------------------------------------------------------------------
// State Machine
always @(posedge sys_clk or negedge sys_rst_l)
  if (~sys_rst_l) begin
    next_state	<= `state_wait;
    autorefresh_cntr_l <= `LO;
	refresh_cntr_l  <= `LO;
    pwrup       <= `HI;				// high indicates we've just power'd up or RESET
    sd_wr_l     <= `HI;
    //sd_cs_l     <= `HI;
    sd_ras_l    <= `HI;
    sd_cas_l    <= `HI;
    sd_dqm      <= 4'h0;
   // sd_wr_ena <= `LO;
    sd_addx_mux <= 2'b10;           // select the mode reg default value
    sd_addx10_mux <= 2'b11;         // select 1 as default
   // sd_rd_ena   <= `LO;
  //  mp_data_mux <= `LO;

    burst_cntr_ena <= `LO;          // do not enable the burst counter
    doing_refresh  <= `LO;
	 doing_precharge<= `LO;
    do_write_ack <= `LO;            // do not ack as reset default
    do_read_ack  <= `LO;            // do not ack as reset default
	 sddata_ena<=`LO;
   // do_modeset_ack <= `LO;          // do not ack as reset default
    do_refresh_ack <= `LO;
    counter_wait<=20'd0;
  end 
  else case (next_state)
//--------------------------------------------------------------------------------------------------------
    // Power Up state
   /* `state_powerup:  begin
        next_state  <= `state_precharge;
        sd_wr_l     <= `HI;
       // sd_cs_l     <= `HI;
    	sd_ras_l    <= `HI;
    	sd_cas_l    <= `HI;
        sd_dqm      <= 4'hF;
        sd_data_ena <= `LO;
        sd_addx_mux <= 2'b10;
        sd_rd_ena   <= `LO;
        pwrup       <= `HI;         // this is the power up run
        burst_cntr_ena <= `LO;      // do not enable the burst counter
		refresh_cntr_l <= `HI;		// allow the refresh cycle counter to count
     end*/

//-------------------------------------------------------------------------------------------------------------------
//Wait 100us
`state_wait: begin

		sd_wr_l     <= `HI;    //NOP       
    	sd_ras_l    <= `HI;   //NOP
    	sd_cas_l    <= `HI;   //NOP

      //sd_dqm      <= 4'hF;
		sd_dqm<=4'd0;
//		sd_wr_ena <= `LO;
		//sd_rd_ena   <= `LO;

		sd_addx_mux <= 2'b10;

	pwrup       <= `HI;   
	burst_cntr_ena <= `LO;      // do not enable the burst counter
	refresh_cntr_l <= `HI;		// allow the refresh cycle counter to count


	if(counter_wait>=14'd11000)   ////注意根據時鐘設定具體數值,對于105M的時鐘信號
	                              //等待100US需要10526個周期
											//但仿真結果表明至少要等到5555才能滿足100US的要求
	
  		 begin
  		 //調試屏蔽	next_state<=`state_precharge;
		    counter_wait<=14'd0;
		 	doing_precharge<=`HI; //下個周期進行PRECHARGE,
		   next_state<=`state_precharge;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区欧美激情| 婷婷久久综合九色国产成人| 国产精品久久久久天堂| 亚洲精品国产成人久久av盗摄| 亚洲一区在线看| 人人精品人人爱| 麻豆精品视频在线观看视频| 高清国产午夜精品久久久久久| 成人a区在线观看| 99在线视频精品| 精品视频在线免费看| 欧美mv日韩mv亚洲| 国产精品久久久久久户外露出| 亚洲bdsm女犯bdsm网站| 韩国女主播成人在线| 色婷婷久久久亚洲一区二区三区| 91精品国产综合久久久久久久| 久久久精品国产免费观看同学| 亚洲乱码国产乱码精品精小说| 捆绑调教一区二区三区| 色婷婷久久一区二区三区麻豆| 精品成人一区二区| 亚洲高清免费观看高清完整版在线观看 | 一区二区三区中文在线| 国产乱妇无码大片在线观看| 在线免费精品视频| 国产精品国产三级国产专播品爱网 | 国产精品系列在线| 久久99精品久久只有精品| 91激情在线视频| 国产精品久久久久久久久免费樱桃 | 国产综合色精品一区二区三区| 色综合天天综合狠狠| 精品国产乱码久久久久久图片 | 欧美日韩一二三| 91精品国产综合久久精品麻豆| 中文字幕在线不卡国产视频| 高清不卡一二三区| 国产精品人妖ts系列视频| 成人一区二区视频| 中文字幕综合网| 91免费国产在线观看| 亚洲综合视频网| 3d动漫精品啪啪| 免费的成人av| 国产亚洲视频系列| 94-欧美-setu| 亚洲a一区二区| 精品国产免费久久| 国产河南妇女毛片精品久久久| 国产精品三级av在线播放| 97久久精品人人做人人爽50路| 一区二区在线观看av| 欧美伦理影视网| 国模冰冰炮一区二区| 国产精品私房写真福利视频| 一道本成人在线| 日韩av网站免费在线| 久久免费国产精品| 91影院在线观看| 日本欧美一区二区三区乱码| 久久亚洲捆绑美女| 91福利视频网站| 久久不见久久见免费视频1| 国产精品初高中害羞小美女文| 欧美人xxxx| 成人小视频在线| 日本成人在线看| 亚洲欧洲日韩女同| 日韩久久免费av| 色诱亚洲精品久久久久久| 麻豆91在线播放| 亚洲日本在线a| 欧美大片一区二区| 日本精品裸体写真集在线观看| 日韩国产精品久久久久久亚洲| 国产精品全国免费观看高清| 91精品久久久久久蜜臀| 91在线观看污| 国产乱人伦偷精品视频免下载| 一级精品视频在线观看宜春院 | 国产在线精品一区二区| 亚洲最新在线观看| 日本一区二区不卡视频| 日韩女优电影在线观看| 欧美一a一片一级一片| 国产精品一区二区三区四区| 日韩激情一区二区| 亚洲精品中文在线影院| 国产欧美日韩综合| 精品久久久久久久一区二区蜜臀| 在线观看一区二区视频| 成人免费观看视频| 国产一区二区三区在线看麻豆| 亚洲成人av电影| 一区二区三区精品视频在线| 日本一区二区动态图| 久久久蜜桃精品| 日韩欧美一级二级三级| 欧美老女人在线| 欧美在线你懂得| 欧美在线视频你懂得| 一本色道久久综合亚洲aⅴ蜜桃| 国产成人午夜99999| 激情久久五月天| 久久99国产精品久久| 免费视频一区二区| 天天爽夜夜爽夜夜爽精品视频| 亚洲国产日日夜夜| 亚洲高清视频在线| 午夜欧美电影在线观看| 亚洲成人三级小说| 亚洲在线观看免费视频| 夜夜爽夜夜爽精品视频| 一区二区免费视频| 亚洲成人综合在线| 日韩国产一二三区| 久久99精品久久久| 国产呦精品一区二区三区网站| 国产一区二区不卡老阿姨| 国产乱码精品一区二区三区忘忧草| 久久超碰97人人做人人爱| 精品一区二区三区香蕉蜜桃| 精品一区二区三区不卡| 国产一区二区三区香蕉| 国产精品99久久久| 99re热这里只有精品免费视频| 91久久精品一区二区三区| 欧美唯美清纯偷拍| 日韩视频免费观看高清完整版在线观看| 日韩写真欧美这视频| 精品福利视频一区二区三区| 国产肉丝袜一区二区| 亚洲欧洲国产专区| 亚洲午夜电影网| 日产国产高清一区二区三区| 国产综合久久久久影院| jvid福利写真一区二区三区| 日本韩国一区二区| 日韩欧美国产午夜精品| 国产欧美日韩中文久久| 夜夜嗨av一区二区三区| 蜜臀a∨国产成人精品| 国产91精品露脸国语对白| 91看片淫黄大片一级在线观看| 3d动漫精品啪啪一区二区竹菊| 久久免费看少妇高潮| 一区二区三区 在线观看视频| 免播放器亚洲一区| a级精品国产片在线观看| 欧美精品乱码久久久久久| 欧美国产日韩a欧美在线观看| 亚洲国产精品一区二区www| 狠狠色丁香婷综合久久| 欧美中文字幕一区二区三区亚洲| 日韩欧美国产麻豆| 亚洲男人天堂一区| 婷婷中文字幕一区三区| fc2成人免费人成在线观看播放 | 一区视频在线播放| 日本午夜一本久久久综合| av午夜一区麻豆| 精品久久久久av影院| 一区二区三区精密机械公司| 国产成人激情av| 欧美一级日韩免费不卡| 亚洲最大成人网4388xx| 国产精品一级在线| 欧美一区二区三区视频免费播放| 亚洲天天做日日做天天谢日日欢 | 美女免费视频一区二区| 一本色道亚洲精品aⅴ| 国产亚洲精品aa| 蜜臀a∨国产成人精品| 欧美揉bbbbb揉bbbbb| 最新不卡av在线| 成人在线视频一区| 久久久久久久久久久黄色| 日韩电影在线观看一区| 欧美丝袜自拍制服另类| 亚洲免费大片在线观看| 成人手机电影网| 国产亚洲成aⅴ人片在线观看 | 亚洲国产精品v| 国产一区二区三区久久悠悠色av| 欧美片网站yy| 亚洲成人综合在线| 欧美日韩精品一区视频| 一区二区视频在线| 99久久免费精品高清特色大片| 久久久影视传媒| 国产呦萝稀缺另类资源| 26uuu色噜噜精品一区二区| 欧美bbbbb| 日韩欧美成人激情| 毛片av一区二区| xnxx国产精品| 国产久卡久卡久卡久卡视频精品| 精品国产网站在线观看| 韩国一区二区三区|