summaryrefslogtreecommitdiff
path: root/ext/systemc/src/sysc/kernel/sc_sensitive.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'ext/systemc/src/sysc/kernel/sc_sensitive.cpp')
-rw-r--r--ext/systemc/src/sysc/kernel/sc_sensitive.cpp959
1 files changed, 959 insertions, 0 deletions
diff --git a/ext/systemc/src/sysc/kernel/sc_sensitive.cpp b/ext/systemc/src/sysc/kernel/sc_sensitive.cpp
new file mode 100644
index 000000000..210c2670e
--- /dev/null
+++ b/ext/systemc/src/sysc/kernel/sc_sensitive.cpp
@@ -0,0 +1,959 @@
+/*****************************************************************************
+
+ Licensed to Accellera Systems Initiative Inc. (Accellera) under one or
+ more contributor license agreements. See the NOTICE file distributed
+ with this work for additional information regarding copyright ownership.
+ Accellera licenses this file to you under the Apache License, Version 2.0
+ (the "License"); you may not use this file except in compliance with the
+ License. You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ implied. See the License for the specific language governing
+ permissions and limitations under the License.
+
+ *****************************************************************************/
+
+/*****************************************************************************
+
+ sc_sensitive.cpp --
+
+ Original Author: Stan Y. Liao, Synopsys, Inc.
+ Martin Janssen, Synopsys, Inc.
+
+ CHANGE LOG AT THE END OF THE FILE
+ *****************************************************************************/
+
+
+#include "sysc/kernel/sc_event.h"
+#include "sysc/kernel/sc_kernel_ids.h"
+#include "sysc/kernel/sc_module.h"
+#include "sysc/kernel/sc_cthread_process.h"
+#include "sysc/kernel/sc_method_process.h"
+#include "sysc/kernel/sc_thread_process.h"
+#include "sysc/kernel/sc_process_handle.h"
+#include "sysc/kernel/sc_sensitive.h"
+#include "sysc/communication/sc_signal_ports.h"
+#include "sysc/utils/sc_utils_ids.h"
+
+namespace sc_core {
+
+// support functions
+
+static
+sc_method_handle
+as_method_handle( sc_process_b* handle_ )
+{
+ return DCAST<sc_method_handle>( handle_ );
+}
+
+static
+sc_thread_handle
+as_thread_handle( sc_process_b* handle_ )
+{
+ return DCAST<sc_thread_handle>( handle_ );
+}
+
+static
+void
+warn_no_parens()
+{
+ static bool warn_no_parentheses=true;
+ if ( warn_no_parentheses )
+ {
+ warn_no_parentheses=false;
+ SC_REPORT_INFO(SC_ID_IEEE_1666_DEPRECATION_,
+ "use of () to specify sensitivity is deprecated, use << instead" );
+ }
+}
+
+// ----------------------------------------------------------------------------
+// CLASS : sc_sensitive
+//
+// Static sensitivity class for events.
+// ----------------------------------------------------------------------------
+
+// constructor
+
+sc_sensitive::sc_sensitive( sc_module* module_ )
+: m_module( module_ ),
+ m_mode( SC_NONE_ ),
+ m_handle( 0 )
+{}
+
+
+// destructor
+
+sc_sensitive::~sc_sensitive()
+{}
+
+
+// changing between process handles
+
+sc_sensitive&
+sc_sensitive::operator << ( sc_process_handle handle_ )
+{
+ switch ( handle_.proc_kind() )
+ {
+ case SC_CTHREAD_PROC_:
+ case SC_THREAD_PROC_:
+ m_mode = SC_THREAD_;
+ break;
+ case SC_METHOD_PROC_:
+ m_mode = SC_METHOD_;
+ break;
+ default:
+ assert(0);
+ }
+ m_handle = (sc_process_b*)handle_;
+ return *this;
+}
+
+sc_sensitive&
+sc_sensitive::operator << ( const sc_event& event_ )
+{
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_:
+ case SC_THREAD_: {
+ m_handle->add_static_event( event_ );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+void
+sc_sensitive::make_static_sensitivity(
+ sc_process_b* handle_, const sc_event& event_)
+{
+ handle_->add_static_event( event_ );
+}
+
+
+sc_sensitive&
+sc_sensitive::operator << ( const sc_interface& interface_ )
+{
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_:
+ case SC_THREAD_: {
+ m_handle->add_static_event( interface_.default_event() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+void
+sc_sensitive::make_static_sensitivity(
+ sc_process_b* handle_, const sc_interface& interface_)
+{
+ handle_->add_static_event( interface_.default_event() );
+}
+
+sc_sensitive&
+sc_sensitive::operator << ( const sc_port_base& port_ )
+{
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_: {
+ port_.make_sensitive( as_method_handle( m_handle ) );
+ break;
+ }
+ case SC_THREAD_: {
+ port_.make_sensitive( as_thread_handle( m_handle ) );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+void
+sc_sensitive::make_static_sensitivity(
+ sc_process_b* handle_, const sc_port_base& port_)
+{
+ sc_method_handle handle_m = as_method_handle( handle_ );
+ if ( handle_m ) {
+ port_.make_sensitive( handle_m );
+ return;
+ }
+ sc_thread_handle handle_t = as_thread_handle( handle_ );
+ // assert(handle_t);
+ port_.make_sensitive( handle_t );
+}
+
+sc_sensitive&
+sc_sensitive::operator << ( sc_event_finder& event_finder_ )
+{
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_: {
+ event_finder_.port().make_sensitive( as_method_handle( m_handle ),
+ &event_finder_ );
+ break;
+ }
+ case SC_THREAD_: {
+ event_finder_.port().make_sensitive( as_thread_handle( m_handle ),
+ &event_finder_ );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+void
+sc_sensitive::make_static_sensitivity(
+ sc_process_b* handle_, sc_event_finder& event_finder_)
+{
+ if (sc_is_running()) {
+ handle_->add_static_event( event_finder_.find_event() );
+ } else {
+ sc_method_handle handle_m = as_method_handle( handle_ );
+ if ( handle_m ) {
+ event_finder_.port().make_sensitive( handle_m, &event_finder_ );
+ return;
+ }
+ sc_thread_handle handle_t = as_thread_handle( handle_ );
+ // assert(handle_t);
+ event_finder_.port().make_sensitive( handle_t, &event_finder_);
+ }
+}
+
+
+sc_sensitive&
+sc_sensitive::operator () ( const sc_event& event_ )
+{
+ warn_no_parens();
+ return operator << ( event_ );
+}
+
+sc_sensitive&
+sc_sensitive::operator () ( const sc_interface& interface_ )
+{
+ warn_no_parens();
+ return operator << ( interface_ );
+}
+
+sc_sensitive&
+sc_sensitive::operator () ( const sc_port_base& port_ )
+{
+ warn_no_parens();
+ return operator << ( port_ );
+}
+
+sc_sensitive&
+sc_sensitive::operator () ( sc_event_finder& event_finder_ )
+{
+ warn_no_parens();
+ return operator << ( event_finder_ );
+}
+
+
+sc_sensitive&
+sc_sensitive::operator () ( sc_cthread_handle handle_,
+ sc_event_finder& event_finder_ )
+{
+ event_finder_.port().make_sensitive( handle_, &event_finder_ );
+ return *this;
+}
+
+sc_sensitive&
+sc_sensitive::operator () ( sc_cthread_handle handle_,
+ const in_if_b_type& interface_ )
+{
+ handle_->add_static_event( interface_.posedge_event() );
+ return *this;
+}
+
+sc_sensitive&
+sc_sensitive::operator () ( sc_cthread_handle handle_,
+ const in_if_l_type& interface_ )
+{
+ handle_->add_static_event( interface_.posedge_event() );
+ return *this;
+}
+
+sc_sensitive&
+sc_sensitive::operator () ( sc_cthread_handle handle_,
+ const in_port_b_type& port_ )
+{
+ port_.make_sensitive( handle_, &port_.pos() );
+ return *this;
+}
+
+sc_sensitive&
+sc_sensitive::operator () ( sc_cthread_handle handle_,
+ const in_port_l_type& port_ )
+{
+ port_.make_sensitive( handle_, &port_.pos() );
+ return *this;
+}
+
+sc_sensitive&
+sc_sensitive::operator () ( sc_cthread_handle handle_,
+ const inout_port_b_type& port_ )
+{
+ port_.make_sensitive( handle_, &port_.pos() );
+ return *this;
+}
+
+sc_sensitive&
+sc_sensitive::operator () ( sc_cthread_handle handle_,
+ const inout_port_l_type& port_ )
+{
+ port_.make_sensitive( handle_, &port_.pos() );
+ return *this;
+}
+
+void sc_sensitive::reset()
+{
+ m_mode = SC_NONE_;
+}
+
+
+// ----------------------------------------------------------------------------
+// CLASS : sc_sensitive_pos
+//
+// Static sensitivity class for positive edge events.
+// ----------------------------------------------------------------------------
+
+static void sc_deprecated_sensitive_pos()
+{
+ static bool warn_sensitive_pos=true;
+ if ( warn_sensitive_pos )
+ {
+ warn_sensitive_pos=false;
+ SC_REPORT_INFO(SC_ID_IEEE_1666_DEPRECATION_,
+ "sc_sensitive_pos is deprecated use sc_sensitive << with pos() instead" );
+ }
+}
+
+// constructor
+
+sc_sensitive_pos::sc_sensitive_pos( sc_module* module_ )
+: m_module( module_ ),
+ m_mode( SC_NONE_ ),
+ m_handle( 0 )
+{}
+
+
+// destructor
+
+sc_sensitive_pos::~sc_sensitive_pos()
+{}
+
+
+// changing between process handles
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator << ( sc_process_handle handle_ )
+{
+ switch ( handle_.proc_kind() )
+ {
+ case SC_CTHREAD_PROC_:
+ case SC_THREAD_PROC_:
+ m_mode = SC_THREAD_;
+ break;
+ case SC_METHOD_PROC_:
+ m_mode = SC_METHOD_;
+ break;
+ default:
+ assert(0);
+ }
+ m_handle = (sc_process_b*)handle_;
+ return *this;
+}
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator << ( sc_method_handle handle_ )
+{
+ m_mode = SC_METHOD_;
+ m_handle = handle_;
+ return *this;
+}
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator << ( sc_thread_handle handle_ )
+{
+ m_mode = SC_THREAD_;
+ m_handle = handle_;
+ return *this;
+}
+
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator << ( const in_if_b_type& interface_ )
+{
+ sc_deprecated_sensitive_pos();
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_POS_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_:
+ case SC_THREAD_: {
+ m_handle->add_static_event( interface_.posedge_event() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator << ( const in_if_l_type& interface_ )
+{
+ sc_deprecated_sensitive_pos();
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_POS_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_:
+ case SC_THREAD_: {
+ m_handle->add_static_event( interface_.posedge_event() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator << ( const in_port_b_type& port_ )
+{
+ sc_deprecated_sensitive_pos();
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_POS_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_: {
+ port_.make_sensitive( as_method_handle( m_handle ), &port_.pos() );
+ break;
+ }
+ case SC_THREAD_: {
+ port_.make_sensitive( as_thread_handle( m_handle ), &port_.pos() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator << ( const in_port_l_type& port_ )
+{
+ sc_deprecated_sensitive_pos();
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_POS_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_: {
+ port_.make_sensitive( as_method_handle( m_handle ), &port_.pos() );
+ break;
+ }
+ case SC_THREAD_: {
+ port_.make_sensitive( as_thread_handle( m_handle ), &port_.pos() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator << ( const inout_port_b_type& port_ )
+{
+ sc_deprecated_sensitive_pos();
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_POS_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_: {
+ port_.make_sensitive( as_method_handle( m_handle ), &port_.pos() );
+ break;
+ }
+ case SC_THREAD_: {
+ port_.make_sensitive( as_thread_handle( m_handle ), &port_.pos() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator << ( const inout_port_l_type& port_ )
+{
+ sc_deprecated_sensitive_pos();
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_POS_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_: {
+ port_.make_sensitive( as_method_handle( m_handle ), &port_.pos() );
+ break;
+ }
+ case SC_THREAD_: {
+ port_.make_sensitive( as_thread_handle( m_handle ), &port_.pos() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator () ( const in_if_b_type& interface_ )
+{
+ warn_no_parens();
+ return operator << ( interface_ );
+}
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator () ( const in_if_l_type& interface_ )
+{
+ warn_no_parens();
+ return operator << ( interface_ );
+}
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator () ( const in_port_b_type& port_ )
+{
+ warn_no_parens();
+ return operator << ( port_ );
+}
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator () ( const in_port_l_type& port_ )
+{
+ warn_no_parens();
+ return operator << ( port_ );
+}
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator () ( const inout_port_b_type& port_ )
+{
+ warn_no_parens();
+ return operator << ( port_ );
+}
+
+sc_sensitive_pos&
+sc_sensitive_pos::operator () ( const inout_port_l_type& port_ )
+{
+ warn_no_parens();
+ return operator << ( port_ );
+}
+
+void sc_sensitive_pos::reset()
+{
+ m_mode = SC_NONE_;
+}
+
+
+// ----------------------------------------------------------------------------
+// CLASS : sc_sensitive_neg
+//
+// Static sensitivity class for negative edge events.
+// ----------------------------------------------------------------------------
+
+static void sc_deprecated_sensitive_neg()
+{
+ static bool warn_sensitive_neg=true;
+ if ( warn_sensitive_neg )
+ {
+ warn_sensitive_neg=false;
+ SC_REPORT_INFO(SC_ID_IEEE_1666_DEPRECATION_,
+ "sc_sensitive_neg is deprecated use sc_sensitive << with neg() instead" );
+ }
+}
+
+// constructor
+
+sc_sensitive_neg::sc_sensitive_neg( sc_module* module_ )
+: m_module( module_ ),
+ m_mode( SC_NONE_ ),
+ m_handle( 0 )
+{}
+
+
+// destructor
+
+sc_sensitive_neg::~sc_sensitive_neg()
+{}
+
+
+// changing between process handles
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator << ( sc_process_handle handle_ )
+{
+ switch ( handle_.proc_kind() )
+ {
+ case SC_CTHREAD_PROC_:
+ case SC_THREAD_PROC_:
+ m_mode = SC_THREAD_;
+ break;
+ case SC_METHOD_PROC_:
+ m_mode = SC_METHOD_;
+ break;
+ default:
+ assert(0);
+ }
+ m_handle = (sc_process_b*)handle_;
+ return *this;
+}
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator << ( sc_method_handle handle_ )
+{
+ m_mode = SC_METHOD_;
+ m_handle = handle_;
+ return *this;
+}
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator << ( sc_thread_handle handle_ )
+{
+ m_mode = SC_THREAD_;
+ m_handle = handle_;
+ return *this;
+}
+
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator << ( const in_if_b_type& interface_ )
+{
+ sc_deprecated_sensitive_neg();
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_NEG_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_:
+ case SC_THREAD_: {
+ m_handle->add_static_event( interface_.negedge_event() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator << ( const in_if_l_type& interface_ )
+{
+ sc_deprecated_sensitive_neg();
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_NEG_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_:
+ case SC_THREAD_: {
+ m_handle->add_static_event( interface_.negedge_event() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator << ( const in_port_b_type& port_ )
+{
+ sc_deprecated_sensitive_neg();
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_NEG_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_: {
+ port_.make_sensitive( as_method_handle( m_handle ), &port_.neg() );
+ break;
+ }
+ case SC_THREAD_: {
+ port_.make_sensitive( as_thread_handle( m_handle ), &port_.neg() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator << ( const in_port_l_type& port_ )
+{
+ sc_deprecated_sensitive_neg();
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_NEG_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_: {
+ port_.make_sensitive( as_method_handle( m_handle ), &port_.neg() );
+ break;
+ }
+ case SC_THREAD_: {
+ port_.make_sensitive( as_thread_handle( m_handle ), &port_.neg() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator << ( const inout_port_b_type& port_ )
+{
+ sc_deprecated_sensitive_neg();
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_NEG_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_: {
+ port_.make_sensitive( as_method_handle( m_handle ), &port_.neg() );
+ break;
+ }
+ case SC_THREAD_: {
+ port_.make_sensitive( as_thread_handle( m_handle ), &port_.neg() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator << ( const inout_port_l_type& port_ )
+{
+ sc_deprecated_sensitive_neg();
+ // check
+ if( sc_is_running() ) {
+ SC_REPORT_ERROR( SC_ID_MAKE_SENSITIVE_NEG_, "simulation running" );
+ }
+
+ // make sensitive
+ switch( m_mode ) {
+ case SC_METHOD_: {
+ port_.make_sensitive( as_method_handle( m_handle ), &port_.neg() );
+ break;
+ }
+ case SC_THREAD_: {
+ port_.make_sensitive( as_thread_handle( m_handle ), &port_.neg() );
+ break;
+ }
+ case SC_NONE_:
+ /* do nothing */
+ break;
+ }
+
+ return *this;
+}
+
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator () ( const in_if_b_type& interface_ )
+{
+ warn_no_parens();
+ return operator << ( interface_ );
+}
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator () ( const in_if_l_type& interface_ )
+{
+ warn_no_parens();
+ return operator << ( interface_ );
+}
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator () ( const in_port_b_type& port_ )
+{
+ warn_no_parens();
+ return operator << ( port_ );
+}
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator () ( const in_port_l_type& port_ )
+{
+ warn_no_parens();
+ return operator << ( port_ );
+}
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator () ( const inout_port_b_type& port_ )
+{
+ warn_no_parens();
+ return operator << ( port_ );
+}
+
+sc_sensitive_neg&
+sc_sensitive_neg::operator () ( const inout_port_l_type& port_ )
+{
+ warn_no_parens();
+ return operator << ( port_ );
+}
+
+void sc_sensitive_neg::reset()
+{
+ m_mode = SC_NONE_;
+}
+
+} // namespace sc_core
+
+/*****************************************************************************
+
+ MODIFICATION LOG - modifiers, enter your name, affiliation, date and
+ changes you are making here.
+
+ Name, Affiliation, Date: Bishnupriya Bhattacharya, Cadence Design Systems,
+ 25 August, 2003
+ Description of Modification: add make_static_sensitivity() routines to support
+ dynamic method process creation with static
+ sensitivity
+
+ *****************************************************************************/
+
+// $Log: sc_sensitive.cpp,v $
+// Revision 1.5 2011/08/26 20:46:10 acg
+// Andy Goodrich: moved the modification log to the end of the file to
+// eliminate source line number skew when check-ins are done.
+//
+// Revision 1.4 2011/02/18 20:27:14 acg
+// Andy Goodrich: Updated Copyrights.
+//
+// Revision 1.3 2011/02/13 21:47:38 acg
+// Andy Goodrich: update copyright notice.
+//
+// Revision 1.2 2008/05/22 17:06:26 acg
+// Andy Goodrich: updated copyright notice to include 2008.
+//
+// Revision 1.1.1.1 2006/12/15 20:20:05 acg
+// SystemC 2.3
+//
+// Revision 1.8 2006/04/11 23:13:21 acg
+// Andy Goodrich: Changes for reduced reset support that only includes
+// sc_cthread, but has preliminary hooks for expanding to method and thread
+// processes also.
+//
+// Revision 1.7 2006/01/27 17:31:24 acg
+// Andy Goodrich: removed debugging comments from << operator code for types
+// that are deprecated.
+//
+// Revision 1.6 2006/01/26 21:04:54 acg
+// Andy Goodrich: deprecation message changes and additional messages.
+//
+// Revision 1.5 2006/01/25 00:31:19 acg
+// Andy Goodrich: Changed over to use a standard message id of
+// SC_ID_IEEE_1666_DEPRECATION for all deprecation messages.
+//
+// Revision 1.4 2006/01/24 20:49:05 acg
+// Andy Goodrich: changes to remove the use of deprecated features within the
+// simulator, and to issue warning messages when deprecated features are used.
+//
+// Revision 1.3 2006/01/13 18:44:30 acg
+// Added $Log to record CVS changes into the source.
+//
+
+// Taf!