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

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

?? ddr_cntl_a_controller_0.v

?? arm控制FPGA的DDR測試代碼
?? V
?? 第 1 頁 / 共 4 頁
字號:
                            else
                                 next_state1 <= WRITE_WAIT;
                         end
                       default :
                         next_state1 <= WRITE_WAIT;
                     endcase
                     end
          BURST_WRITE :
                       begin
              if ((burst_length == 3'b001) && (wrburst_end == 1'b0))   //Added for BL =2
                        next_state1 <= BURST_WRITE;
             else if ((burst_length == 3'b001) && (wrburst_end == 1'b1))
				next_state1 <= PRECHARGE_AFTER_WRITE;  
               else
                         next_state1 <= WRITE_WAIT;
                       end
          READ_AFTER_WRITE :
                     next_state1 <= BURST_READ;
          PRECHARGE_AFTER_WRITE :
                     next_state1 <= PRECHARGE_AFTER_WRITE_2;
          PRECHARGE_AFTER_WRITE_2 : 
          		begin  
                     if(WR_COUNT == 2'd0)   
		       precharge_flag <= 1'b1;
		     else
                     next_state1 <= PRECHARGE_AFTER_WRITE_2;
                     end   
                    

          READ_WAIT : begin
                     case(rdburst_end)
                     1'b1 :
                      next_state1 <= PRECHARGE_AFTER_WRITE;
                     1'b0 :
                         begin
                           if (CAS_COUNT == 3'b001) //For BL = 8
                             next_state1 <= BURST_READ;
                         else
                             next_state1 <= READ_WAIT;
                         end
                     default :
                         next_state1 <= READ_WAIT;
                    endcase
                     end
          BURST_READ :
                     begin
              if ((burst_length == 3'b001) && (rdburst_end == 1'b0))    //Added for BL =2
                        next_state1 <= BURST_READ;
             else if ((burst_length == 3'b001) && (rdburst_end == 1'b1))
				next_state1 <= PRECHARGE_AFTER_WRITE;  
               else
                         next_state1 <= READ_WAIT;
                     end
          BURST_STOP :
                    next_state1 <= READ_WAIT;
          default :
                next_state1 <= IDLE;
    endcase
  end
end

//************************************************************************************************
// address generation logic
//************************************************************************************************

assign address_config[`row_address-1:7] = (INIT_COUNT == 3'b010) ? {`row_address-7{1'b0}} :
                                          (INIT_COUNT == 3'b011) ? {{`row_address-9{1'b0}},2'b10}:
                                          (next_state == PRECHARGE) ? 8 :
                                          {`row_address-7{1'b0}};

assign address_config[6:4] =  (INIT_COUNT == 3'b010) ? 3'b000 :
                              (next_state == LOAD_MODE_REG) ? cas_latency :
                              3'b000;
                              
assign address_config[3] = 1'b0; // design uses sequential burst

assign address_config[2:0] =  (INIT_COUNT == 3'b010) ? 3'b000 :
                              (next_state == LOAD_MODE_REG) ? burst_length :
                              3'b000;


assign ddr_address1 = (next_state == LOAD_MODE_REG || next_state == PRECHARGE) ? address_config :
                      (next_state == ACTIVE) ? row_address_reg :
                        ((next_state == BURST_WRITE) || (next_state == FIRST_WRITE) || (next_state == BURST_READ)) ? column_address_reg : 
                      `row_address'b0;
                      
assign ddr_ba1 =  ((next_state == LOAD_MODE_REG) && (INIT_COUNT == 3'b010)) ? {{`bank_address-1{1'b0}},1'b1} :
                  ((next_state == ACTIVE) || (next_state == FIRST_WRITE) || (next_state == BURST_WRITE) || (next_state == BURST_READ)) ? BA_address_reg :
                  {{`bank_address-1{1'b0}},1'b0};



//********************************************************************************************************
//  register row address
//********************************************************************************************************
always @ (negedge clk)       //(posedge clk180)
begin
  if (rst180_r == 1'b1)
     row_address_active_reg <= `row_address'b0;
  else
   begin
     if (next_state == ACTIVE)
         row_address_active_reg <= row_address_reg;
     else
         row_address_active_reg <= row_address_active_reg;
   end
end

always @ (negedge clk)       //(posedge clk180)
begin
  if (rst180_r == 1'b1)
     row_address_conflict <= 1'b0;
  else
   begin
     if (row_address_reg != row_address_active_reg)
         row_address_conflict <= 1'b1;
     else
         row_address_conflict <= 1'b0;
   end
end

//********************************************************************************************************
//  register bank address
//********************************************************************************************************

always @ (negedge clk)       //(posedge clk180)
begin
  if (rst180_r == 1'b1)
      BA_address_active <= `bank_address'b0;
  else
    begin
      if (next_state == ACTIVE)
          BA_address_active <= BA_address_reg;
      else
          BA_address_active <= BA_address_active;
    end
end

always @ (negedge clk)       //(posedge clk180)
begin
  if (rst180_r == 1'b1)
      BA_address_conflict <= 1'b0;
  else
    begin
      if (BA_address_reg != BA_address_active)
          BA_address_conflict <= 1'b1;
      else
          BA_address_conflict <= 1'b0;
    end
end

//********************************************************************************************************
//  register column address
//********************************************************************************************************
always @ (negedge clk)       //(posedge clk180)
begin
  if (rst180_r == 1'b1)
    begin
     column_address_reg1 <= `row_address'b0;
     column_address_reg2 <= `row_address'b0;
     column_address_reg3 <= `row_address'b0;
     column_address_reg4 <= `row_address'b0;
     column_address_reg5 <= `row_address'b0;
     column_address_reg6 <= `row_address'b0; 

    end
  else
    begin
     column_address_reg1 <= column_address_reg;
     column_address_reg2 <= column_address_reg1;
     column_address_reg3 <= column_address_reg2;
     column_address_reg4 <= column_address_reg3;
     column_address_reg5 <= column_address_reg4;
     column_address_reg6 <= column_address_reg5;
    end
end



//**************************************************************************************************
//Pipeline stages for ddr_address and ddr_ba
//**************************************************************************************************

always @ (negedge clk)       //(posedge clk180)
begin
if (rst180_r == 1'b1)
  begin
   ddr_address2  <= `row_address'b0;
   ddr_address3  <= `row_address'b0;
   ddr_ba2       <= `bank_address'b0;
   ddr_ba3       <= `bank_address'b0;
  end
else
  begin
    ddr_address2 <= ddr_address1;
    ddr_address3 <= ddr_address2;
    ddr_ba2      <= ddr_ba1;
    ddr_ba3      <= ddr_ba2;
  end
end

always @ (negedge clk)       //(posedge clk180)
begin
  if (rst180_r == 1'b1)
    begin
      ddr_address4  <= `row_address'b0;
      ddr_address5  <= `row_address'b0;
      ddr_address_cntrl   <= `row_address'b0;
    end
  else
    begin
      ddr_address4  <= ddr_address3;
      ddr_address5  <= ddr_address4;
     ddr_address_cntrl   <= ddr_address1;
    end
end

always @ (negedge clk)       //(posedge clk180)
begin
  if (rst180_r == 1'b1)
    begin
     ddr_ba4 <= `bank_address'b0;
     ddr_ba5 <= `bank_address'b0;
     ddr_ba_cntrl  <= `bank_address'b0;
    end
  else
    begin
     ddr_ba4 <= ddr_ba3;
     ddr_ba5 <= ddr_ba4;
     ddr_ba_cntrl  <= ddr_ba1;

    end
end

//************************************************************************************************
// control signals to the Memory
//************************************************************************************************

assign ddr_rasb1 = ((next_state == ACTIVE) || (next_state == PRECHARGE) || (next_state == AUTO_REFRESH) || (next_state == LOAD_MODE_REG)) ? 1'b0 : 1'b1;

assign ddr_casb1 = ((next_state == BURST_READ) || (next_state == BURST_WRITE) || (next_state == FIRST_WRITE) || 
                   (next_state == AUTO_REFRESH) || (next_state == LOAD_MODE_REG)) ? 1'b0 : 1'b1;

assign ddr_web1  = ((next_state == BURST_WRITE) || (next_state == FIRST_WRITE) || (next_state == BURST_STOP) || 
                   (next_state == PRECHARGE) || (next_state == LOAD_MODE_REG)) ? 1'b0 : 1'b1;


//*************************************************************************************************
// register CONTROL SIGNALS outputs
//**************************************************************************************************
always @ (negedge clk)       //(posedge clk180)
begin
  if (rst180_r == 1'b1)
    begin
      ddr_rasb3 <= 1'b1;
      ddr_casb3 <= 1'b1;
      ddr_web3  <= 1'b1;
      ddr_rasb2 <= 1'b1;
      ddr_casb2 <= 1'b1;
      ddr_web2  <= 1'b1;
    end
  else
    begin
      ddr_rasb2    <= ddr_rasb1;
      ddr_casb2    <= ddr_casb1;
      ddr_web2     <= ddr_web1;
      ddr_rasb3     <= ddr_rasb2;
      ddr_casb3    <= ddr_casb2;
      ddr_web3     <= ddr_web2;
    end
end

always @ (negedge clk)       //(posedge clk180)
begin
  if (rst180_r == 1'b1)
    begin
      ddr_rasb4  <= 1'b1;
      ddr_casb4  <= 1'b1;
      ddr_web4   <= 1'b1; 
      ddr_rst_dqs_rasb4  <= 1'b1;
      ddr_rst_dqs_casb4  <= 1'b1;
      ddr_rst_dqs_web4   <= 1'b1; 
      ddr_rasb5 <= 1'b1;
      ddr_casb5 <= 1'b1;
      ddr_web5  <= 1'b1;
    end
  else
    begin
      ddr_rasb4  <= ddr_rasb3;
      ddr_casb4  <= ddr_casb3;
      ddr_web4   <= ddr_web3;
      ddr_rasb5   <= ddr_rasb4;
      ddr_casb5   <= ddr_casb4;
      ddr_web5    <= ddr_web4;
    
	 if(cas_latency == 3'b011) // --CL3
	 begin
		ddr_rst_dqs_rasb4  <= ddr_rasb1;
   		ddr_rst_dqs_casb4  <= ddr_casb1;
   		ddr_rst_dqs_web4   <= ddr_web1; 
	 end
	 
	else
	begin
	  ddr_rst_dqs_rasb4  <= ddr_rst_dqs_rasb4;
   	ddr_rst_dqs_casb4  <= ddr_rst_dqs_casb4;
   	ddr_rst_dqs_web4   <= ddr_rst_dqs_web4; 
	end
	end
end

always @ (negedge clk)       //(posedge clk180)
begin
    if (rst180_r == 1'b1)
        dqs_div_cascount <= 3'b000;
    else
      begin
  if( (ddr_rasb1 == 1'b1) && (ddr_casb1 == 1'b0) && (ddr_web1 == 1'b1) && ((cas_latency == 3'b010)||(cas_latency == 3'b110)) )  // For CL= 2,2.5 & BL=8,4
          dqs_div_cascount <= burst_cnt_max ; // Modified by Abhishake for BL=8

   else if((ddr_rst_dqs_rasb4 == 1'b1) && (ddr_rst_dqs_casb4 == 1'b0) && (ddr_rst_dqs_web4 == 1'b1)) // For BL = 4,8 & CL=3
             dqs_div_cascount <= burst_cnt_max ;
   else
    begin
     if (dqs_div_cascount != 3'b000)
        dqs_div_cascount <= dqs_div_cascount - 1'b1;
      else
       dqs_div_cascount <= dqs_div_cascount;
       end
  end
end

always @ (negedge clk)       //(posedge clk180)
begin
    if (rst180_r == 1'b1)
        dqs_div_rdburstcount <= 3'b000;
    else
      begin
             if (dqs_div_cascount == 3'b001  && burst_length == 3'b010)
            dqs_div_rdburstcount <= 3'b010; 
        else if (dqs_div_cascount == 3'b011  && burst_length == 3'b011)
            dqs_div_rdburstcount <= 3'b100; 
        else if (dqs_div_cascount == 3'b001  && burst_length == 3'b001) // Added for BL = 2
            dqs_div_rdburstcount <= 3'b001;                             // Added for BL = 2  

        else 
          begin
            if (dqs_div_rdburstcount != 3'b000)
               dqs_div_rdburstcount <= dqs_div_rdburstcount - 1'b1;
            else
               dqs_div_rdburstcount <= dqs_div_rdburstcount;
          end
      end
end


always @ (negedge clk)       //(posedge clk180)
begin
    if (rst180_r == 1'b1)
        rst_dqs_div_r <= 1'b0;
    else
      begin
        if (dqs_div_cascount == 3'b001  && burst_length == 3'b010)
            rst_dqs_div_r <= 1'b1;
        else if (dqs_div_cascount == 3'b011  && burst_length == 3'b011)
            rst_dqs_div_r <= 1'b1;
	  else if (dqs_div_cascount == 3'b001  && burst_length == 3'b001)   // Added for BL = 2
            rst_dqs_div_r <= 1'b1;                                         // Added for BL = 2 

        else if (dqs_div_rdburstcount == 3'b001 && dqs_div_cascount == 3'b000)
            rst_dqs_div_r <= 1'b0;
        else
            rst_dqs_div_r <= rst_dqs_div_r;
      end
end



//For BL=2,4,8 n Comp or Unbuffered Dimms
assign rst_dqs_div_r1 = rst_dqs_div_r;

always @(negedge clk)    //(posedge clk180)
begin
  if (rst180_r == 1'b1)
    dly_dqs_div_r <= 1'b0;
  else
    dly_dqs_div_r <= rst_dqs_div_r;
end


 FD  rst_calib0  (
                 .Q(rst_calib),     
                 
                 
   .D(rst_dqs_div_r),  

		                                              
                 .C(~clk)     //.C(clk180)
                 );         
        
FD  rst_iob_out (
                 .Q(rst_dqs_div_int),     
                 
       	     
   .D(rst_dqs_div_r1),  

	           
		     
		     
   .C(clk)  

       	     
	           
		     	
                 );
   
                 
endmodule   

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩国产小视频在线观看| 伊人色综合久久天天| 国产精品久久久久久久久免费相片| 亚洲欧洲日韩一区二区三区| 奇米精品一区二区三区在线观看一| 国产91在线观看| 在线电影欧美成精品| 国产精品久久久爽爽爽麻豆色哟哟 | 日韩欧美一级在线播放| 自拍视频在线观看一区二区| 国产伦理精品不卡| 欧美一区二区网站| 亚洲一区二区av在线| 成人精品高清在线| 久久嫩草精品久久久久| 男女性色大片免费观看一区二区| 色婷婷综合久久久| 日韩理论片中文av| 丁香五精品蜜臀久久久久99网站| 欧美本精品男人aⅴ天堂| 亚洲高清免费视频| 欧美丝袜自拍制服另类| 亚洲欧美乱综合| av在线不卡网| 中文字幕日韩欧美一区二区三区| 国产精品一区二区久久不卡| 日产精品久久久久久久性色| 国产乱色国产精品免费视频| 日韩丝袜美女视频| 天天做天天摸天天爽国产一区| 欧美日韩中文一区| 亚洲一区二区三区在线看| 色诱亚洲精品久久久久久| 亚洲欧洲在线观看av| eeuss国产一区二区三区| 日本一区二区视频在线| av在线播放不卡| 国产精品久久久爽爽爽麻豆色哟哟| 国产不卡视频一区| 欧美国产日韩精品免费观看| 丁香婷婷深情五月亚洲| 国产精品久久久久永久免费观看| 国产激情一区二区三区四区| 国产亚洲精品中文字幕| 99国产精品99久久久久久| 国产精品久久三| 91高清视频免费看| 日韩欧美一二区| 一区二区三区在线观看欧美 | 欧美日韩精品一区二区天天拍小说| 亚洲九九爱视频| 精品视频一区三区九区| 日本欧美一区二区三区乱码| 日韩一区二区电影| 从欧美一区二区三区| 亚洲欧美欧美一区二区三区| 欧美伊人久久久久久久久影院| 日韩国产精品久久| 久久久高清一区二区三区| 高清不卡在线观看av| 一区二区三区精品| 日韩女优av电影| 国产福利精品导航| 亚洲午夜精品在线| 337p日本欧洲亚洲大胆色噜噜| 色婷婷综合久久久| 一区二区三区成人| 日韩欧美国产一区二区在线播放 | av动漫一区二区| 夜夜嗨av一区二区三区| 91精品在线免费| 成人免费视频一区二区| 日韩在线观看一区二区| 久久精品免费在线观看| 欧美性视频一区二区三区| 麻豆精品在线看| 亚洲美女屁股眼交3| 精品福利在线导航| 97aⅴ精品视频一二三区| 蜜桃91丨九色丨蝌蚪91桃色| 亚洲人xxxx| 久久久久久久一区| 67194成人在线观看| a4yy欧美一区二区三区| 蜜乳av一区二区| 1024精品合集| 欧美日韩久久不卡| 亚洲成人精品影院| 中文字幕av不卡| 欧美videossexotv100| 日本高清不卡在线观看| 国产精品一区在线| 日本亚洲最大的色成网站www| 国产精品剧情在线亚洲| 欧美精品一区二| 日韩免费一区二区三区在线播放| 91老司机福利 在线| 国产成人精品影院| 精品一区二区成人精品| 日韩极品在线观看| 午夜欧美一区二区三区在线播放| 综合久久一区二区三区| 国产精品另类一区| 日本一区免费视频| 中文字幕国产一区二区| 久久亚洲一区二区三区四区| 91.成人天堂一区| 欧美日韩成人一区二区| 欧美在线观看视频一区二区三区| 成人av在线资源网站| 国产精品亚洲综合一区在线观看| 麻豆91在线看| 精品亚洲成a人在线观看| 美女国产一区二区| 免费av成人在线| 麻豆成人久久精品二区三区红| 日本va欧美va瓶| 精品系列免费在线观看| 国产麻豆精品视频| 不卡视频一二三| 97se亚洲国产综合自在线不卡| 91麻豆蜜桃一区二区三区| 色综合久久久久| 在线免费不卡电影| 制服丝袜一区二区三区| 日韩一区二区三区免费看| 精品毛片乱码1区2区3区| 精品国产成人系列| 国产精品乱码一区二区三区软件| 亚洲色图色小说| 亚洲成人一区二区| 日韩在线卡一卡二| 国产一区二区不卡老阿姨| 丁香六月综合激情| 色诱视频网站一区| 91精品婷婷国产综合久久| 亚洲精品在线一区二区| 欧美国产欧美综合| 艳妇臀荡乳欲伦亚洲一区| 水野朝阳av一区二区三区| 国产一区 二区| 99国产精品久久久久| 欧美人妇做爰xxxⅹ性高电影| 日韩欧美国产综合一区| 中文字幕佐山爱一区二区免费| 一区二区三区国产豹纹内裤在线| 亚洲综合色成人| 紧缚奴在线一区二区三区| 99久久久久免费精品国产 | 亚洲视频1区2区| 日日夜夜精品视频天天综合网| 久久精品国内一区二区三区| 成人午夜在线免费| 欧美日韩精品系列| 国产日韩v精品一区二区| 亚洲黄色小说网站| 国产一区二区视频在线播放| 日本韩国视频一区二区| 精品日本一线二线三线不卡| 最新不卡av在线| 精品亚洲成a人在线观看| 欧美亚州韩日在线看免费版国语版| 欧美sm美女调教| 亚洲午夜久久久久久久久电影院| 国产精品综合二区| 欧美高清精品3d| 亚洲欧美另类在线| 国产乱码精品1区2区3区| 欧美久久久久久久久中文字幕| 国产欧美va欧美不卡在线| 日韩成人免费在线| 色婷婷av久久久久久久| 欧美激情艳妇裸体舞| 天天影视涩香欲综合网| 97国产精品videossex| 国产午夜精品在线观看| 麻豆一区二区三| 欧美日韩aaa| 亚洲乱码国产乱码精品精小说 | 国产精品成人免费精品自在线观看| 日本不卡视频在线| 欧美三级在线播放| 1区2区3区欧美| 粉嫩欧美一区二区三区高清影视| 日韩欧美一区在线| 亚洲国产精品一区二区www在线| 99re热这里只有精品视频| 国产天堂亚洲国产碰碰| 精品一区二区三区在线播放| 69p69国产精品| 日韩高清不卡一区二区三区| 欧美亚洲一区三区| 一区二区三区日韩在线观看| 99在线精品观看| 中文字幕在线不卡视频| 高清不卡在线观看| 国产精品欧美久久久久一区二区| 激情综合色综合久久| 精品久久久影院| 国产一区二区三区在线观看免费视频|