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

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

?? ddr_sdram_auk_ddr_dqs_group.v

?? 基于NIOS的CF卡應用(包括了軟件和硬件),ALTERA的IP庫中只提供了底層的硬件寄存器描述頭文件.這是個基于IP核HAL的軟件,以及相應的硬件設計示例.
?? V
?? 第 1 頁 / 共 2 頁
字號:
//Legal Notice: (C)2005 Altera Corporation. All rights reserved.  Your
//use of Altera Corporation's design tools, logic functions and other
//software and tools, and its AMPP partner logic functions, and any
//output files any of the foregoing (including device programming or
//simulation files), and any associated documentation or information are
//expressly subject to the terms and conditions of the Altera Program
//License Subscription Agreement or other applicable license agreement,
//including, without limitation, that your use is for the sole purpose
//of programming logic devices manufactured by Altera and sold by Altera
//or its authorized distributors.  Please refer to the applicable
//agreement for further details.

// synthesis translate_off
`timescale 1ps / 1ps
// synthesis translate_on
//------------------------------------------------------------------------------
//This confidential and proprietary software may be used only as authorized by
//a licensing agreement from Altera Corporation.
//(C) COPYRIGHT 2004 ALTERA CORPORATION
//ALL RIGHTS RESERVED
//The entire notice above must be reproduced on all authorized copies and any
//such reproduction must be pursuant to a licensing agreement from Altera.
//Title        : Datapath for the Altera DDR SDRAM Controller
//Project      : DDR SDRAM Controller
//File         : ddr_sdram_ddr_dqs_group.v
//Revision     : V3.2.0
//Abstract:
//This file contains the datapath for the DDR SDRAM Controller.
//------------------------------------------------------------------------------
//Parameters:
//Device Family                      : Cyclone II
//DQ_PER_DQS                         : 8
//NON-DQS MODE                       : false
//use Resynch clock                  : true
//Resynch clock edge                 : falling
//Postamble Clock Edge               : falling
//Postamble Clock Cycle              : 1
//Intermediate Resynch               : false
//Intermediate Postamble             : false
//Pipeline read Data                 : true
//Enable Postamble Logic             : true
//Postamble Regs Per DQS             : 1
//Stratix Insert DQS delay buffers   : 0
//------------------------------------------------------------------------------
module ddr_sdram_auk_ddr_dqs_group (
                                     // inputs:
                                      capture_clk,
                                      clk,
                                      control_be,
                                      control_doing_rd,
                                      control_doing_wr,
                                      control_dqs_burst,
                                      control_wdata,
                                      control_wdata_valid,
                                      postamble_clk,
                                      reset_n,
                                      resynch_clk,
                                      write_clk,

                                     // outputs:
                                      control_rdata,
                                      ddr_dm,
                                      ddr_dq,
                                      ddr_dqs
                                   );

  parameter gINTER_RESYNCH = "false";
  parameter gPIPELINE_READDATA = "true";
  parameter gPOSTAMBLE_REGS = 1;
  parameter gMEM_DQ_PER_DQS = 8;
  parameter gINTER_POSTAMBLE = "false";
  parameter gPOSTAMBLE_CYCLE = 1;


  output  [ 15: 0] control_rdata;
  output           ddr_dm;
  inout   [  7: 0] ddr_dq;
  inout            ddr_dqs;
  input            capture_clk;
  input            clk;
  input   [  1: 0] control_be;
  input            control_doing_rd;
  input            control_doing_wr;
  input            control_dqs_burst;
  input   [ 15: 0] control_wdata;
  input            control_wdata_valid;
  input            postamble_clk;
  input            reset_n;
  input            resynch_clk;
  input            write_clk;

  wire             ZERO;
  wire    [  7: 0] ZEROS;
  wire    [  1: 0] be;
  wire    [ 15: 0] control_rdata;
  wire             ddr_dm;
  wire    [  7: 0] ddr_dq;
  wire             ddr_dqs;
  wire    [  3: 0] delayed_dqs;
  reg     [  1: 0] dm_out;
  wire             doing_rd;
  reg              doing_rd_delayed;
  reg     [  2: 0] doing_rd_pipe;
  wire             doing_wr;
  reg              doing_wr_r;
  wire             dq_capture_clk;
  wire    [  7: 0] dq_captured_falling;
  wire    [  7: 0] dq_captured_rising;
  reg     [  0: 0] dq_enable;
  reg     [  0: 0] dq_enable_reset;
  reg              dq_oe;
  wire             dqs_burst;
  reg              dqs_burst_r;
  wire    [  0: 0] dqs_clk;
  wire             dqs_oe;
  reg     [  0: 0] dqs_oe_r;
  wire             dqs_postamble_clk;
  wire    [ 15: 0] inter_rdata;
  wire    [  0: 0] not_dqs_clk;
  reg     [ 15: 0] rdata;
  wire             reset;
  reg     [ 15: 0] resynched_data;
  wire             tmp_dmout0;
  wire             tmp_dmout1;
  wire    [ 15: 0] wdata;
  reg     [ 15: 0] wdata_r;
  wire             wdata_valid;
  wire    [  0: 0] wire_dqs_clkctrl_outclk;
  //


  assign ZERO = 1'b0;
  assign ZEROS = 0;
  assign reset = ~reset_n;
  assign not_dqs_clk = ~dqs_clk;
  // rename user i/f signals, outputs
  assign control_rdata = rdata;

  // rename user i/f signals, inputs
  assign wdata = control_wdata;

  assign wdata_valid = control_wdata_valid;
  assign doing_wr = control_doing_wr;
  assign doing_rd = control_doing_rd;
  assign be = control_be;
  assign dqs_burst = control_dqs_burst;
  //-----------------------------------------------------------------------------
  //DQS pin and its logic
  //Generate the output enable for DQS from the signal that indicates we're
  //doing a write. The DQS burst signal is generated by the controller to keep
  //the DQS toggling for the required burst length.
  //-----------------------------------------------------------------------------

  always @(posedge clk or negedge reset_n)
    begin
      if (reset_n == 0)
        begin
          dqs_oe_r <= 1'b0;
          doing_wr_r <= 1'b0;
          dqs_burst_r <= 1'b0;
        end
      else 
        begin
          dqs_oe_r <= dqs_oe;
          doing_wr_r <= doing_wr;
          dqs_burst_r <= dqs_burst;
        end
    end


  assign dqs_oe = doing_wr | dqs_burst;
  //

  altddio_bidir dqs_io
    (
      .aclr (reset),
      .aset (),
      .combout (dqs_clk),
      .datain_h (dqs_oe_r),
      .datain_l (ZEROS[0]),
      .dataout_h (),
      .dataout_l (),
      .inclock (1'b1),
      .inclocken (1'b1),
      .oe (dqs_oe),
      .outclock (clk),
      .outclocken (1'b1),
      .padio (ddr_dqs)
    );

  defparam dqs_io.extend_oe_disable = "ON",
           dqs_io.implement_input_in_lcell = "UNUSED",
           dqs_io.intended_device_family = "Cyclone II",
           dqs_io.invert_output = "OFF",
           dqs_io.lpm_hint = "UNUSED",
           dqs_io.lpm_type = "altddio_bidir",
           dqs_io.oe_reg = "REGISTERED",
           dqs_io.power_up_high = "OFF",
           dqs_io.width = 1;

  cycloneii_clk_delay_ctrl dqs_delay_ctrl
    (
      .clk (dqs_clk),
      .clkout (delayed_dqs[0])
    );

  defparam dqs_delay_ctrl.delay_chain = "47",
           dqs_delay_ctrl.delay_chain_mode = "static",
           dqs_delay_ctrl.lpm_type = "cycloneii_clk_delay_ctrl";

  assign delayed_dqs[3 : 1] = {1'b0,1'b0,1'b0};
  cycloneii_clkctrl dqs_clkctrl
    (
      .clkselect (2'b00),
      .ena (dq_enable),
      .inclk (delayed_dqs),
      .outclk (wire_dqs_clkctrl_outclk)
    );

  defparam dqs_clkctrl.ena_register_mode = "none",
           dqs_clkctrl.lpm_type = "cycloneii_clkctrl";

  //-----------------------------------------------------------------------------
  //DM pins and their logic
  //Although these don't get tristated like DQ, they do share the same IO timing.
  //-----------------------------------------------------------------------------
  assign tmp_dmout0 = dm_out[0];
  assign tmp_dmout1 = dm_out[1];
  altddio_out dm_pin
    (
      .aclr (reset),
      .aset (),
      .datain_h (tmp_dmout0),
      .datain_l (tmp_dmout1),
      .dataout (ddr_dm),
      .oe (1'b1),
      .outclock (write_clk),
      .outclocken (1'b1)
    );

  defparam dm_pin.extend_oe_disable = "UNUSED",
           dm_pin.intended_device_family = "Cyclone II",
           dm_pin.invert_output = "OFF",
           dm_pin.lpm_hint = "UNUSED",
           dm_pin.lpm_type = "altddio_out",
           dm_pin.oe_reg = "UNUSED",
           dm_pin.power_up_high = "OFF",
           dm_pin.width = 1;

  //-----------------------------------------------------------------------------
  //Data mask registers
  //These are the last registers before the registers in the altddio_out. They
  //are clocked off the system clock but feed registers which are clocked off the
  //write clock, so their output is the beginning of 3/4 cycle path.
  //-----------------------------------------------------------------------------
  always @(posedge clk or negedge reset_n)
    begin
      if (reset_n == 0)
          dm_out <= {2{1'b1}};
      else if (doing_wr)
          // don't latch in data unless it's valid
          dm_out <= ~be;

      else 
        dm_out <= {2{1'b1}};
    end


  //-----------------------------------------------------------------------------
  //Logic to disable the capture registers (particularly during DQS postamble)
  //The output of the dq_enable_reset register holds the dq_enable register in
  //reset (which *enables* the dq capture registers). The controller releases
  //the dq_enable register so that it is clocked by the last falling edge of the
  //read dqs signal. This disables the dq capture registers during and after the
  //dqs postamble so that the output of the dq capture registers can be safely
  //resynchronised.
  //Postamble Clock Cycle  : 1
  //Postamble Clock Edge   : falling
  //Postamble Regs Per DQS : 1
  //-----------------------------------------------------------------------------

  //Critical registers clocked on the falling edge of the DQS to
  //disable the DQ capture registers during the DQS postamble
  always @(posedge dqs_postamble_clk or posedge dq_enable_reset)
    begin
      if (dq_enable_reset == 1)
          dq_enable <= 1'b1;
      else 
        dq_enable <= 1'b0;
    end


  //Use a falling edge for postamble
  //The registers which generate the reset signal to the above registers
  //Can be clocked off the resynch or system clock
  always @(negedge postamble_clk or negedge reset_n)
    begin
      if (reset_n == 0)
          dq_enable_reset <= 1'b0;
      else 
        dq_enable_reset <= doing_rd_delayed;
    end


  //pipeline the doing_rd signal to enable and disable the DQ capture regs at the right time
  always @(posedge clk or negedge reset_n)
    begin
      if (reset_n == 0)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲第一二三四区| 99精品久久只有精品| 欧美日本国产视频| 亚洲综合激情另类小说区| 在线免费观看日本欧美| 一区二区不卡在线视频 午夜欧美不卡在| 成人三级伦理片| 亚洲女女做受ⅹxx高潮| 欧美性猛交xxxxxxxx| 婷婷夜色潮精品综合在线| 日韩三级中文字幕| 国产传媒欧美日韩成人| 国产精品夫妻自拍| 欧美视频你懂的| 经典三级在线一区| 亚洲欧洲一区二区三区| 欧美日韩的一区二区| 久久国产麻豆精品| 国产精品久久久久久久第一福利| 91亚洲精华国产精华精华液| 午夜久久久久久久久| 久久天天做天天爱综合色| 99国产精品视频免费观看| 午夜精品久久久久久不卡8050| 欧美一区二区日韩一区二区| 国产不卡视频在线播放| 亚洲图片欧美视频| 久久久久国产精品麻豆ai换脸| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 丝袜美腿亚洲一区二区图片| 欧美va亚洲va香蕉在线| 99麻豆久久久国产精品免费优播| 亚洲国产日韩一级| 久久久综合九色合综国产精品| 一本久道中文字幕精品亚洲嫩| 日本视频免费一区| 国产精品乱码久久久久久| 欧美日韩一区二区在线观看| 国产精品1024| 亚洲成人一区在线| 国产精品九色蝌蚪自拍| 日韩视频在线一区二区| 一本一本大道香蕉久在线精品 | 久久精品99国产精品日本| 亚洲区小说区图片区qvod| 精品人伦一区二区色婷婷| 一本色道亚洲精品aⅴ| 国产一区二区三区综合| 午夜精品在线视频一区| 亚洲人成亚洲人成在线观看图片| 精品免费一区二区三区| 欧美色网站导航| 99久久精品免费观看| 狠狠色狠狠色综合| 日韩二区在线观看| 亚洲一二三专区| 中文字幕视频一区| 国产三级精品视频| 日韩精品一区在线| 欧美久久久一区| 色素色在线综合| 99国内精品久久| 波多野结衣视频一区| 国产又粗又猛又爽又黄91精品| 日韩二区在线观看| 婷婷一区二区三区| 日韩中文字幕区一区有砖一区 | 亚洲一区免费视频| 亚洲日本在线天堂| 国产精品久久久久久久久晋中| 日韩视频一区二区三区| 日韩一区二区三区免费观看| 欧美男人的天堂一二区| 欧美午夜精品理论片a级按摩| 99精品久久只有精品| heyzo一本久久综合| 丁香啪啪综合成人亚洲小说 | 亚洲丰满少妇videoshd| 一区二区三区四区在线| 亚洲私人黄色宅男| 一区二区三区欧美| 亚洲综合在线五月| 午夜伊人狠狠久久| 久久国内精品自在自线400部| 久久综合综合久久综合| 久久精品久久综合| 国产美女娇喘av呻吟久久| 国产精品一品二品| 成人综合激情网| 91麻豆免费视频| 精品视频在线免费观看| 666欧美在线视频| 精品少妇一区二区三区免费观看 | 精品一区二区三区影院在线午夜| 久久超碰97中文字幕| 国产精品资源网站| 99久久精品免费精品国产| 欧美性视频一区二区三区| 欧美日韩久久久一区| 日韩欧美激情一区| 国产视频911| 亚洲最新视频在线播放| 美女网站色91| 国v精品久久久网| 欧美亚洲一区三区| 日韩欧美在线123| 久久先锋影音av| 亚洲人成亚洲人成在线观看图片| 亚欧色一区w666天堂| 久久99久久久久| 丁香六月综合激情| 欧美精品视频www在线观看 | 欧美精品一区二区精品网| 中文字幕欧美区| 一区二区三区国产精华| 日本成人在线不卡视频| 高清视频一区二区| 欧美三级日韩在线| 国产午夜久久久久| 亚洲午夜一二三区视频| 狠狠狠色丁香婷婷综合久久五月| 99久久99久久久精品齐齐| 欧美人体做爰大胆视频| 久久嫩草精品久久久久| 亚洲精品v日韩精品| 久久成人综合网| 欧美亚洲高清一区二区三区不卡| xnxx国产精品| 亚洲午夜一区二区| av电影在线观看不卡| 日韩欧美视频在线| 一区二区三区四区乱视频| 国产一区二区视频在线播放| 欧美视频在线一区二区三区 | av在线免费不卡| 精品国产一区二区三区忘忧草| 自拍偷拍国产精品| 韩国理伦片一区二区三区在线播放| 99久久国产综合色|国产精品| www国产精品av| 亚洲成人精品影院| 91亚洲国产成人精品一区二区三| 久久综合一区二区| 日韩精品欧美成人高清一区二区| 成人av电影免费在线播放| 精品美女在线播放| 日韩精品亚洲一区| 欧美日韩激情在线| 亚洲欧美另类综合偷拍| 国产乱对白刺激视频不卡| 欧美精选一区二区| 亚洲一二三区不卡| 色一情一乱一乱一91av| 国产精品每日更新在线播放网址 | 欧美午夜精品电影| 亚洲欧美激情一区二区| 国产suv精品一区二区883| 久久久久久夜精品精品免费| 日韩电影在线免费| 欧美日韩国产精品成人| 亚洲成av人片一区二区梦乃| 91九色02白丝porn| 亚洲精品伦理在线| 色噜噜狠狠一区二区三区果冻| 日韩一区日韩二区| 99久久免费视频.com| 亚洲特黄一级片| 欧美自拍丝袜亚洲| 亚洲国产一区在线观看| 欧美三区在线观看| 亚洲在线视频网站| 欧美日韩精品一区二区在线播放 | 日韩专区一卡二卡| 日韩一级大片在线观看| 免费高清在线视频一区·| 欧美一级夜夜爽| 男女男精品视频| 日韩写真欧美这视频| 麻豆精品一区二区三区| 精品欧美乱码久久久久久1区2区| 麻豆成人久久精品二区三区小说| 欧美一区二区三区免费视频| 麻豆91免费看| 久久精品免视看| 成人精品免费网站| 亚洲美女一区二区三区| 欧美三级日韩在线| 韩国中文字幕2020精品| 国产欧美一区二区精品仙草咪| 成人激情免费视频| 一区二区欧美国产| 欧美一卡二卡在线| 懂色av中文字幕一区二区三区| 亚洲欧洲av在线| 欧美色精品天天在线观看视频| 蜜桃av一区二区在线观看| 欧美激情一区三区| 91福利国产精品| 蜜桃av一区二区在线观看| 中文字幕av一区二区三区高|