gem5
v21.2.0.0
Main Page
Related Pages
Modules
Namespaces
Namespace List
Namespace Members
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Functions
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Variables
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Typedefs
_
a
b
c
d
e
f
g
h
i
l
m
n
o
p
r
s
t
u
v
w
x
Enumerations
_
a
b
c
d
e
f
g
h
i
k
l
m
o
p
q
r
s
t
v
x
Enumerator
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
Classes
Class List
Class Index
Class Hierarchy
Class Members
All
:
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
Functions
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
Variables
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Typedefs
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
y
Enumerations
a
b
c
d
e
f
g
h
i
l
m
n
o
p
r
s
t
u
w
Enumerator
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
Related Functions
:
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
Files
File List
File Members
All
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
Functions
a
b
c
d
e
f
g
h
i
l
m
n
o
p
s
t
v
Variables
a
b
c
d
e
f
g
h
i
m
n
o
p
r
s
t
v
w
Typedefs
a
b
c
d
h
i
l
m
r
s
t
u
w
Enumerations
b
h
i
o
p
Enumerator
h
i
o
Macros
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Modules
Pages
systemc
tlm_bridge
sc_mm.hh
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2015, University of Kaiserslautern
3
* All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions are
7
* met:
8
*
9
* 1. Redistributions of source code must retain the above copyright notice,
10
* this list of conditions and the following disclaimer.
11
*
12
* 2. Redistributions in binary form must reproduce the above copyright
13
* notice, this list of conditions and the following disclaimer in the
14
* documentation and/or other materials provided with the distribution.
15
*
16
* 3. Neither the name of the copyright holder nor the names of its
17
* contributors may be used to endorse or promote products derived from
18
* this software without specific prior written permission.
19
*
20
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
22
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
23
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER
24
* OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
26
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
27
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
28
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
29
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
30
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31
*/
32
33
#ifndef __SYSTEMC_TLM_BRIDGE_SC_MM_HH__
34
#define __SYSTEMC_TLM_BRIDGE_SC_MM_HH__
35
36
#include <vector>
37
38
#include "
systemc/ext/tlm_core/2/generic_payload/gp.hh
"
39
40
namespace
Gem5SystemC
41
{
42
43
typedef
tlm::tlm_generic_payload
gp
;
44
45
class
MemoryManager
:
public
tlm::tlm_mm_interface
46
{
47
public
:
48
MemoryManager
();
49
virtual
~MemoryManager
();
50
virtual
gp
*
allocate
();
51
virtual
void
free
(
gp
*payload);
52
53
private
:
54
unsigned
int
numberOfAllocations
;
55
unsigned
int
numberOfFrees
;
56
std::vector<gp *>
freePayloads
;
57
};
58
59
}
// namespace Gem5SystemC
60
61
#endif // __SYSTEMC_TLM_BRIDGE_SC_MM_HH__
Gem5SystemC::gp
tlm::tlm_generic_payload gp
Definition:
sc_mm.hh:43
Gem5SystemC::MemoryManager
Definition:
sc_mm.hh:45
Gem5SystemC::MemoryManager::MemoryManager
MemoryManager()
Definition:
sc_mm.cc:38
std::vector
STL vector class.
Definition:
stl.hh:37
Gem5SystemC::MemoryManager::free
virtual void free(gp *payload)
Definition:
sc_mm.cc:62
Gem5SystemC
Definition:
sc_ext.cc:40
Gem5SystemC::MemoryManager::numberOfFrees
unsigned int numberOfFrees
Definition:
sc_mm.hh:55
Gem5SystemC::MemoryManager::allocate
virtual gp * allocate()
Definition:
sc_mm.cc:49
tlm::tlm_generic_payload
Definition:
gp.hh:133
Gem5SystemC::MemoryManager::freePayloads
std::vector< gp * > freePayloads
Definition:
sc_mm.hh:56
Gem5SystemC::MemoryManager::numberOfAllocations
unsigned int numberOfAllocations
Definition:
sc_mm.hh:54
tlm::tlm_mm_interface
Definition:
gp.hh:50
Gem5SystemC::MemoryManager::~MemoryManager
virtual ~MemoryManager()
Definition:
sc_mm.cc:40
gp.hh
Generated on Tue Dec 21 2021 11:34:41 for gem5 by
doxygen
1.8.17