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_ADAPTERS_H__
2112027Sjungma@eit.uni-kl.de#define __TLM_ADAPTERS_H__
2212027Sjungma@eit.uni-kl.de
2312027Sjungma@eit.uni-kl.de#include "tlm_core/tlm_1/tlm_req_rsp/tlm_1_interfaces/tlm_master_slave_ifs.h"
2412027Sjungma@eit.uni-kl.de
2512027Sjungma@eit.uni-kl.denamespace tlm {
2612027Sjungma@eit.uni-kl.de
2712027Sjungma@eit.uni-kl.detemplate< typename REQ , typename RSP >
2812027Sjungma@eit.uni-kl.declass tlm_transport_to_master :
2912027Sjungma@eit.uni-kl.de  public sc_core::sc_module ,
3012027Sjungma@eit.uni-kl.de  public virtual tlm_transport_if< REQ , RSP >
3112027Sjungma@eit.uni-kl.de{
3212027Sjungma@eit.uni-kl.depublic:
3312027Sjungma@eit.uni-kl.de  sc_core::sc_export< tlm_transport_if< REQ , RSP > > target_export;
3412027Sjungma@eit.uni-kl.de  sc_core::sc_port< tlm_master_if< REQ , RSP > > master_port;
3512027Sjungma@eit.uni-kl.de
3612027Sjungma@eit.uni-kl.de  tlm_transport_to_master( sc_core::sc_module_name nm ) :
3712027Sjungma@eit.uni-kl.de    sc_core::sc_module( nm ) {
3812027Sjungma@eit.uni-kl.de
3912027Sjungma@eit.uni-kl.de    target_export( *this );
4012027Sjungma@eit.uni-kl.de
4112027Sjungma@eit.uni-kl.de  }
4212027Sjungma@eit.uni-kl.de
4312027Sjungma@eit.uni-kl.de  tlm_transport_to_master() :
4412027Sjungma@eit.uni-kl.de    sc_core::sc_module( sc_core::sc_module_name( sc_core::sc_gen_unique_name( "transport_to_master" ) ) ){
4512027Sjungma@eit.uni-kl.de
4612027Sjungma@eit.uni-kl.de    target_export( *this );
4712027Sjungma@eit.uni-kl.de
4812027Sjungma@eit.uni-kl.de  }
4912027Sjungma@eit.uni-kl.de
5012027Sjungma@eit.uni-kl.de  RSP transport( const REQ &req ) {
5112027Sjungma@eit.uni-kl.de
5212027Sjungma@eit.uni-kl.de    mutex.lock();
5312027Sjungma@eit.uni-kl.de
5412027Sjungma@eit.uni-kl.de    master_port->put( req );
5512027Sjungma@eit.uni-kl.de    rsp = master_port->get();
5612027Sjungma@eit.uni-kl.de
5712027Sjungma@eit.uni-kl.de    mutex.unlock();
5812027Sjungma@eit.uni-kl.de    return rsp;
5912027Sjungma@eit.uni-kl.de
6012027Sjungma@eit.uni-kl.de  }
6112027Sjungma@eit.uni-kl.de
6212027Sjungma@eit.uni-kl.deprivate:
6312027Sjungma@eit.uni-kl.de  sc_core::sc_mutex mutex;
6412027Sjungma@eit.uni-kl.de  RSP rsp;
6512027Sjungma@eit.uni-kl.de
6612027Sjungma@eit.uni-kl.de};
6712027Sjungma@eit.uni-kl.de
6812027Sjungma@eit.uni-kl.detemplate< typename REQ , typename RSP >
6912027Sjungma@eit.uni-kl.declass tlm_slave_to_transport : public sc_core::sc_module
7012027Sjungma@eit.uni-kl.de{
7112027Sjungma@eit.uni-kl.depublic:
7212027Sjungma@eit.uni-kl.de
7312027Sjungma@eit.uni-kl.de  SC_HAS_PROCESS( tlm_slave_to_transport );
7412027Sjungma@eit.uni-kl.de
7512027Sjungma@eit.uni-kl.de  sc_core::sc_port< tlm_slave_if< REQ , RSP > > slave_port;
7612027Sjungma@eit.uni-kl.de  sc_core::sc_port< tlm_transport_if< REQ , RSP > > initiator_port;
7712027Sjungma@eit.uni-kl.de
7812027Sjungma@eit.uni-kl.de  tlm_slave_to_transport( sc_core::sc_module_name nm ) : sc_core::sc_module( nm )
7912027Sjungma@eit.uni-kl.de  {}
8012027Sjungma@eit.uni-kl.de
8112027Sjungma@eit.uni-kl.de  tlm_slave_to_transport() :
8212027Sjungma@eit.uni-kl.de    sc_core::sc_module( sc_core::sc_module_name( sc_core::sc_gen_unique_name("slave_to_transport") ) )
8312027Sjungma@eit.uni-kl.de  {}
8412027Sjungma@eit.uni-kl.de
8512027Sjungma@eit.uni-kl.deprivate:
8612027Sjungma@eit.uni-kl.de  void run() {
8712027Sjungma@eit.uni-kl.de
8812027Sjungma@eit.uni-kl.de    REQ req;
8912027Sjungma@eit.uni-kl.de    RSP rsp;
9012027Sjungma@eit.uni-kl.de
9112027Sjungma@eit.uni-kl.de    while( true ) {
9212027Sjungma@eit.uni-kl.de
9312027Sjungma@eit.uni-kl.de     slave_port->get( req );
9412027Sjungma@eit.uni-kl.de     rsp = initiator_port->transport( req );
9512027Sjungma@eit.uni-kl.de     slave_port->put( rsp );
9612027Sjungma@eit.uni-kl.de
9712027Sjungma@eit.uni-kl.de    }
9812027Sjungma@eit.uni-kl.de
9912027Sjungma@eit.uni-kl.de  }
10012027Sjungma@eit.uni-kl.de
10112027Sjungma@eit.uni-kl.de};
10212027Sjungma@eit.uni-kl.de
10312027Sjungma@eit.uni-kl.de} // namespace tlm
10412027Sjungma@eit.uni-kl.de
10512027Sjungma@eit.uni-kl.de#endif
106