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

Subversion Repositories async_sdm_noc

[/] [async_sdm_noc/] [trunk/] [vc/] [src/] [fcctl.v] - Rev 48

Go to most recent revision | Compare with Previous | Blame | View Log

/*
 Asynchronous SDM NoC
 (C)2011 Wei Song
 Advanced Processor Technologies Group
 Computer Science, the Univ. of Manchester, UK
 
 Authors: 
 Wei Song     wsong83@gmail.com
 
 License: LGPL 3.0 or later
 
 Flow control unit.
 
 History:
 31/03/2010  Initial version. <wsong83@gmail.com>
 12/05/2010  Use MPxP crossbar. <wsong83@gmail.com>
 02/06/2011  Clean up for opensource. <wsong83@gmail.com>
 
*/
 
module fcctl ( /*AUTOARG*/
   // Outputs
   afc, ro,
   // Inputs
   credit, ri, rst
   );
   parameter VCN = 2;		// number of VCs per direction
   parameter PD = 3;		// depth of an input VC buffer
 
   input [VCN-1:0]  credit;	// credit input from the next router
   output [VCN-1:0] afc;	// ack for the credit input
   input [VCN-1:0]  ri;		// VC request from VCA
   output [VCN-1:0] ro;		// credit grant output
   input 	    rst;	// active high reset
 
   wire [PD:0][VCN-1:0] cp, cpa;
 
   genvar 		  i,j;
 
   // the credit pipeline
   generate
      for(i=0; i<PD; i++) begin: P
	 for(j=0; j<VCN; j++) begin: V
	    cpipe CP (.cia(cpa[i][j]), .co(cp[i+1][j]), .rst(rst), .ci(cp[i][j]), .coa(cpa[i+1][j]));
	 end
      end
   endgenerate
 
   // grant a credit to a VC request
   generate
      for(i=0; i<VCN; i++) begin:R
	 dc2 CR (.a(ri[i]), .d(cp[PD][i]), .q(cpa[PD][i]));
      end
   endgenerate	 
 
   assign ro = cpa[PD];
   assign cp[0] = credit;
   assign afc = cpa[0];
 
endmodule // fcctl
 
 

Go to most recent revision | 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.