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