gem5  v19.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
sc_port.cc
Go to the documentation of this file.
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 <sstream>
31 
32 #include "base/cprintf.hh"
33 #include "systemc/core/module.hh"
34 #include "systemc/core/port.hh"
39 
40 namespace sc_core
41 {
42 
43 namespace
44 {
45 
46 void
47 reportError(const char *id, const char *add_msg,
48  const char *name, const char *kind)
49 {
50  std::string msg;
51  if (add_msg)
52  msg = csprintf("%s: port '%s' (%s)", add_msg, name, kind);
53  else
54  msg = csprintf("port '%s' (%s)", name, kind);
55 
56  SC_REPORT_ERROR(id, msg.c_str());
57 }
58 
59 }
60 
61 sc_port_base::sc_port_base(const char *n, int max_size, sc_port_policy p) :
62  sc_object(n), _gem5Port(nullptr)
63 {
64  if (sc_is_running()) {
65  reportError(SC_ID_INSERT_PORT_, "simulation running",
66  name(), kind());
67  }
68  if (::sc_gem5::scheduler.elaborationDone()) {
69  reportError(SC_ID_INSERT_PORT_, "elaboration done",
70  name(), kind());
71  }
72 
74  if (!m)
75  reportError(SC_ID_PORT_OUTSIDE_MODULE_, nullptr, name(), kind());
76  else
77  m->ports.push_back(this);
78  _gem5Port = new ::sc_gem5::Port(this, max_size);
79 }
80 
82 {
83  delete _gem5Port;
84 }
85 
86 void
88 {
89  static bool warned = false;
90  if (!warned) {
92  "interface and/or port binding in port constructors "
93  "is deprecated");
94  warned = true;
95  }
96 }
97 
98 void
99 sc_port_base::report_error(const char *id, const char *add_msg) const
100 {
101  std::ostringstream ss;
102  if (add_msg)
103  ss << add_msg << ": ";
104  ss << "port '" << name() << "' (" << kind() << ")";
105  SC_REPORT_ERROR(id, ss.str().c_str());
106 }
107 
108 int sc_port_base::maxSize() const { return _gem5Port->maxSize(); }
109 int sc_port_base::size() const { return _gem5Port->size(); }
110 
113 
114 } // namespace sc_core
bool sc_is_running()
Definition: sc_main.cc:144
const std::string & name()
Definition: trace.cc:54
Bitfield< 7 > i
Bitfield< 0 > m
const char * kind() const
Definition: sc_port.hh:87
const char * name() const
Definition: sc_object.cc:46
#define SC_REPORT_INFO(msg_type, msg)
void report_error(const char *id, const char *add_msg) const
Definition: sc_port.cc:99
Bitfield< 31 > n
const char SC_ID_INSERT_PORT_[]
Definition: messages.cc:49
int size() const
Definition: sc_port.cc:109
const char SC_ID_PORT_OUTSIDE_MODULE_[]
Definition: messages.cc:36
sc_port_base(const char *name, int n, sc_port_policy p)
Definition: sc_port.cc:61
std::string csprintf(const char *format, const Args &...args)
Definition: cprintf.hh:162
int maxSize() const
Definition: sc_port.cc:108
Bitfield< 21 > ss
virtual ~sc_port_base()
Definition: sc_port.cc:81
Scheduler scheduler
Definition: scheduler.cc:491
sc_port_policy
Definition: sc_port.hh:69
void warn_port_constructor() const
Definition: sc_port.cc:87
void bind(::sc_core::sc_interface *interface)
Definition: port.hh:140
#define SC_REPORT_ERROR(msg_type, msg)
int size()
Definition: port.hh:161
static Module * pickParentModule()
Definition: module.hh:143
::sc_gem5::Port * _gem5Port
Definition: sc_port.hh:114
Bitfield< 0 > p
const char SC_ID_IEEE_1666_DEPRECATION_[]
Definition: messages.cc:50
void bind(sc_interface &)
Definition: sc_port.cc:111
int maxSize()
Definition: port.hh:162

Generated on Fri Feb 28 2020 16:27:03 for gem5 by doxygen 1.8.13