/* * 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 #include "base/logging.hh" #include "systemc/ext/utils/messages.hh" #include "systemc/ext/utils/sc_report.hh" #include "systemc/ext/utils/sc_report_handler.hh" #include "systemc/utils/report.hh" namespace sc_core { sc_report::sc_report(sc_severity _severity, const char *msg_type, const char *msg, int _verbosity, const char *_fileName, int _lineNumber, sc_time _time, const char *_processName, int _id) : _severity(_severity), _msgType(msg_type), _msg(msg), _verbosity(_verbosity), _fileName(_fileName), _lineNumber(_lineNumber), _time(_time), _processName(_processName), _id(_id) { if (_msgType) _msgType = strdup(_msgType); if (_msg) _msg = strdup(_msg); _what = sc_report_compose_message(*this); } sc_report::sc_report(const sc_report &r) : sc_report(r._severity, r._msgType, r._msg, r._verbosity, r._fileName, r._lineNumber, r._time, r._processName, r._id) {} sc_report & sc_report::operator = (const sc_report &r) { _severity = r._severity; free((void *)_msgType); _msgType = r._msgType ? strdup(r._msgType) : nullptr; free((void *)_msg); _msg = r._msg ? strdup(r._msg) : nullptr; _verbosity = r._verbosity; _fileName = r._fileName; _lineNumber = r._lineNumber; _time = r._time; _processName = r._processName; _id = r._id; return *this; } sc_report::~sc_report() throw() { free((void *)_msgType); free((void *)_msg); } const char * sc_report::what() const throw() { return _what.c_str(); } const char * sc_report::get_message(int id) { auto it = sc_gem5::reportIdToMsgMap.find(id); if (it == sc_gem5::reportIdToMsgMap.end()) return "unknown id"; else return it->second.c_str(); } bool sc_report::is_suppressed(int id) { auto it = sc_gem5::reportIdToMsgMap.find(id); if (it == sc_gem5::reportIdToMsgMap.end()) return false; auto &msgInfo = sc_gem5::reportMsgInfoMap[it->second]; return (msgInfo.actions == SC_DO_NOTHING || (msgInfo.sevActions[SC_INFO] == SC_DO_NOTHING && msgInfo.sevActions[SC_WARNING] == SC_DO_NOTHING)); } void sc_report::make_warnings_errors(bool val) { sc_gem5::reportWarningsAsErrors = val; } void sc_report::register_id(int id, const char *msg) { if (id < 0) { SC_REPORT_ERROR(SC_ID_REGISTER_ID_FAILED_, "invalid report id"); return; } if (!msg) { SC_REPORT_ERROR(SC_ID_REGISTER_ID_FAILED_, "invalid report message"); return; } auto p = sc_gem5::reportIdToMsgMap.insert( std::pair(id, msg)); if (!p.second) { SC_REPORT_ERROR(SC_ID_REGISTER_ID_FAILED_, "report id already exists"); } else { sc_gem5::reportMsgInfoMap[msg].id = id; } } void sc_report::suppress_id(int id, bool suppress) { auto it = sc_gem5::reportIdToMsgMap.find(id); if (it == sc_gem5::reportIdToMsgMap.end()) return; if (suppress) { sc_gem5::reportMsgInfoMap[it->second]. sevActions[SC_INFO] = SC_DO_NOTHING; sc_gem5::reportMsgInfoMap[it->second]. sevActions[SC_WARNING] = SC_DO_NOTHING; } else { sc_gem5::reportMsgInfoMap[it->second]. sevActions[SC_INFO] = SC_UNSPECIFIED; sc_gem5::reportMsgInfoMap[it->second]. sevActions[SC_WARNING] = SC_UNSPECIFIED; } } void sc_report::suppress_infos(bool suppress) { if (suppress) sc_gem5::reportSevInfos[SC_INFO].actions = SC_DO_NOTHING; else sc_gem5::reportSevInfos[SC_INFO].actions = SC_DEFAULT_INFO_ACTIONS; } void sc_report::suppress_warnings(bool suppress) { if (suppress) { sc_gem5::reportSevInfos[SC_WARNING].actions = SC_DO_NOTHING; } else { sc_gem5::reportSevInfos[SC_WARNING].actions = SC_DEFAULT_WARNING_ACTIONS; } } void sc_abort() { panic("simulation aborted"); } } // namespace sc_core