blob: 7d067cfd709c1ea509469fec16d3e8ac9be523bf [file] [log] [blame]
/*
* 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