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

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

?? mem_interface_top_ddr_controller_0.txt

?? 該項對于設計DDSRAM有很大的幫助
?? TXT
?? 第 1 頁 / 共 4 頁
字號:
           if ( (rfc_count == 6'b00001) && (conflict_detect_r) )begin
              next_state = ACTIVE;
           end else if (rfc_count == 6'b00001) begin
              next_state = IDLE;
           end else begin
              next_state = AUTO_REFRESH_WAIT;
           end
        end

        ACTIVE             : next_state = ACTIVE_WAIT;

        ACTIVE_WAIT        : begin
             if (rcd_count == 3'b000) begin
                if(WR)
                  next_state = FIRST_WRITE;
                else if (RD)
                  next_state = FIRST_READ;
                else
                  next_state = IDLE;
             end
             else
               next_state = ACTIVE_WAIT;
        end // case: `active_wait

        FIRST_WRITE  : begin
           if(((conflict_detect & (~conflict_resolved_r))|| auto_ref) || RD)
             next_state = WRITE_WAIT;
           else if((burst_cnt == 3'd1) && WR)
             next_state = BURST_WRITE;
           else
             next_state = WRITE_WAIT;
        end

        BURST_WRITE : begin
           if(((conflict_detect & (~conflict_resolved_r))|| auto_ref) || RD)
             next_state = WRITE_WAIT;
           else if((burst_cnt == 3'd1) && WR)
             next_state = BURST_WRITE;
           else
             next_state = WRITE_WAIT;
        end

        WRITE_WAIT          : begin
           if ((conflict_detect & (~conflict_resolved_r))|| auto_ref)  begin
              if ((wtp_count == 4'b0000) && (ras_count == 4'b0000))
                next_state = PRECHARGE;
              else
                next_state = WRITE_WAIT;
           end else if (RD ) begin
              next_state = WRITE_READ;
           end else if ((WR) && (wrburst_cnt == 3'b010)) begin
              next_state = BURST_WRITE;
           end else if((WR) && (wrburst_cnt == 3'b000)) begin 
              next_state = FIRST_WRITE;
           end else if (idle_cnt == 4'b0000) begin
              next_state = PRECHARGE;
           end else begin
              next_state = WRITE_WAIT;
           end
        end

        WRITE_READ         : begin
             if (wr_to_rd_count == 4'b0000) begin
                next_state = FIRST_READ;
             end else begin
                next_state = WRITE_READ;
             end
        end

        FIRST_READ  :begin
           if(((conflict_detect & (~conflict_resolved_r))|| auto_ref) || WR)
             next_state = READ_WAIT;
           else if((burst_cnt == 3'd1) && RD)
             next_state = BURST_READ;
           else
             next_state = READ_WAIT;
        end

        BURST_READ :begin
           if(((conflict_detect & (~conflict_resolved_r))|| auto_ref) || WR)
             next_state = READ_WAIT;
           else if((burst_cnt == 3'd1) && RD)
             next_state = BURST_READ;
           else
             next_state = READ_WAIT;
        end


        READ_WAIT          : begin
           if ((conflict_detect & (~conflict_resolved_r)) || auto_ref) begin
              if(rtp_count == 4'b0000 && ras_count == 4'b0000)
                next_state = PRECHARGE;
              else
                next_state = READ_WAIT;
           end else if (WR) begin
              next_state = READ_WRITE;
           end else if ((RD) && (read_burst_cnt <= 3'b010)) begin
              if(af_empty_r)
                next_state = FIRST_READ;
              else
                next_state = BURST_READ;
           end else if (idle_cnt == 4'b0000) begin
              next_state = PRECHARGE;
           end else begin
              next_state = READ_WAIT;
           end
        end

        READ_WRITE          : begin
           if (rd_to_wr_count == 4'b0000) begin
              next_state = FIRST_WRITE;
           end else begin
              next_state = READ_WRITE;
           end
        end

      endcase
   end


   //register command outputs
   always @ (posedge clk_0) begin
      if (rst_r) begin
         state_r2 <= 5'b00000;
         state_r3 <= 5'b00000;
      end
      else begin
         state_r2 <= state;
         state_r3 <= state_r2;
      end
   end

   always @ (posedge clk_0) begin
      if (rst_r) begin
         init_state_r2 <= 5'b00000;
         init_state_r3 <= 5'b00000;
      end
      else begin
         init_state_r2 <= init_state;
         init_state_r3 <= init_state_r2;
      end
   end

   // commands to the memory
   always @ (posedge clk_0) begin
      if (rst_r) begin
         ddr_ras_r <= 1'b1;
      end
      else if (state == LOAD_MODE_REG_ST || state == PRECHARGE || state ==ACTIVE
               || state == AUTO_REFRESH || init_state==INIT_LOAD_MODE_REG_ST ||
               init_state == INIT_PRECHARGE || init_state == INIT_AUTO_REFRESH
               || init_state == INIT_DUMMY_ACTIVE) begin
         ddr_ras_r <= 1'b0;
      end
      else ddr_ras_r <= 1'b1;
   end

   // commands to the memory
   always @ (posedge clk_0) begin
      if (rst_r)
        ddr_cas_r <= 1'b1;
      else if (state == LOAD_MODE_REG_ST || init_state == INIT_LOAD_MODE_REG_ST
               || read_write_state || init_state == INIT_DUMMY_FIRST_READ ||
               dummy_write_state || state==AUTO_REFRESH ||
               init_state == INIT_AUTO_REFRESH || init_state== INIT_DUMMY_READ
               || pattern_read_state)
        ddr_cas_r <= 1'b0;
      else if ((state == ACTIVE_WAIT)  || (init_state == INIT_DUMMY_ACTIVE_WAIT))
        ddr_cas_r <= 1'b1;
      else
        ddr_cas_r <= 1'b1;
   end // always @ (posedge clk_0)

   // commands to the memory
   always @ (posedge clk_0) begin
      if (rst_r)
        ddr_we_r <= 1'b1;
      else if (state == LOAD_MODE_REG_ST || state == PRECHARGE ||
               init_state==INIT_LOAD_MODE_REG_ST || init_state==INIT_PRECHARGE ||
               write_state || dummy_write_state)
        ddr_we_r <= 1'b0;
      else
        ddr_we_r <= 1'b1;
   end

   //register commands to the memory
   always @ (posedge clk_0) begin
      if (rst_r) begin
         ddr_ras_r2 <= 1'b1;
         ddr_cas_r2 <= 1'b1;
         ddr_we_r2 <= 1'b1;
      end
      else begin
         ddr_ras_r2  <= ddr_ras_r;
         ddr_cas_r2  <= ddr_cas_r;
         ddr_we_r2   <= ddr_we_r;
      end
   end

   //register commands to the memory
   always @ (posedge clk_0) begin
      if (rst_r)
        begin
           ddr_ras_r3 <= 1'b1;
           ddr_cas_r3 <= 1'b1;
           ddr_we_r3  <= 1'b1;
        end
      else begin
         ddr_ras_r3  <= ddr_ras_r2;
         ddr_cas_r3  <= ddr_cas_r2;
         ddr_we_r3   <= ddr_we_r2;
      end // else: !if(rst_r)
   end // always @ (posedge clk_0)


   always @ (posedge clk_0) begin
      if (rst_r)
        row_addr_r[`row_address-1:0] <= `row_address'h0;
      else
        row_addr_r[`row_address-1:0] <= af_addr[(`row_address + `col_ap_width)-1
                                                :`col_ap_width];
   end

   // chip enable generation logic
   always @ (posedge clk_0) begin
      if (rst_r)
        ddr_cs_r[`no_of_cs-1 : 0] <=  `no_of_cs'h0;
      else begin
         if (af_addr_r[`chip_address + `bank_address +`row_address+
                       `col_ap_width-1:`bank_address+`row_address+`col_ap_width]
             == `chip_address'h0) begin
            ddr_cs_r[`no_of_cs-1 : 0] <= `no_of_cs'hE;
         end  else if (af_addr_r[`chip_address + `bank_address +`row_address +
                                 `col_ap_width-1:`bank_address +`row_address +
                                 `col_ap_width] == `chip_address'h1) begin
            ddr_cs_r[`no_of_cs-1 : 0] <= `no_of_cs'hD;
         end else if (af_addr_r[`chip_address + `bank_address +`row_address +
                                `col_ap_width-1:`bank_address +`row_address +
                                `col_ap_width] == `chip_address'h2) begin
            ddr_cs_r[`no_of_cs-1 : 0] <= `no_of_cs'hB;
         end else if (af_addr_r[`chip_address + `bank_address +`row_address +
                                `col_ap_width-1:`bank_address +`row_address +
                                `col_ap_width] == `chip_address'h3) begin
            ddr_cs_r[`no_of_cs-1 : 0] <= `no_of_cs'h7;
         end else
           ddr_cs_r[`no_of_cs-1 : 0] <= `no_of_cs'hF;
      end // else: !if(rst_r)
   end // always@ (posedge clk_0)

   // address during init
   always @ (posedge clk_0) begin
      if (rst_r)
        ddr_address_init_r <= `row_address'h0000;
      else if (init_memory) begin
         if (init_state_r2 == INIT_PRECHARGE)
            ddr_address_init_r <= `row_address'h0400; //A10= 1 for precharge all
         else if ( init_state_r2 == INIT_LOAD_MODE_REG_ST && init_count_cp == 4'h3)
           ddr_address_init_r <= ext_mode_reg;       // A0 == 0 for DLL enable
         else if ( init_state_r2 == INIT_LOAD_MODE_REG_ST && init_count_cp == 4'h4 )
           ddr_address_init_r <= (`row_address'h0100 | load_mode_reg);// A8 == 1
                                                                  //for DLL reset
         else if ( init_state_r2 == INIT_LOAD_MODE_REG_ST && init_count_cp == 4'h9 )
           ddr_address_init_r <= (`row_address'hFEFF & load_mode_reg);// A8 = 0
                                              //for DLL reset bit to deactivate
         else
           ddr_address_init_r <= `row_address'h0000;
      end
   end // always @ (posedge clk_0)

   always @ (posedge clk_0) begin
      if (rst_r)
        ddr_address_r1 <= `row_address'h0000;
      else if ((init_state_r2 == INIT_DUMMY_WRITE1) ||
               (init_state_r2 == INIT_PATTERN_READ1))
        ddr_address_r1 <= `row_address'h0000;
      else if ((init_state_r2 == INIT_DUMMY_WRITE2) ||
                (init_state_r2 == INIT_PATTERN_READ2))
        ddr_address_r1 <= ddr_address_BL;
      else if ((state_r2 == ACTIVE))
        ddr_address_r1 <= row_addr_r;
      else if (read_write_state_r2)
        ddr_address_r1 <=  af_addr_r[`row_address-1 :0] & `row_address'hFBFF;
                                        // Auto Precharge option is disabled
      else if (state_r2 == PRECHARGE || init_state_r2 == INIT_PRECHARGE) begin
           ddr_address_r1 <= `row_address'h0400;
      end
      else if (state_r2 == LOAD_MODE_REG_ST ||
               init_state_r2 == INIT_LOAD_MODE_REG_ST)
        ddr_address_r1 <= af_addr_r[`row_address-1:0];
      else ddr_address_r1 <=  `row_address'h0000;
   end // always @ (posedge clk_0)

   always @ (posedge clk_0) begin
      if (rst_r)
        ddr_address_r2 <= `row_address'h0000;
      else
        begin
           if(init_memory)
             ddr_address_r2 <= ddr_address_init_r;
           else
             ddr_address_r2 <= ddr_address_r1;
        end
   end

   always @ (posedge clk_0) begin
      if (rst_r) begin
         ddr_ba_r1[`bank_address-1:0] <= `bank_address'h0;
      end
      else if (init_memory == 1'b1 && (state_r2 == LOAD_MODE_REG_ST ||
                                init_state_r2 == INIT_LOAD_MODE_REG_ST)) begin
         if (init_count_cp == 4'h3)
           ddr_ba_r1[`bank_address-1:0] <= `bank_address'h1;
         else ddr_ba_r1[`bank_address-1:0] <= `bank_address'h0;
      end else if ((state_r2 == ACTIVE)|| (init_state_r2 == INIT_DUMMY_ACTIVE)
                   || (state_r2==LOAD_MODE_REG_ST) ||
                   (init_state_r2==INIT_LOAD_MODE_REG_ST) ||
                   ((state_r2==PRECHARGE) || (init_state_r2 == INIT_PRECHARGE)
                    & PRE_r))
        ddr_ba_r1[`bank_address-1:0] <= af_addr[(`bank_address+`row_address +
                         `col_ap_width)-1:(`col_ap_width + `row_address)];
      else ddr_ba_r1[`bank_address-1:0] <= ddr_ba_r1[`bank_address-1:0];
   end

   always @ (posedge clk_0) begin
      if (rst_r)
        ddr_ba_r2 <= `bank_address'h0;
      else
        ddr_ba_r2 <= ddr_ba_r1;
   end

   always @ (posedge clk_0) begin
      if (rst_r)
        ddr_cs_r1[`no_of_cs-1:0]    <= `no_of_cs'h0;
      else if (init_memory == 1'b1 ) begin
         if (chip_cnt == 2'h0)
           ddr_cs_r1[`no_of_cs-1:0] <= `no_of_cs'hE;
         else if (chip_cnt == 2'h1)
           ddr_cs_r1[`no_of_cs-1:0] <= `no_of_cs'hD;
         else if (chip_cnt == 2'h2)
           ddr_cs_r1[`no_of_cs-1:0] <= `no_of_cs'hB;
         else if (chip_cnt == 2'h3)
           ddr_cs_r1[`no_of_cs-1:0] <= `no_of_cs'h7;
         else
           ddr_cs_r1[`no_of_cs-1:0] <= `no_of_cs'hF;
      end
      else if ((state_r3 == AUTO_REFRESH ) || (init_state_r3 == INIT_AUTO_REFRESH ))
        ddr_cs_r1[`no_of_cs-1:0] <=    `no_of_cs'h0;
      else if ((state_r3 == ACTIVE )||(init_state_r3 == INIT_DUMMY_ACTIVE)||
               (state_r3==LOAD_MODE_REG_ST) ||
               (init_state_r3==INIT_LOAD_MODE_REG_ST)
               ||(state_r3 == PRECHARGE_WAIT) ||
               (init_state_r3 == INIT_PRECHARGE_WAIT))
        ddr_cs_r1[`no_of_cs-1:0] <= ddr_cs_r[`no_of_cs-1:0];
      else
        ddr_cs_r1[`no_of_cs-1:0] <= ddr_cs_r1[`no_of_cs-1:0];
   end // always @ (posedge clk_0)

   always @ (posedge clk_0) begin
      if (rst_r)
        conflict_resolved_r <= 1'b0;
      else begin
         if (((state == PRECHARGE_WAIT) || (init_state == INIT_PRECHARGE_WAIT))
             & conflict_detect_r)
           conflict_resolved_r  <= 1'b1;
         else if(af_rden)
           conflict_resolved_r  <= 1'b0;
      end
   end

   always @ (posedge clk_0) begin
      if (rst_r)
        ddr_cke_r<= `cke_width'h0;
      else begin
         if(done_200us == 1'b1)
           ddr_cke_r<= `cke_width'hF;
      end
   end

   assign ctrl_ddr_address[`row_address-1:0]  = ddr_address_r2[`row_address-1:0];
   assign ctrl_ddr_ba [`bank_address-1:0]     = ddr_ba_r2[`bank_address-1:0];
   assign ctrl_ddr_ras_L = ddr_ras_r3;
   assign ctrl_ddr_cas_L = ddr_cas_r3;
   assign ctrl_ddr_we_L  = ddr_we_r3;
   assign ctrl_ddr_cs_L = 2'b00;
   assign ctrl_ddr_cke  = ddr_cke_r;

endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
丝袜亚洲另类欧美| 中文字幕av在线一区二区三区| 日韩视频免费直播| 国产精品久久久99| 日韩成人精品在线观看| 99综合影院在线| 欧美一区二区久久久| 亚洲三级小视频| 韩国女主播一区| 精品1区2区3区| 国产精品乱码一区二区三区软件 | eeuss影院一区二区三区| 欧美一卡2卡3卡4卡| 综合久久久久久| 国产成a人无v码亚洲福利| 欧美精品国产精品| 亚洲精品你懂的| 波多野结衣在线aⅴ中文字幕不卡| 日韩精品中文字幕一区二区三区| 亚洲一区二区在线观看视频| 成人精品鲁一区一区二区| 欧美xxxxxxxx| 美女一区二区视频| 在线电影欧美成精品| 亚洲福利电影网| 欧美在线你懂的| 亚洲精品视频在线| 色狠狠桃花综合| 亚洲欧美日韩国产一区二区三区| 不卡一卡二卡三乱码免费网站| 亚洲精品一区二区三区精华液| 蜜臀av一区二区三区| 宅男在线国产精品| 日韩精品久久理论片| 欧美日韩精品一区二区三区蜜桃| 91福利在线导航| 色婷婷av一区二区三区大白胸| 911精品国产一区二区在线| **欧美大码日韩| 成人av在线播放网址| 欧美韩国一区二区| 国产成人免费视| 中文字幕乱码久久午夜不卡| 成人av免费在线观看| 国产精品久久久久久久裸模| 白白色 亚洲乱淫| 亚洲女人****多毛耸耸8| 91丨九色丨黑人外教| 亚洲精品菠萝久久久久久久| 在线观看不卡一区| 日韩电影在线免费| 日韩欧美在线一区二区三区| 国产在线观看免费一区| 亚洲色图.com| 成人综合在线观看| 久久九九99视频| 国产一区二区中文字幕| 久久久久久久久久久久久久久99 | 欧美性xxxxx极品少妇| 亚洲一区影音先锋| 日韩欧美国产精品一区| 国产大陆精品国产| 亚洲人成在线播放网站岛国| 欧美麻豆精品久久久久久| 99精品国产一区二区三区不卡| 一区二区三区四区不卡在线| av激情成人网| 亚洲人成小说网站色在线 | 日韩一区二区免费在线观看| 国产日本欧美一区二区| 丁香亚洲综合激情啪啪综合| 亚洲综合色噜噜狠狠| 日韩片之四级片| 91麻豆国产福利在线观看| 石原莉奈在线亚洲三区| 精品久久久久香蕉网| 日韩欧美一级在线播放| 天天影视涩香欲综合网 | 欧美日本在线视频| 精品一区二区影视| 亚洲女女做受ⅹxx高潮| 2021国产精品久久精品| 色网站国产精品| 精品在线一区二区| 亚洲国产精品一区二区久久| 久久久国产一区二区三区四区小说| 91社区在线播放| 免费在线欧美视频| 亚洲另类在线一区| 国产亚洲成年网址在线观看| 欧美电影影音先锋| 91美女在线视频| 国产一区在线观看视频| 日产精品久久久久久久性色| 国产三级三级三级精品8ⅰ区| 欧美日韩高清一区二区| 一本一道久久a久久精品| 国产精品一线二线三线| 美国av一区二区| 午夜欧美电影在线观看| 亚洲蜜桃精久久久久久久| 久久人人97超碰com| 欧美一级二级在线观看| 欧美日韩在线一区二区| 91黄色激情网站| 91在线免费视频观看| 成人午夜在线播放| 国产精品91一区二区| 精品系列免费在线观看| 免费不卡在线视频| 天天操天天色综合| 亚洲成人资源在线| 亚洲一二三四区| 亚洲激情在线激情| 中文字幕一区不卡| 国产精品麻豆99久久久久久| 国产日韩欧美精品一区| 国产婷婷色一区二区三区在线| 亚洲精品在线观看视频| 精品久久久三级丝袜| 国产区在线观看成人精品| 久久久精品中文字幕麻豆发布| 久久久久久久久97黄色工厂| 成+人+亚洲+综合天堂| 亚洲综合免费观看高清完整版在线| 亚洲国产成人午夜在线一区| 久久久久久免费| 国产亚洲欧美在线| 国产精品久久久久久久第一福利| 久久久久亚洲蜜桃| 国产精品久久久久久福利一牛影视| 亚洲色图19p| 国产亚洲美州欧州综合国| 91久久国产最好的精华液| 一区二区三区久久久| 亚洲久本草在线中文字幕| 亚洲美女屁股眼交| 国产丶欧美丶日本不卡视频| 久久99精品久久久久久动态图| 成人在线一区二区三区| 成人免费精品视频| 在线免费观看视频一区| 夜夜嗨av一区二区三区| 国产精品乱人伦| 亚洲精品视频在线| 日韩精品亚洲一区二区三区免费| 亚欧色一区w666天堂| 日韩国产欧美在线播放| 欧美男女性生活在线直播观看| 国产一区二区成人久久免费影院 | 3751色影院一区二区三区| 欧美色精品在线视频| 粉嫩av一区二区三区粉嫩| 免费看欧美女人艹b| 久久综合综合久久综合| 夜夜精品视频一区二区| 国产精品自在欧美一区| 久久99久久久久| 亚洲国产精品人人做人人爽| 国产日韩av一区二区| 欧美一区二区免费视频| 欧美喷水一区二区| 91福利在线看| 久久综合五月天婷婷伊人| 欧美国产精品一区二区三区| 夜夜夜精品看看| 欧美a级一区二区| www.日韩av| 国产无人区一区二区三区| 国产日韩欧美激情| 日韩一级欧美一级| 轻轻草成人在线| 日韩精品一区二区在线观看| 欧美精品一区二区在线观看| 国产精品美日韩| 蜜臀av性久久久久蜜臀aⅴ流畅| 成人高清在线视频| 欧美一区二区三区的| 综合色天天鬼久久鬼色| 国内精品在线播放| 欧美日韩免费视频| 亚洲欧美另类图片小说| 久久国产福利国产秒拍| 成人短视频下载| 精品免费99久久| 午夜精品一区在线观看| 一本久久精品一区二区| 国产丝袜欧美中文另类| 精品一区二区精品| 欧美一级精品在线| 日韩一区欧美二区| 在线视频国产一区| 国产精品久久久久久妇女6080| 久久精品99国产精品日本| 欧美久久一区二区| 亚洲国产cao| 欧美剧情片在线观看| 久久精品一区二区三区不卡牛牛| 99久久精品免费看国产免费软件| av一区二区不卡|