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_ANALYSIS_PORT_H__
2112027Sjungma@eit.uni-kl.de#define __TLM_ANALYSIS_PORT_H__
2212027Sjungma@eit.uni-kl.de
2312027Sjungma@eit.uni-kl.de#include "tlm_core/tlm_1/tlm_analysis/tlm_analysis_if.h"
2412027Sjungma@eit.uni-kl.de#include <deque>
2512027Sjungma@eit.uni-kl.de#include <algorithm>
2612027Sjungma@eit.uni-kl.de
2712027Sjungma@eit.uni-kl.denamespace tlm {
2812027Sjungma@eit.uni-kl.de
2912027Sjungma@eit.uni-kl.de
3012027Sjungma@eit.uni-kl.detemplate < typename T>
3112027Sjungma@eit.uni-kl.declass tlm_analysis_port :
3212027Sjungma@eit.uni-kl.de  public sc_core::sc_object ,
3312027Sjungma@eit.uni-kl.de  public virtual tlm_analysis_if< T >
3412027Sjungma@eit.uni-kl.de{
3512027Sjungma@eit.uni-kl.de public:
3612027Sjungma@eit.uni-kl.de  tlm_analysis_port() : sc_core::sc_object() {}
3712027Sjungma@eit.uni-kl.de  tlm_analysis_port( const char *nm ) : sc_core::sc_object( nm ) {}
3812027Sjungma@eit.uni-kl.de
3912027Sjungma@eit.uni-kl.de  // bind and () work for both interfaces and analysis ports, since
4012027Sjungma@eit.uni-kl.de  // analysis ports implement the analysis interface
4112027Sjungma@eit.uni-kl.de
4212027Sjungma@eit.uni-kl.de  virtual void bind( tlm_analysis_if<T> &_if ) {
4312027Sjungma@eit.uni-kl.de    m_interfaces.push_back( &_if );
4412027Sjungma@eit.uni-kl.de  }
4512027Sjungma@eit.uni-kl.de
4612027Sjungma@eit.uni-kl.de  void operator() ( tlm_analysis_if<T> &_if ) { bind( _if ); }
4712027Sjungma@eit.uni-kl.de
4812027Sjungma@eit.uni-kl.de  virtual bool unbind( tlm_analysis_if<T> &_if ) {
4912027Sjungma@eit.uni-kl.de
5012027Sjungma@eit.uni-kl.de    typename std::deque< tlm_analysis_if<T> * >::iterator i
5112027Sjungma@eit.uni-kl.de      = std::remove( m_interfaces.begin(), m_interfaces.end(), &_if );
5212027Sjungma@eit.uni-kl.de
5312027Sjungma@eit.uni-kl.de    if( i != m_interfaces.end() ) {
5412027Sjungma@eit.uni-kl.de      m_interfaces.erase(i, m_interfaces.end() );
5512027Sjungma@eit.uni-kl.de      return 1;
5612027Sjungma@eit.uni-kl.de    }
5712027Sjungma@eit.uni-kl.de
5812027Sjungma@eit.uni-kl.de    return 0;
5912027Sjungma@eit.uni-kl.de
6012027Sjungma@eit.uni-kl.de  }
6112027Sjungma@eit.uni-kl.de
6212027Sjungma@eit.uni-kl.de  void write( const T &t ) {
6312027Sjungma@eit.uni-kl.de    typename std::deque< tlm_analysis_if<T> * >::iterator i;
6412027Sjungma@eit.uni-kl.de
6512027Sjungma@eit.uni-kl.de    for( i = m_interfaces.begin();
6612027Sjungma@eit.uni-kl.de   i != m_interfaces.end();
6712027Sjungma@eit.uni-kl.de   i++ ) {
6812027Sjungma@eit.uni-kl.de
6912027Sjungma@eit.uni-kl.de      (*i)->write( t );
7012027Sjungma@eit.uni-kl.de
7112027Sjungma@eit.uni-kl.de    }
7212027Sjungma@eit.uni-kl.de
7312027Sjungma@eit.uni-kl.de  }
7412027Sjungma@eit.uni-kl.de
7512027Sjungma@eit.uni-kl.de private:
7612027Sjungma@eit.uni-kl.de  std::deque< tlm_analysis_if<T> * > m_interfaces;
7712027Sjungma@eit.uni-kl.de
7812027Sjungma@eit.uni-kl.de};
7912027Sjungma@eit.uni-kl.de
8012027Sjungma@eit.uni-kl.de} // namespace tlm
8112027Sjungma@eit.uni-kl.de
8212027Sjungma@eit.uni-kl.de#endif
8312027Sjungma@eit.uni-kl.de
8412027Sjungma@eit.uni-kl.de
85