/* * Copyright 2018 Google, Inc. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer; * redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution; * neither the name of the copyright holders nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * Authors: Gabe Black */ #include "systemc/ext/core/messages.hh" #include "systemc/utils/report.hh" namespace sc_core { const char SC_ID_NO_BOOL_RETURNED_[] = "operator does not return boolean"; const char SC_ID_NO_INT_RETURNED_[] = "operator does not return int"; const char SC_ID_NO_SC_LOGIC_RETURNED_[] = "operator does not return sc_logic"; const char SC_ID_OPERAND_NOT_SC_LOGIC_[] = "operand is not sc_logic"; const char SC_ID_OPERAND_NOT_BOOL_[] = "operand is not bool"; const char SC_ID_INSTANCE_EXISTS_[] = "object already exists"; const char SC_ID_ILLEGAL_CHARACTERS_[] = "illegal characters"; const char SC_ID_VC6_PROCESS_HELPER_[] = "internal error: sc_vc6_process_helper"; const char SC_ID_VC6_MAX_PROCESSES_EXCEEDED_[] = "maximum number of processes per module exceeded (VC6)"; const char SC_ID_END_MODULE_NOT_CALLED_[] = "module construction not properly completed: did " "you forget to add a sc_module_name parameter to " "your module constructor?"; const char SC_ID_HIER_NAME_INCORRECT_[] = "hierarchical name as shown may be incorrect due to previous errors"; const char SC_ID_SET_STACK_SIZE_[] = "set_stack_size() is only allowed for SC_THREADs and SC_CTHREADs"; const char SC_ID_SC_MODULE_NAME_USE_[] = "incorrect use of sc_module_name"; const char SC_ID_SC_MODULE_NAME_REQUIRED_[] = "an sc_module_name parameter for your constructor is required"; const char SC_ID_SET_TIME_RESOLUTION_[] = "set time resolution failed"; const char SC_ID_SET_DEFAULT_TIME_UNIT_[] = "set default time unit failed"; const char SC_ID_DEFAULT_TIME_UNIT_CHANGED_[] = "default time unit changed to time resolution"; const char SC_ID_INCONSISTENT_API_CONFIG_[] = "inconsistent library configuration detected"; const char SC_ID_WAIT_NOT_ALLOWED_[] = "wait() is only allowed in SC_THREADs and SC_CTHREADs"; const char SC_ID_NEXT_TRIGGER_NOT_ALLOWED_[] = "next_trigger() is only allowed in SC_METHODs"; const char SC_ID_IMMEDIATE_NOTIFICATION_[] = "immediate notification is not allowed during update phase or elaboration"; const char SC_ID_HALT_NOT_ALLOWED_[] = "halt() is only allowed in SC_CTHREADs"; const char SC_ID_WATCHING_NOT_ALLOWED_[] = "watching() has been deprecated, use reset_signal_is()"; const char SC_ID_DONT_INITIALIZE_[] = "dont_initialize() has no effect for SC_CTHREADs"; const char SC_ID_WAIT_N_INVALID_[] = "wait(n) is only valid for n > 0"; const char SC_ID_MAKE_SENSITIVE_[] = "make sensitive failed"; const char SC_ID_MAKE_SENSITIVE_POS_[] = "make sensitive pos failed"; const char SC_ID_MAKE_SENSITIVE_NEG_[] = "make sensitive neg failed"; const char SC_ID_INSERT_MODULE_[] = "insert module failed"; const char SC_ID_REMOVE_MODULE_[] = "remove module failed"; const char SC_ID_NOTIFY_DELAYED_[] = "notify_delayed() cannot be called on events " "that have pending notifications"; const char SC_ID_GEN_UNIQUE_NAME_[] = "cannot generate unique name from null string"; const char SC_ID_MODULE_NAME_STACK_EMPTY_[] = "module name stack is empty: did you forget to " "add a sc_module_name parameter to your module " "constructor?"; const char SC_ID_NAME_EXISTS_[] = "name already exists"; const char SC_ID_IMMEDIATE_SELF_NOTIFICATION_[] = "immediate self-notification ignored as of IEEE 1666-2011"; const char SC_ID_WAIT_DURING_UNWINDING_[] = "wait() not allowed during unwinding"; const char SC_ID_CYCLE_MISSES_EVENTS_[] = "the simulation contains timed-events but they are " "ignored by sc_cycle() ==> the simulation will be " "incorrect"; const char SC_ID_RETHROW_UNWINDING_[] = "sc_unwind_exception not re-thrown during kill/reset"; const char SC_ID_PROCESS_ALREADY_UNWINDING_[] = "kill/reset ignored during unwinding"; const char SC_ID_MODULE_METHOD_AFTER_START_[] = "call to SC_METHOD in sc_module while simulation running"; const char SC_ID_MODULE_THREAD_AFTER_START_[] = "call to SC_THREAD in sc_module while simulation running"; const char SC_ID_MODULE_CTHREAD_AFTER_START_[] = "call to SC_CTHREAD in sc_module while simulation running"; const char SC_ID_SIMULATION_TIME_OVERFLOW_[] = "simulation time value overflow, simulation aborted"; const char SC_ID_SIMULATION_STOP_CALLED_TWICE_[] = "sc_stop has already been called"; const char SC_ID_SIMULATION_START_AFTER_STOP_[] = "sc_start called after sc_stop has been called"; const char SC_ID_STOP_MODE_AFTER_START_[] = "attempt to set sc_stop mode after start will be ignored"; const char SC_ID_SIMULATION_START_AFTER_ERROR_[] = "attempt to restart simulation after error"; const char SC_ID_SIMULATION_UNCAUGHT_EXCEPTION_[] = "uncaught exception"; const char SC_ID_PHASE_CALLBACKS_UNSUPPORTED_[] = "simulation phase callbacks not enabled"; const char SC_ID_PHASE_CALLBACK_NOT_IMPLEMENTED_[] = "empty simulation phase callback called"; const char SC_ID_PHASE_CALLBACK_REGISTER_[] = "register simulation phase callback"; const char SC_ID_PHASE_CALLBACK_FORBIDDEN_[] = "forbidden action in simulation phase callback"; const char SC_ID_SIMULATION_START_UNEXPECTED_[] = "sc_start called unexpectedly"; const char SC_ID_THROW_IT_IGNORED_[] = "throw_it on method/non-running process is being ignored "; const char SC_ID_NOT_EXPECTING_DYNAMIC_EVENT_NOTIFY_[] = "dynamic event notification encountered when sensitivity is static"; const char SC_ID_DISABLE_WILL_ORPHAN_PROCESS_[] = "disable() or dont_initialize() called on process with no static " "sensitivity, it will be orphaned"; const char SC_ID_PROCESS_CONTROL_CORNER_CASE_[] = "Undefined process control interaction"; const char SC_ID_METHOD_TERMINATION_EVENT_[] = "Attempt to get terminated event for a method process"; const char SC_ID_JOIN_ON_METHOD_HANDLE_[] = "Attempt to register method process with sc_join object"; const char SC_ID_NO_PROCESS_SEMANTICS_[] = "Attempt to invoke process with no semantics() method"; const char SC_ID_EVENT_ON_NULL_PROCESS_[] = "Attempt to get an event for non-existent process"; const char SC_ID_EVENT_LIST_FAILED_[] = "invalid use of sc_(and|or)_event list"; const char SC_ID_UNKNOWN_PROCESS_TYPE_[] = "Unknown process type"; const char SC_ID_TIME_CONVERSION_FAILED_[] = "sc_time conversion failed"; const char SC_ID_NEGATIVE_SIMULATION_TIME_[] = "negative simulation interval specified in sc_start call"; const char SC_ID_BAD_SC_MODULE_CONSTRUCTOR_[] = "sc_module(const char*), sc_module(const std::string&) " "have been deprecated, use sc_module(const sc_module_name&)"; const char SC_ID_EMPTY_PROCESS_HANDLE_[] = "attempt to use an empty process handle ignored"; const char SC_ID_NO_SC_START_ACTIVITY_[] = "no activity or clock movement for sc_start() invocation"; const char SC_ID_KILL_PROCESS_WHILE_UNITIALIZED_[] = "a process may not be killed before it is initialized"; const char SC_ID_RESET_PROCESS_WHILE_NOT_RUNNING_[] = "a process may not be asynchronously reset while the " "simulation is not running"; const char SC_ID_THROW_IT_WHILE_NOT_RUNNING_[] = "throw_it not allowed unless simulation is running "; namespace { sc_gem5::DefaultReportMessages predfinedMessages{ {500, SC_ID_NO_BOOL_RETURNED_}, {501, SC_ID_NO_INT_RETURNED_}, {502, SC_ID_NO_SC_LOGIC_RETURNED_}, {503, SC_ID_OPERAND_NOT_SC_LOGIC_}, {504, SC_ID_OPERAND_NOT_BOOL_}, {505, SC_ID_INSTANCE_EXISTS_}, {506, SC_ID_ILLEGAL_CHARACTERS_}, {507, SC_ID_VC6_PROCESS_HELPER_}, {508, SC_ID_VC6_MAX_PROCESSES_EXCEEDED_}, {509, SC_ID_END_MODULE_NOT_CALLED_}, {510, SC_ID_HIER_NAME_INCORRECT_}, {511, SC_ID_SET_STACK_SIZE_}, {512, SC_ID_SC_MODULE_NAME_USE_}, {513, SC_ID_SC_MODULE_NAME_REQUIRED_}, {514, SC_ID_SET_TIME_RESOLUTION_}, {515, SC_ID_SET_DEFAULT_TIME_UNIT_}, {516, SC_ID_DEFAULT_TIME_UNIT_CHANGED_}, {517, SC_ID_INCONSISTENT_API_CONFIG_}, {519, SC_ID_WAIT_NOT_ALLOWED_}, {520, SC_ID_NEXT_TRIGGER_NOT_ALLOWED_}, {521, SC_ID_IMMEDIATE_NOTIFICATION_}, {522, SC_ID_HALT_NOT_ALLOWED_}, {523, SC_ID_WATCHING_NOT_ALLOWED_}, {524, SC_ID_DONT_INITIALIZE_}, {525, SC_ID_WAIT_N_INVALID_}, {526, SC_ID_MAKE_SENSITIVE_}, {527, SC_ID_MAKE_SENSITIVE_POS_}, {528, SC_ID_MAKE_SENSITIVE_NEG_}, {529, SC_ID_INSERT_MODULE_}, {530, SC_ID_REMOVE_MODULE_}, {531, SC_ID_NOTIFY_DELAYED_}, {532, SC_ID_GEN_UNIQUE_NAME_}, {533, SC_ID_MODULE_NAME_STACK_EMPTY_}, {534, SC_ID_NAME_EXISTS_}, {536, SC_ID_IMMEDIATE_SELF_NOTIFICATION_}, {537, SC_ID_WAIT_DURING_UNWINDING_}, {538, SC_ID_CYCLE_MISSES_EVENTS_}, {539, SC_ID_RETHROW_UNWINDING_}, {540, SC_ID_PROCESS_ALREADY_UNWINDING_}, {541, SC_ID_MODULE_METHOD_AFTER_START_}, {542, SC_ID_MODULE_THREAD_AFTER_START_}, {543, SC_ID_MODULE_CTHREAD_AFTER_START_}, {544, SC_ID_SIMULATION_TIME_OVERFLOW_}, {545, SC_ID_SIMULATION_STOP_CALLED_TWICE_}, {546, SC_ID_SIMULATION_START_AFTER_STOP_}, {547, SC_ID_STOP_MODE_AFTER_START_}, {548, SC_ID_SIMULATION_START_AFTER_ERROR_}, {549, SC_ID_SIMULATION_UNCAUGHT_EXCEPTION_}, {550, SC_ID_PHASE_CALLBACKS_UNSUPPORTED_}, {551, SC_ID_PHASE_CALLBACK_NOT_IMPLEMENTED_}, {552, SC_ID_PHASE_CALLBACK_REGISTER_}, {553, SC_ID_PHASE_CALLBACK_FORBIDDEN_}, {554, SC_ID_SIMULATION_START_UNEXPECTED_}, {556, SC_ID_THROW_IT_IGNORED_}, {557, SC_ID_NOT_EXPECTING_DYNAMIC_EVENT_NOTIFY_}, {558, SC_ID_DISABLE_WILL_ORPHAN_PROCESS_}, {559, SC_ID_PROCESS_CONTROL_CORNER_CASE_}, {560, SC_ID_METHOD_TERMINATION_EVENT_}, {561, SC_ID_JOIN_ON_METHOD_HANDLE_}, {563, SC_ID_NO_PROCESS_SEMANTICS_}, {564, SC_ID_EVENT_ON_NULL_PROCESS_}, {565, SC_ID_EVENT_LIST_FAILED_}, {566, SC_ID_UNKNOWN_PROCESS_TYPE_}, {567, SC_ID_TIME_CONVERSION_FAILED_}, {568, SC_ID_NEGATIVE_SIMULATION_TIME_}, {569, SC_ID_BAD_SC_MODULE_CONSTRUCTOR_}, {570, SC_ID_EMPTY_PROCESS_HANDLE_}, {571, SC_ID_NO_SC_START_ACTIVITY_}, {572, SC_ID_KILL_PROCESS_WHILE_UNITIALIZED_}, {573, SC_ID_RESET_PROCESS_WHILE_NOT_RUNNING_}, {574, SC_ID_THROW_IT_WHILE_NOT_RUNNING_} }; } // anonymous namespace } // namespace sc_core