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

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

?? ddr_sdram_auk_ddr_dqs_group.v

?? MagicSopc DDR-Sdram
?? V
?? 第 1 頁 / 共 3 頁
字號:
//Legal Notice: (C)2006 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

// turn off superfluous verilog processor warnings 
// altera message_level Level1 
// altera message_off 10034 10035 10036 10037 10230 10240 10030 

//------------------------------------------------------------------------------
//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
                                   )
  /* synthesis ALTERA_ATTRIBUTE = "SUPPRESS_DA_RULE_INTERNAL=C101;SUPPRESS_DA_RULE_INTERNAL=C105;SUPPRESS_DA_RULE_INTERNAL=C106;SUPPRESS_DA_RULE_INTERNAL=R104;SUPPRESS_DA_RULE_INTERNAL=A102;SUPPRESS_DA_RULE_INTERNAL=A103;SUPPRESS_DA_RULE_INTERNAL=C104;SUPPRESS_DA_RULE_INTERNAL=D101;SUPPRESS_DA_RULE_INTERNAL=D102;SUPPRESS_DA_RULE_INTERNAL=D103;SUPPRESS_DA_RULE_INTERNAL=R102;SUPPRESS_DA_RULE_INTERNAL=R105" */ ;

  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    [ 13: 0] ZEROS_14;
  wire    [  1: 0] be;
  wire    [ 15: 0] control_rdata;
  wire             ddr_dm;
  wire    [  7: 0] ddr_dq;
  wire             ddr_dqs;
  wire    [ 15: 0] delayed_dq_captured;
  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    [ 15: 0] dq_captured_0;
  wire    [ 15: 0] dq_captured_1;
  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;
  wire    [  0: 0] dqs_clk;
  wire             dqs_oe;
  reg     [  0: 0] dqs_oe_r;
  wire    [  0: 0] dqs_oe_vector;
  wire             dqs_postamble_clk;
  wire    [  0: 0] dqs_twpst_ctrl;
  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 ZEROS_14 = 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;
        end
      else 
        begin
          dqs_oe_r <= dqs_oe;
          doing_wr_r <= doing_wr;
        end
    end


  assign dqs_oe = doing_wr | dqs_burst;
  assign dqs_oe_vector = dqs_oe;
  //Gate off the DQS at the end of a write burst to improve tWPST
  assign dqs_twpst_ctrl = dqs_oe_vector & dqs_oe_r;

  //

  altddio_bidir dqs_io
    (
      .aclr (reset),
      .aset (),
      .combout (dqs_clk),
      .datain_h (dqs_twpst_ctrl),
      .datain_l (ZEROS[0]),
      .dataout_h (),
      .dataout_l (),
      .dqsundelayedout (),
      .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 = "51",
           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};
  //-----------------------------------------------------------------------------
  //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一区二区三区免费野_久草精品视频
国产综合久久久久影院| 亚洲成人综合在线| 日韩一区二区不卡| 欧美日产国产精品| 欧美日韩国产首页| 日韩三级精品电影久久久| 欧美一区二区三区在线看| 欧美午夜寂寞影院| 欧美肥大bbwbbw高潮| 欧美酷刑日本凌虐凌虐| 91精品国产一区二区| 日韩三级在线观看| 2023国产精品| 国产精品久久久一本精品| 国产精品久久777777| 亚洲视频1区2区| 婷婷开心激情综合| 狠狠色狠狠色综合| 99精品视频在线观看免费| 99久久婷婷国产综合精品| 在线观看亚洲a| 日韩视频免费直播| 欧美日韩国产综合一区二区| 日韩欧美黄色影院| 国产精品你懂的| 亚洲国产一区二区三区青草影视| 人人精品人人爱| 懂色av一区二区三区蜜臀| 欧美综合视频在线观看| 日韩免费看的电影| 欧美国产成人精品| 五月天激情综合| 粉嫩嫩av羞羞动漫久久久| 欧美中文字幕一区二区三区| 日韩女优制服丝袜电影| 中文字幕的久久| 日韩av中文字幕一区二区| 成人一区二区视频| 91精品国产福利| 国产精品国产三级国产| 免费久久99精品国产| aaa亚洲精品| 精品少妇一区二区三区免费观看| 亚洲三级在线观看| 精久久久久久久久久久| 欧美日韩日日夜夜| 国产精品久久久久久久久图文区| 日本视频中文字幕一区二区三区| 成人国产精品视频| 欧美精品一区二区三区很污很色的| 亚洲视频一二区| 国产成人夜色高潮福利影视| 678五月天丁香亚洲综合网| 最新热久久免费视频| 看国产成人h片视频| 91国模大尺度私拍在线视频| 国产精品美女一区二区三区| 毛片av一区二区| 色成人在线视频| 中文字幕 久热精品 视频在线| 久久99久久精品| 日韩亚洲国产中文字幕欧美| 亚洲一区二区免费视频| 成人精品视频.| 亚洲国产精品99久久久久久久久 | 美女在线观看视频一区二区| 色偷偷久久人人79超碰人人澡| 久久精品日产第一区二区三区高清版| 美美哒免费高清在线观看视频一区二区| 在线观看亚洲专区| 亚洲综合激情网| 日本道色综合久久| 一区二区三区在线免费播放| 色综合中文字幕| 亚洲视频网在线直播| 91免费看视频| 亚洲免费在线观看| 在线观看亚洲专区| 亚洲成av人片观看| 欧美精品三级在线观看| 日本女人一区二区三区| 555夜色666亚洲国产免| 免费在线欧美视频| 欧美v日韩v国产v| 国产乱码精品一区二区三| 久久久噜噜噜久久中文字幕色伊伊| 狠狠狠色丁香婷婷综合久久五月| 久久久亚洲精品一区二区三区 | www.欧美日韩国产在线| 国产精品丝袜一区| 91在线看国产| 午夜av一区二区| 日韩精品在线网站| 成人av综合在线| 夜夜嗨av一区二区三区网页| 欧美一区二区三区视频免费| 国产一区视频网站| 自拍偷拍国产精品| 欧美伦理电影网| 国产一区二区三区日韩| 国产精品情趣视频| 欧美人妖巨大在线| 国产精品一区二区黑丝| 亚洲欧美日韩中文字幕一区二区三区 | 欧美一区二区在线看| 国产麻豆精品在线| 一区二区成人在线视频| 91麻豆精品国产自产在线观看一区 | 国产高清一区日本| 一级女性全黄久久生活片免费| 欧美一区午夜视频在线观看| 国产成人精品影视| 图片区小说区区亚洲影院| 久久亚洲捆绑美女| 欧美日韩精品一区二区在线播放| 国产精品99久久久久久久女警| 一区二区三区不卡在线观看 | 国产成人精品在线看| 亚洲福利视频三区| 中文字幕国产一区二区| 欧美精品精品一区| 92国产精品观看| 国产在线乱码一区二区三区| 亚洲一二三四在线| 国产欧美一二三区| 日韩一区二区在线免费观看| 91色.com| 成人av综合在线| 国内精品久久久久影院薰衣草 | 99久久精品费精品国产一区二区| 蜜桃久久av一区| 亚洲综合男人的天堂| 国产欧美日本一区二区三区| 91精品国产91久久久久久一区二区| 99久久国产综合精品色伊| 国产麻豆91精品| 另类小说综合欧美亚洲| 天堂av在线一区| 亚洲综合另类小说| 亚洲最新视频在线观看| 中文字幕一区在线观看| 国产精品美女久久久久av爽李琼| 精品sm在线观看| 日韩视频123| 欧美sm美女调教| 日韩午夜电影在线观看| 91精品国产全国免费观看| 欧美人狂配大交3d怪物一区| 欧美在线制服丝袜| 欧美性极品少妇| 欧美三级午夜理伦三级中视频| 在线欧美小视频| 欧美色视频在线| 欧美福利视频导航| 欧美美女一区二区| 日韩欧美中文字幕一区| 日韩视频中午一区| 久久九九久久九九| 国产精品色在线| 一区二区三区日本| 精品国内片67194| 精品99999| 欧美三级在线视频| 免费亚洲电影在线| 日韩精品资源二区在线| 欧美高清视频一二三区 | 99久久精品情趣| 成人精品电影在线观看| 91视频一区二区| 欧美日韩在线三级| 91精品国产综合久久香蕉的特点| 日韩欧美在线不卡| 欧美激情综合五月色丁香小说| 中文在线资源观看网站视频免费不卡 | 精品国产乱码久久久久久久久| 久久日韩精品一区二区五区| 国产亚洲精品aa| 亚洲丝袜自拍清纯另类| 日韩精品一级二级| 国产成人综合在线观看| 色婷婷av一区二区三区gif| 欧美电影在线免费观看| 精品国产乱码久久久久久图片 | 白白色 亚洲乱淫| 欧美在线色视频| 精品国产一区二区国模嫣然| 国产精品久久毛片av大全日韩| 亚洲综合视频在线观看| 激情综合色播五月| 日本福利一区二区| 精品国产一区二区亚洲人成毛片 | 麻豆成人免费电影| 成人av在线观| 日韩免费一区二区| 一区二区三区四区精品在线视频| 男男视频亚洲欧美| 91福利视频网站| 国产亲近乱来精品视频| 日韩高清不卡一区二区三区| 成人动漫视频在线|