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

Subversion Repositories async_sdm_noc

[/] [async_sdm_noc/] [branches/] [init/] [vc/] [tb/] [netnode.h] - Rev 60

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
 
 The SystemC module of network node including the processing element and the network interface.
 Currently the transmission FIFO is 500 frame deep.
 
 History:
 26/02/2011  Initial version. <wsong83@gmail.com>
 04/03/2011  Support VC router. <wsong83@gmail.com>
 05/06/2011  Clean up for opensource. <wsong83@gmail.com>
 
*/
 
#ifndef NETNODE_H_
#define NETNODE_H_
 
#include "define.h"
#include <systemc.h>
#include "ni.h"
#include "procelem.h"
#include "rtdriver.h"
 
class NetNode : public sc_module {
 public:
  RTDriver * LIOD; /* driving and convert I/O to/from router local port */
  Network_Adapter * NI;		/* network interface */
  ProcElem  * PE;		/* processor element */
 
  // signals for router
  sc_out<   sc_logic >         doa ;
  sc_out<   sc_lv<SubChN > >   doc ;
  sc_in<    sc_lv<ChBW*4 > >   do0 ;
  sc_in<    sc_lv<ChBW*4 > >   do1 ;
  sc_in<    sc_lv<ChBW*4 > >   do2 ;
  sc_in<    sc_lv<ChBW*4 > >   do3 ;
  sc_in<    sc_lv<3> >         doft;
  sc_in<    sc_lv<SubChN > >   dovc;
  sc_in<    sc_lv<SubChN > >   doca;
  sc_in<    sc_logic >         dia;
  sc_in<    sc_lv<SubChN > >   dic;
  sc_out<   sc_lv<ChBW*4 > >   di0;
  sc_out<   sc_lv<ChBW*4 > >   di1;
  sc_out<   sc_lv<ChBW*4 > >   di2;
  sc_out<   sc_lv<ChBW*4 > >   di3;
  sc_out<   sc_lv<3> >         dift;
  sc_out<   sc_lv<SubChN > >   divc;
  sc_out<   sc_lv<SubChN > >   dica;
 
  sc_in<sc_logic >         rst_n; /* global active-low reset */
 
  // signals between IOD and NI
  sc_fifo<pdu_flit<ChBW> > *   NI2P ; /* flit fifo, from NI to IO driver */
  sc_fifo<pdu_flit<ChBW> > *   P2NI ; /* flit fifo, from IO driver to NI */
  sc_signal<bool>              CP [SubChN]; /* credit input */
  sc_signal<bool>              CPa [SubChN]; /* credit ack */
 
  // signals between NI and FG/FS
  sc_fifo<pdu_frame<ChBW> > *   FIQ; /* the frame fifo, from PE to NI */
  sc_fifo<pdu_frame<ChBW> > *   FOQ; /* the frame fifo, from NI to PE */
  sc_signal<bool>               brst_n;	/* the reset in the SystemC modules */
 
  int x, y;			/* private local address */
 
  SC_CTOR(NetNode) 
    : doa("doa"), doc("doc"), 
    do0("do0"), do1("do1"), do2("do2"), do3("do3"), 
    doft("doft"), dovc("dovc"), doca("doca"),
    dia("dia"), dic("dic"), 
    di0("di0"), di1("di1"), di2("di2"), di3("di3"), 
    dift("dift"), divc("divc"), dica("dica"),
    rst_n("rst_n")
      {
	// dynamically get the parameters from Verilog test bench
	ncsc_get_param("x", x);
	ncsc_get_param("y", y);
 
	// initialization
	LIOD = new RTDriver("LIOD");
	NI = new Network_Adapter("NI", x, y);
	PE = new ProcElem("PE", x, y);
	NI2P = new sc_fifo<pdu_flit<ChBW> >(1);
	P2NI = new sc_fifo<pdu_flit<ChBW> >(1);
	FIQ = new sc_fifo<pdu_frame<ChBW> >(500);/* currently the fifo from PE is 500 frame deep */
	FOQ = new sc_fifo<pdu_frame<ChBW> >(1);
 
	// connections
	LIOD->NI2P(*NI2P);
	LIOD->P2NI(*P2NI);
	LIOD->rtid[0](di0);
	LIOD->rtod[0](do0);
	LIOD->rtid[1](di1);
	LIOD->rtod[1](do1);
	LIOD->rtid[2](di2);
	LIOD->rtod[2](do2);
	LIOD->rtid[3](di3);
	LIOD->rtod[3](do3);
	LIOD->rtift(dift);
	LIOD->rtivc(divc);
	LIOD->rtia(dia);
	LIOD->rtic(dic);
	LIOD->rtica(dica);
	LIOD->rtoft(doft);
	LIOD->rtovc(dovc);
	LIOD->rtoa(doa);
	LIOD->rtoc(doc);
	LIOD->rtoca(doca);
        for(unsigned int j=0; j<SubChN; j++) {
          LIOD->CP[j](CP[j]);
          LIOD->CPa[j](CPa[j]);
        }
 
	NI->frame_in(*FIQ);
	NI->frame_out(*FOQ);
	NI->IP(*P2NI);
	NI->OP(*NI2P);
	for(unsigned int j=0; j<SubChN; j++) {
	  NI->CP[j](CP[j]);
	  NI->CPa[j](CPa[j]);
	}
 
	PE->rst_n(brst_n);
	PE->Fout(*FIQ);
	PE->Fin(*FOQ);
 
	brst_n.write(false);
 
	SC_METHOD(rst_proc);
	sensitive << rst_n;
      }
 
 
  void rst_proc() {
    bool mrst_n;
    mrst_n = rst_n.read().is_01() ? rst_n.read().to_bool() : false;
    brst_n.write(mrst_n);
  }
};
 
 
#endif
 

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.