OpenCores
URL https://opencores.org/ocsvn/qaz_libs/qaz_libs/trunk

Subversion Repositories qaz_libs

[/] [qaz_libs/] [trunk/] [axi4_stream_lib/] [src/] [axis_to_memory.sv] - Rev 50

Compare with Previous | Blame | View Log

//////////////////////////////////////////////////////////////////////
////                                                              ////
//// Copyright (C) 2019 Authors and OPENCORES.ORG                 ////
////                                                              ////
//// This source file may be used and distributed without         ////
//// restriction provided that this copyright statement is not    ////
//// removed from the file and that any derivative work contains  ////
//// the original copyright notice and the associated disclaimer. ////
////                                                              ////
//// This source file is free software; you can redistribute it   ////
//// and/or modify it under the terms of the GNU Lesser General   ////
//// Public License as published by the Free Software Foundation; ////
//// either version 2.1 of the License, or (at your option) any   ////
//// later version.                                               ////
////                                                              ////
//// This source is distributed in the hope that it will be       ////
//// useful, but WITHOUT ANY WARRANTY; without even the implied   ////
//// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR      ////
//// PURPOSE.  See the GNU Lesser General Public License for more ////
//// details.                                                     ////
////                                                              ////
//// You should have received a copy of the GNU Lesser General    ////
//// Public License along with this source; if not, download it   ////
//// from http://www.opencores.org/lgpl.shtml                     ////
////                                                              ////
//////////////////////////////////////////////////////////////////////

module
  axis_to_memory
  #(
    W, // data width in bits
    A, // address width in bits
    P = 1 // pipeline delay
  )
  (
    axis_if        axis_ar,
    axis_if        axis_r,
    output         wr,
    output [A-1:0] addr,
    output [W-1:0] din,
    input  [W-1:0] dout,
    input          aclk,
    input          aresetn
  );

  // --------------------------------------------------------------------
  localparam CW = ($clog2(P) == 0) ? 1 : $clog2(P);
  localparam D = 2 ** CW;
  localparam UB = $clog2(D);

  // --------------------------------------------------------------------
  reg [P-1:0] pipeline;
  wire ar = axis_ar.tready & axis_ar.tvalid;
  wire rd_ready = pipeline[0];
  wire bypass;

  generate
    if(P > 1) begin: pipeline_gen
      always_ff @(posedge aclk)
        if(~aresetn)
          pipeline <= 0;
        else
          pipeline <= {ar, pipeline[P-1:1]};
    end
    else begin: min_pipeline_gen // P == 1
      always_ff @(posedge aclk)
        if(~aresetn)
          pipeline <= 0;
        else
          pipeline <= ar;
    end
  endgenerate

  // --------------------------------------------------------------------
  wire          wr_full;
  wire [W-1:0]  wr_data = dout;
  wire          wr_en = bypass ? 0 : rd_ready;
  wire          rd_empty;
  wire [W-1:0]  rd_data;
  wire          rd_en = axis_r.tready & axis_r.tvalid & ~bypass;
  wire [UB:0]   count;

  sync_fifo #(W, D) fifo_i(.clk(aclk), .reset(~aresetn), .*);

  // --------------------------------------------------------------------
  // assign bypass = rd_empty & (count != 0) & rd_ready;
  assign bypass = 0;

  // // --------------------------------------------------------------------
  // logic [$clog2($bits(pipeline)+1)-1:0] in_pipeline;

  // always_comb begin
    // in_pipeline = '0;

    // foreach(pipeline[idx]) begin
      // in_pipeline += pipeline[idx];
    // end
  // end

  // --------------------------------------------------------------------
  reg [$clog2($bits(pipeline)+1)-1:0] pipeline_count;
  reg [$clog2($bits(pipeline)+1)-1:0] next_pipeline_count;

  always_comb
    case({rd_ready, ar})
      2'b0_0: next_pipeline_count = pipeline_count;
      2'b0_1: next_pipeline_count = pipeline_count + 1;
      2'b1_0: next_pipeline_count = pipeline_count - 1;
      2'b1_1: next_pipeline_count = pipeline_count;
  endcase

  always_ff @(posedge aclk)
    if(~aresetn)
      pipeline_count <= 0;
    else
      pipeline_count <= next_pipeline_count;

  // --------------------------------------------------------------------
  assign axis_ar.tready = (pipeline_count + count < D) | rd_en;
  assign axis_r.tdata = bypass ? dout : rd_data;
  assign axis_r.tlast = 1;
  assign axis_r.tvalid = ~rd_empty | bypass;

  // --------------------------------------------------------------------
  assign wr = 0;
  // assign addr = axis_ar.tdata;

// --------------------------------------------------------------------
endmodule

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.