diff options
Diffstat (limited to 'ext/systemc/src/sysc/kernel/sc_sensitive.cpp')
-rw-r--r-- | ext/systemc/src/sysc/kernel/sc_sensitive.cpp | 959 |
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! |