112027Sjungma@eit.uni-kl.de/*****************************************************************************
212027Sjungma@eit.uni-kl.de
312027Sjungma@eit.uni-kl.de  Licensed to Accellera Systems Initiative Inc. (Accellera) under one or
412027Sjungma@eit.uni-kl.de  more contributor license agreements.  See the NOTICE file distributed
512027Sjungma@eit.uni-kl.de  with this work for additional information regarding copyright ownership.
612027Sjungma@eit.uni-kl.de  Accellera licenses this file to you under the Apache License, Version 2.0
712027Sjungma@eit.uni-kl.de  (the "License"); you may not use this file except in compliance with the
812027Sjungma@eit.uni-kl.de  License.  You may obtain a copy of the License at
912027Sjungma@eit.uni-kl.de
1012027Sjungma@eit.uni-kl.de    http://www.apache.org/licenses/LICENSE-2.0
1112027Sjungma@eit.uni-kl.de
1212027Sjungma@eit.uni-kl.de  Unless required by applicable law or agreed to in writing, software
1312027Sjungma@eit.uni-kl.de  distributed under the License is distributed on an "AS IS" BASIS,
1412027Sjungma@eit.uni-kl.de  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
1512027Sjungma@eit.uni-kl.de  implied.  See the License for the specific language governing
1612027Sjungma@eit.uni-kl.de  permissions and limitations under the License.
1712027Sjungma@eit.uni-kl.de
1812027Sjungma@eit.uni-kl.de *****************************************************************************/
1912027Sjungma@eit.uni-kl.de
2012027Sjungma@eit.uni-kl.de#ifndef __TLM_REQ_RSP_CHANNELS_H__
2112027Sjungma@eit.uni-kl.de#define __TLM_REQ_RSP_CHANNELS_H__
2212027Sjungma@eit.uni-kl.de
2312027Sjungma@eit.uni-kl.de#include "tlm_core/tlm_1/tlm_req_rsp/tlm_adapters/tlm_adapters.h"
2412027Sjungma@eit.uni-kl.de#include "tlm_core/tlm_1/tlm_req_rsp/tlm_channels/tlm_fifo/tlm_fifo.h"
2512027Sjungma@eit.uni-kl.de#include "tlm_core/tlm_1/tlm_req_rsp/tlm_channels/tlm_req_rsp_channels/tlm_put_get_imp.h"
2612027Sjungma@eit.uni-kl.de
2712027Sjungma@eit.uni-kl.denamespace tlm {
2812027Sjungma@eit.uni-kl.de
2912027Sjungma@eit.uni-kl.detemplate < typename REQ , typename RSP ,
3012027Sjungma@eit.uni-kl.de     typename REQ_CHANNEL = tlm_fifo<REQ> ,
3112027Sjungma@eit.uni-kl.de     typename RSP_CHANNEL = tlm_fifo<RSP> >
3212027Sjungma@eit.uni-kl.de
3312027Sjungma@eit.uni-kl.declass tlm_req_rsp_channel : public sc_core::sc_module
3412027Sjungma@eit.uni-kl.de{
3512027Sjungma@eit.uni-kl.depublic:
3612027Sjungma@eit.uni-kl.de  // uni-directional slave interface
3712027Sjungma@eit.uni-kl.de
3812027Sjungma@eit.uni-kl.de  sc_core::sc_export< tlm_fifo_get_if< REQ > > get_request_export;
3912027Sjungma@eit.uni-kl.de  sc_core::sc_export< tlm_fifo_put_if< RSP > > put_response_export;
4012027Sjungma@eit.uni-kl.de
4112027Sjungma@eit.uni-kl.de  // uni-directional master interface
4212027Sjungma@eit.uni-kl.de
4312027Sjungma@eit.uni-kl.de  sc_core::sc_export< tlm_fifo_put_if< REQ > > put_request_export;
4412027Sjungma@eit.uni-kl.de  sc_core::sc_export< tlm_fifo_get_if< RSP > > get_response_export;
4512027Sjungma@eit.uni-kl.de
4612027Sjungma@eit.uni-kl.de  // master / slave interfaces
4712027Sjungma@eit.uni-kl.de
4812027Sjungma@eit.uni-kl.de  sc_core::sc_export< tlm_master_if< REQ , RSP > > master_export;
4912027Sjungma@eit.uni-kl.de  sc_core::sc_export< tlm_slave_if< REQ , RSP > > slave_export;
5012027Sjungma@eit.uni-kl.de
5112027Sjungma@eit.uni-kl.de
5212027Sjungma@eit.uni-kl.de  tlm_req_rsp_channel( int req_size = 1 , int rsp_size = 1 ) :
5312027Sjungma@eit.uni-kl.de    sc_core::sc_module( sc_core::sc_module_name( sc_core::sc_gen_unique_name("tlm_req_rsp_channel") ) ) ,
5412027Sjungma@eit.uni-kl.de    request_fifo( req_size ) ,
5512027Sjungma@eit.uni-kl.de    response_fifo( rsp_size ) ,
5612027Sjungma@eit.uni-kl.de    master( request_fifo , response_fifo ) ,
5712027Sjungma@eit.uni-kl.de    slave( request_fifo , response_fifo )
5812027Sjungma@eit.uni-kl.de  {
5912027Sjungma@eit.uni-kl.de
6012027Sjungma@eit.uni-kl.de    bind_exports();
6112027Sjungma@eit.uni-kl.de
6212027Sjungma@eit.uni-kl.de  }
6312027Sjungma@eit.uni-kl.de
6412027Sjungma@eit.uni-kl.de  tlm_req_rsp_channel( sc_core::sc_module_name module_name ,
6512027Sjungma@eit.uni-kl.de           int req_size = 1 , int rsp_size = 1 ) :
6612027Sjungma@eit.uni-kl.de    sc_core::sc_module( module_name  ) ,
6712027Sjungma@eit.uni-kl.de    request_fifo( req_size ) ,
6812027Sjungma@eit.uni-kl.de    response_fifo( rsp_size ) ,
6912027Sjungma@eit.uni-kl.de    master( request_fifo , response_fifo ) ,
7012027Sjungma@eit.uni-kl.de    slave( request_fifo , response_fifo )
7112027Sjungma@eit.uni-kl.de  {
7212027Sjungma@eit.uni-kl.de
7312027Sjungma@eit.uni-kl.de    bind_exports();
7412027Sjungma@eit.uni-kl.de
7512027Sjungma@eit.uni-kl.de  }
7612027Sjungma@eit.uni-kl.de
7712027Sjungma@eit.uni-kl.deprivate:
7812027Sjungma@eit.uni-kl.de  void bind_exports() {
7912027Sjungma@eit.uni-kl.de
8012027Sjungma@eit.uni-kl.de    put_request_export( request_fifo );
8112027Sjungma@eit.uni-kl.de    get_request_export( request_fifo );
8212027Sjungma@eit.uni-kl.de
8312027Sjungma@eit.uni-kl.de    put_response_export( response_fifo );
8412027Sjungma@eit.uni-kl.de    get_response_export( response_fifo );
8512027Sjungma@eit.uni-kl.de
8612027Sjungma@eit.uni-kl.de    master_export( master );
8712027Sjungma@eit.uni-kl.de    slave_export( slave );
8812027Sjungma@eit.uni-kl.de
8912027Sjungma@eit.uni-kl.de  }
9012027Sjungma@eit.uni-kl.de
9112027Sjungma@eit.uni-kl.deprotected:
9212027Sjungma@eit.uni-kl.de  REQ_CHANNEL request_fifo;
9312027Sjungma@eit.uni-kl.de  RSP_CHANNEL response_fifo;
9412027Sjungma@eit.uni-kl.de
9512027Sjungma@eit.uni-kl.de  tlm_master_imp< REQ , RSP > master;
9612027Sjungma@eit.uni-kl.de  tlm_slave_imp< REQ , RSP > slave;
9712027Sjungma@eit.uni-kl.de};
9812027Sjungma@eit.uni-kl.de
9912027Sjungma@eit.uni-kl.detemplate < typename REQ , typename RSP ,
10012027Sjungma@eit.uni-kl.de     typename REQ_CHANNEL = tlm_fifo<REQ> ,
10112027Sjungma@eit.uni-kl.de     typename RSP_CHANNEL = tlm_fifo<RSP> >
10212027Sjungma@eit.uni-kl.declass tlm_transport_channel : public sc_core::sc_module
10312027Sjungma@eit.uni-kl.de{
10412027Sjungma@eit.uni-kl.depublic:
10512027Sjungma@eit.uni-kl.de
10612027Sjungma@eit.uni-kl.de  // master transport interface
10712027Sjungma@eit.uni-kl.de
10812027Sjungma@eit.uni-kl.de  sc_core::sc_export< tlm_transport_if< REQ , RSP > > target_export;
10912027Sjungma@eit.uni-kl.de
11012027Sjungma@eit.uni-kl.de  // slave interfaces
11112027Sjungma@eit.uni-kl.de
11212027Sjungma@eit.uni-kl.de  sc_core::sc_export< tlm_fifo_get_if< REQ > > get_request_export;
11312027Sjungma@eit.uni-kl.de  sc_core::sc_export< tlm_fifo_put_if< RSP > > put_response_export;
11412027Sjungma@eit.uni-kl.de
11512027Sjungma@eit.uni-kl.de  sc_core::sc_export< tlm_slave_if< REQ , RSP > > slave_export;
11612027Sjungma@eit.uni-kl.de
11712027Sjungma@eit.uni-kl.de  tlm_transport_channel() :
11812027Sjungma@eit.uni-kl.de    sc_core::sc_module( sc_core::sc_module_name( sc_core::sc_gen_unique_name("transport_channel" ) ) ) ,
11912027Sjungma@eit.uni-kl.de    target_export("target_export") ,
12012027Sjungma@eit.uni-kl.de    req_rsp( "req_rsp" , 1 , 1 ) ,
12112027Sjungma@eit.uni-kl.de    t2m("ts2m")
12212027Sjungma@eit.uni-kl.de  {
12312027Sjungma@eit.uni-kl.de    do_binding();
12412027Sjungma@eit.uni-kl.de  }
12512027Sjungma@eit.uni-kl.de
12612027Sjungma@eit.uni-kl.de  tlm_transport_channel( sc_core::sc_module_name nm ) :
12712027Sjungma@eit.uni-kl.de    sc_core::sc_module( nm ) ,
12812027Sjungma@eit.uni-kl.de    target_export("target_export") ,
12912027Sjungma@eit.uni-kl.de    req_rsp( "req_rsp" , 1 , 1 ) ,
13012027Sjungma@eit.uni-kl.de    t2m("tsm" )
13112027Sjungma@eit.uni-kl.de  {
13212027Sjungma@eit.uni-kl.de    do_binding();
13312027Sjungma@eit.uni-kl.de  }
13412027Sjungma@eit.uni-kl.de
13512027Sjungma@eit.uni-kl.deprivate:
13612027Sjungma@eit.uni-kl.de  void do_binding() {
13712027Sjungma@eit.uni-kl.de
13812027Sjungma@eit.uni-kl.de    target_export( t2m.target_export );
13912027Sjungma@eit.uni-kl.de
14012027Sjungma@eit.uni-kl.de    t2m.master_port( req_rsp.master_export );
14112027Sjungma@eit.uni-kl.de
14212027Sjungma@eit.uni-kl.de    get_request_export( req_rsp.get_request_export );
14312027Sjungma@eit.uni-kl.de    put_response_export( req_rsp.put_response_export );
14412027Sjungma@eit.uni-kl.de    slave_export( req_rsp.slave_export );
14512027Sjungma@eit.uni-kl.de
14612027Sjungma@eit.uni-kl.de  }
14712027Sjungma@eit.uni-kl.de
14812027Sjungma@eit.uni-kl.de  tlm_req_rsp_channel< REQ , RSP , REQ_CHANNEL , RSP_CHANNEL > req_rsp;
14912027Sjungma@eit.uni-kl.de  tlm_transport_to_master< REQ , RSP > t2m;
15012027Sjungma@eit.uni-kl.de
15112027Sjungma@eit.uni-kl.de};
15212027Sjungma@eit.uni-kl.de
15312027Sjungma@eit.uni-kl.de} // namespace tlm
15412027Sjungma@eit.uni-kl.de
15512027Sjungma@eit.uni-kl.de#endif
156