sc_report.cc (13313:306a97d3b040) sc_report.cc (13314:d1f53683ab94)
1/*
2 * Copyright 2018 Google, Inc.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met: redistributions of source code must retain the above copyright
7 * notice, this list of conditions and the following disclaimer;
8 * redistributions in binary form must reproduce the above copyright
9 * notice, this list of conditions and the following disclaimer in the
10 * documentation and/or other materials provided with the distribution;
11 * neither the name of the copyright holders nor the names of its
12 * contributors may be used to endorse or promote products derived from
13 * this software without specific prior written permission.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
18 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
21 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 *
27 * Authors: Gabe Black
28 */
29
30#include <cstring>
31
32#include "base/logging.hh"
33#include "systemc/ext/utils/sc_report.hh"
34#include "systemc/ext/utils/sc_report_handler.hh"
35#include "systemc/utils/report.hh"
36
37namespace sc_core
38{
39
40sc_report::sc_report(sc_severity _severity, const char *msg_type,
41 const char *msg, int _verbosity, const char *_fileName,
42 int _lineNumber, sc_time _time, const char *_processName, int _id) :
43 _severity(_severity), _msgType(msg_type), _msg(msg),
44 _verbosity(_verbosity), _fileName(_fileName), _lineNumber(_lineNumber),
45 _time(_time), _processName(_processName), _id(_id)
46{
47 if (_msgType)
48 _msgType = strdup(_msgType);
49 if (_msg)
50 _msg = strdup(_msg);
51 _what = sc_report_compose_message(*this);
52}
53
54sc_report::sc_report(const sc_report &r) :
55 sc_report(r._severity, r._msgType, r._msg, r._verbosity, r._fileName,
56 r._lineNumber, r._time, r._processName, r._id)
57{}
58
59sc_report &
60sc_report::operator = (const sc_report &r)
61{
62 _severity = r._severity;
63 free((void *)_msgType);
64 _msgType = r._msgType ? strdup(r._msgType) : nullptr;
65 free((void *)_msg);
66 _msg = r._msg ? strdup(r._msg) : nullptr;
67 _verbosity = r._verbosity;
68 _fileName = r._fileName;
69 _lineNumber = r._lineNumber;
70 _time = r._time;
71 _processName = r._processName;
72 _id = r._id;
73 return *this;
74}
75
76sc_report::~sc_report() throw()
77{
78 free((void *)_msgType);
79 free((void *)_msg);
80}
81
82const char *
83sc_report::what() const throw()
84{
85 return _what.c_str();
86}
87
88const char *
89sc_report::get_message(int id)
90{
91 auto it = sc_gem5::reportIdToMsgMap.find(id);
92 if (it == sc_gem5::reportIdToMsgMap.end())
93 return "unknown id";
94 else
95 return it->second.c_str();
96}
97
98bool
99sc_report::is_suppressed(int id)
100{
101 auto it = sc_gem5::reportIdToMsgMap.find(id);
102 if (it == sc_gem5::reportIdToMsgMap.end())
103 return false;
104
1/*
2 * Copyright 2018 Google, Inc.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met: redistributions of source code must retain the above copyright
7 * notice, this list of conditions and the following disclaimer;
8 * redistributions in binary form must reproduce the above copyright
9 * notice, this list of conditions and the following disclaimer in the
10 * documentation and/or other materials provided with the distribution;
11 * neither the name of the copyright holders nor the names of its
12 * contributors may be used to endorse or promote products derived from
13 * this software without specific prior written permission.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
18 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
21 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 *
27 * Authors: Gabe Black
28 */
29
30#include <cstring>
31
32#include "base/logging.hh"
33#include "systemc/ext/utils/sc_report.hh"
34#include "systemc/ext/utils/sc_report_handler.hh"
35#include "systemc/utils/report.hh"
36
37namespace sc_core
38{
39
40sc_report::sc_report(sc_severity _severity, const char *msg_type,
41 const char *msg, int _verbosity, const char *_fileName,
42 int _lineNumber, sc_time _time, const char *_processName, int _id) :
43 _severity(_severity), _msgType(msg_type), _msg(msg),
44 _verbosity(_verbosity), _fileName(_fileName), _lineNumber(_lineNumber),
45 _time(_time), _processName(_processName), _id(_id)
46{
47 if (_msgType)
48 _msgType = strdup(_msgType);
49 if (_msg)
50 _msg = strdup(_msg);
51 _what = sc_report_compose_message(*this);
52}
53
54sc_report::sc_report(const sc_report &r) :
55 sc_report(r._severity, r._msgType, r._msg, r._verbosity, r._fileName,
56 r._lineNumber, r._time, r._processName, r._id)
57{}
58
59sc_report &
60sc_report::operator = (const sc_report &r)
61{
62 _severity = r._severity;
63 free((void *)_msgType);
64 _msgType = r._msgType ? strdup(r._msgType) : nullptr;
65 free((void *)_msg);
66 _msg = r._msg ? strdup(r._msg) : nullptr;
67 _verbosity = r._verbosity;
68 _fileName = r._fileName;
69 _lineNumber = r._lineNumber;
70 _time = r._time;
71 _processName = r._processName;
72 _id = r._id;
73 return *this;
74}
75
76sc_report::~sc_report() throw()
77{
78 free((void *)_msgType);
79 free((void *)_msg);
80}
81
82const char *
83sc_report::what() const throw()
84{
85 return _what.c_str();
86}
87
88const char *
89sc_report::get_message(int id)
90{
91 auto it = sc_gem5::reportIdToMsgMap.find(id);
92 if (it == sc_gem5::reportIdToMsgMap.end())
93 return "unknown id";
94 else
95 return it->second.c_str();
96}
97
98bool
99sc_report::is_suppressed(int id)
100{
101 auto it = sc_gem5::reportIdToMsgMap.find(id);
102 if (it == sc_gem5::reportIdToMsgMap.end())
103 return false;
104
105 return sc_gem5::reportMsgInfoMap[it->second].actions == SC_DO_NOTHING;
105 auto &msgInfo = sc_gem5::reportMsgInfoMap[it->second];
106
107 return (msgInfo.actions == SC_DO_NOTHING ||
108 (msgInfo.sevActions[SC_INFO] == SC_DO_NOTHING &&
109 msgInfo.sevActions[SC_WARNING] == SC_DO_NOTHING));
106}
107
108void
109sc_report::make_warnings_errors(bool val)
110{
111 sc_gem5::reportWarningsAsErrors = val;
112}
113
114void
115sc_report::register_id(int id, const char *msg)
116{
117 if (id < 0) {
118 SC_REPORT_ERROR("(E800) register_id failed", "invalid report id");
119 return;
120 }
121 if (!msg) {
122 SC_REPORT_ERROR("(E800) register_id failed", "invalid report message");
123 return;
124 }
125 auto p = sc_gem5::reportIdToMsgMap.insert(
126 std::pair<int, std::string>(id, msg));
127 if (!p.second) {
128 SC_REPORT_ERROR("(E800) register_id failed",
129 "report id already exists");
130 } else {
131 sc_gem5::reportMsgInfoMap[msg].id = id;
132 }
133}
134
135void
136sc_report::suppress_id(int id, bool suppress)
137{
138 auto it = sc_gem5::reportIdToMsgMap.find(id);
139 if (it == sc_gem5::reportIdToMsgMap.end())
140 return;
141
110}
111
112void
113sc_report::make_warnings_errors(bool val)
114{
115 sc_gem5::reportWarningsAsErrors = val;
116}
117
118void
119sc_report::register_id(int id, const char *msg)
120{
121 if (id < 0) {
122 SC_REPORT_ERROR("(E800) register_id failed", "invalid report id");
123 return;
124 }
125 if (!msg) {
126 SC_REPORT_ERROR("(E800) register_id failed", "invalid report message");
127 return;
128 }
129 auto p = sc_gem5::reportIdToMsgMap.insert(
130 std::pair<int, std::string>(id, msg));
131 if (!p.second) {
132 SC_REPORT_ERROR("(E800) register_id failed",
133 "report id already exists");
134 } else {
135 sc_gem5::reportMsgInfoMap[msg].id = id;
136 }
137}
138
139void
140sc_report::suppress_id(int id, bool suppress)
141{
142 auto it = sc_gem5::reportIdToMsgMap.find(id);
143 if (it == sc_gem5::reportIdToMsgMap.end())
144 return;
145
142 if (suppress)
143 sc_gem5::reportMsgInfoMap[it->second].actions = SC_DO_NOTHING;
144 else
145 sc_gem5::reportMsgInfoMap[it->second].actions = SC_UNSPECIFIED;
146 if (suppress) {
147 sc_gem5::reportMsgInfoMap[it->second].
148 sevActions[SC_INFO] = SC_DO_NOTHING;
149 sc_gem5::reportMsgInfoMap[it->second].
150 sevActions[SC_WARNING] = SC_DO_NOTHING;
151 } else {
152 sc_gem5::reportMsgInfoMap[it->second].
153 sevActions[SC_INFO] = SC_UNSPECIFIED;
154 sc_gem5::reportMsgInfoMap[it->second].
155 sevActions[SC_WARNING] = SC_UNSPECIFIED;
156 }
146}
147
148void
149sc_report::suppress_infos(bool suppress)
150{
151 if (suppress)
152 sc_gem5::reportSevInfos[SC_INFO].actions = SC_DO_NOTHING;
153 else
154 sc_gem5::reportSevInfos[SC_INFO].actions = SC_DEFAULT_INFO_ACTIONS;
155}
156
157void
158sc_report::suppress_warnings(bool suppress)
159{
160 if (suppress) {
161 sc_gem5::reportSevInfos[SC_WARNING].actions = SC_DO_NOTHING;
162 } else {
163 sc_gem5::reportSevInfos[SC_WARNING].actions =
164 SC_DEFAULT_WARNING_ACTIONS;
165 }
166}
167
168void
169sc_abort()
170{
171 panic("simulation aborted");
172}
173
174} // namespace sc_core
157}
158
159void
160sc_report::suppress_infos(bool suppress)
161{
162 if (suppress)
163 sc_gem5::reportSevInfos[SC_INFO].actions = SC_DO_NOTHING;
164 else
165 sc_gem5::reportSevInfos[SC_INFO].actions = SC_DEFAULT_INFO_ACTIONS;
166}
167
168void
169sc_report::suppress_warnings(bool suppress)
170{
171 if (suppress) {
172 sc_gem5::reportSevInfos[SC_WARNING].actions = SC_DO_NOTHING;
173 } else {
174 sc_gem5::reportSevInfos[SC_WARNING].actions =
175 SC_DEFAULT_WARNING_ACTIONS;
176 }
177}
178
179void
180sc_abort()
181{
182 panic("simulation aborted");
183}
184
185} // namespace sc_core