gem5
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
pyobject.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2017 ARM Limited
3  * All rights reserved
4  *
5  * The license below extends only to copyright in the software and shall
6  * not be construed as granting a license to any other intellectual
7  * property including but not limited to intellectual property relating
8  * to a hardware implementation of the functionality of the software
9  * licensed hereunder. You may use the software subject to the license
10  * terms below provided that you ensure that this notice is replicated
11  * unmodified and in its entirety in all distributions of the software,
12  * modified or unmodified, in source code or in binary form.
13  *
14  * Copyright (c) 2006 The Regents of The University of Michigan
15  * All rights reserved.
16  *
17  * Redistribution and use in source and binary forms, with or without
18  * modification, are permitted provided that the following conditions are
19  * met: redistributions of source code must retain the above copyright
20  * notice, this list of conditions and the following disclaimer;
21  * redistributions in binary form must reproduce the above copyright
22  * notice, this list of conditions and the following disclaimer in the
23  * documentation and/or other materials provided with the distribution;
24  * neither the name of the copyright holders nor the names of its
25  * contributors may be used to endorse or promote products derived from
26  * this software without specific prior written permission.
27  *
28  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
29  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
30  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
31  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
32  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
33  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
34  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
35  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
36  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
38  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39  *
40  * Authors: Nathan Binkert
41  */
42 
43 #include "pybind11/pybind11.h"
44 
45 #include <string>
46 
47 #include "config/the_isa.hh"
48 
49 #if THE_ISA != NULL_ISA
50 #include "dev/net/etherdevice.hh"
51 #include "dev/net/etherint.hh"
52 #include "dev/net/etherobject.hh"
53 
54 #endif
55 
56 #include "mem/mem_object.hh"
58 #include "sim/full_system.hh"
59 
60 namespace py = pybind11;
61 
62 #if THE_ISA != NULL_ISA
63 static EtherInt *
64 lookupEthPort(SimObject *so, const std::string &name, int i)
65 {
66  EtherObject *eo = dynamic_cast<EtherObject *>(so);
67  EtherDevice *ed = dynamic_cast<EtherDevice *>(so);
68  if (eo == NULL && ed == NULL) {
69  warn("error casting SimObject %s", so->name());
70  return NULL;
71  }
72 
73  EtherInt *p = NULL;
74  if (eo)
75  p = eo->getEthPort(name, i);
76  else
77  p = ed->getEthPort(name, i);
78  return p;
79 }
80 #endif
81 
87 static int
88 connectPorts(SimObject *o1, const std::string &name1, int i1,
89  SimObject *o2, const std::string &name2, int i2)
90 {
91 #if THE_ISA != NULL_ISA
92  EtherObject *eo1, *eo2;
93  EtherDevice *ed1, *ed2;
94  eo1 = dynamic_cast<EtherObject*>(o1);
95  ed1 = dynamic_cast<EtherDevice*>(o1);
96  eo2 = dynamic_cast<EtherObject*>(o2);
97  ed2 = dynamic_cast<EtherDevice*>(o2);
98 
99  if ((eo1 || ed1) && (eo2 || ed2)) {
100  EtherInt *p1 = lookupEthPort(o1, name1, i1);
101  EtherInt *p2 = lookupEthPort(o2, name2, i2);
102 
103  if (p1 != NULL && p2 != NULL) {
104 
105  p1->setPeer(p2);
106  p2->setPeer(p1);
107 
108  return 1;
109  }
110  }
111 #endif
112 
113  // These could be MessageBuffers from the ruby memory system. If so, they
114  // need not be connected to anything currently.
115  MessageBuffer *mb1, *mb2;
116  mb1 = dynamic_cast<MessageBuffer*>(o1);
117  mb2 = dynamic_cast<MessageBuffer*>(o2);
118 
119  if (mb1 || mb2) {
120  // No need to connect anything here currently. MessageBuffer
121  // connections in Python only serve to print the connections in
122  // the config output.
123  // TODO: Add real ports to MessageBuffers and use MemObject connect
124  // code below to bind MessageBuffer senders and receivers
125  return 1;
126  }
127 
128  MemObject *mo1, *mo2;
129  mo1 = dynamic_cast<MemObject*>(o1);
130  mo2 = dynamic_cast<MemObject*>(o2);
131 
132  if (mo1 == NULL || mo2 == NULL) {
133  panic ("Error casting SimObjects %s and %s to MemObject", o1->name(),
134  o2->name());
135  }
136 
137  // generic master/slave port connection
138  BaseMasterPort& masterPort = mo1->getMasterPort(name1, i1);
139  BaseSlavePort& slavePort = mo2->getSlavePort(name2, i2);
140 
141  masterPort.bind(slavePort);
142 
143  return 1;
144 }
145 
146 void
147 pybind_init_pyobject(py::module &m_native)
148 {
149  py::module m = m_native.def_submodule("pyobject");
150 
151  m.def("connectPorts", &connectPorts);
152 }
void setPeer(EtherInt *p)
Definition: etherint.cc:37
const std::string & name()
Definition: trace.cc:49
Bitfield< 7 > i
Definition: miscregs.hh:1378
Bitfield< 0 > m
Definition: miscregs.hh:1577
#define panic(...)
Definition: misc.hh:153
Bitfield< 29 > ed
MemObject declaration.
virtual BaseSlavePort & getSlavePort(const std::string &if_name, PortID idx=InvalidPortID)
Get a slave port with a given name and index.
Definition: mem_object.cc:58
A BaseSlavePort is a protocol-agnostic slave port, responsible only for the structural connection to ...
Definition: port.hh:139
Bitfield< 28 > so
Definition: miscregs.hh:51
virtual EtherInt * getEthPort(const std::string &if_name, int idx=-1)=0
Additional function to return the Port of a memory object.
#define warn(...)
Definition: misc.hh:219
void pybind_init_pyobject(py::module &m_native)
Definition: pyobject.cc:147
virtual EtherInt * getEthPort(const std::string &if_name, int idx=-1)=0
Additional function to return the Port of a memory object.
The base EtherObject class, allows for an accesor function to a simobj that returns the Port...
Definition: etherobject.hh:48
Base Ethernet Device declaration.
virtual const std::string name() const
Definition: sim_object.hh:117
virtual void bind(BaseSlavePort &slave_port)=0
The MemObject class extends the ClockedObject with accessor functions to get its master and slave por...
Definition: mem_object.hh:60
A BaseMasterPort is a protocol-agnostic master port, responsible only for the structural connection t...
Definition: port.hh:115
The base EtherObject class, allows for an accesor function to a simobj that returns the Port...
Definition: etherdevice.hh:51
Bitfield< 0 > p
static int connectPorts(SimObject *o1, const std::string &name1, int i1, SimObject *o2, const std::string &name2, int i2)
Connect the described MemObject ports.
Definition: pyobject.cc:88
virtual BaseMasterPort & getMasterPort(const std::string &if_name, PortID idx=InvalidPortID)
Get a master port with a given name and index.
Definition: mem_object.cc:52
Abstract superclass for simulation objects.
Definition: sim_object.hh:94
Base Ethernet Object declaration.

Generated on Fri Jun 9 2017 13:03:51 for gem5 by doxygen 1.8.6