gem5
v21.0.1.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
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
c
d
e
f
g
h
i
m
n
o
p
r
s
t
u
v
w
x
Enumerations
a
c
d
e
f
i
l
m
o
p
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
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
Functions
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
z
Variables
_
a
b
c
d
e
f
g
h
i
j
l
m
n
o
p
r
s
t
u
v
Typedefs
_
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
u
v
w
Enumerations
_
a
b
c
d
e
f
g
h
i
l
m
o
p
q
r
s
t
v
Enumerator
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
Macros
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Modules
Pages
mem
ruby
network
garnet
flitBuffer.hh
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2008 Princeton University
3
* Copyright (c) 2016 Georgia Institute of Technology
4
* All rights reserved.
5
*
6
* Redistribution and use in source and binary forms, with or without
7
* modification, are permitted provided that the following conditions are
8
* met: redistributions of source code must retain the above copyright
9
* notice, this list of conditions and the following disclaimer;
10
* redistributions in binary form must reproduce the above copyright
11
* notice, this list of conditions and the following disclaimer in the
12
* documentation and/or other materials provided with the distribution;
13
* neither the name of the copyright holders nor the names of its
14
* contributors may be used to endorse or promote products derived from
15
* this software without specific prior written permission.
16
*
17
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
*/
29
30
31
#ifndef __MEM_RUBY_NETWORK_GARNET_0_FLITBUFFER_HH__
32
#define __MEM_RUBY_NETWORK_GARNET_0_FLITBUFFER_HH__
33
34
#include <algorithm>
35
#include <iostream>
36
#include <vector>
37
38
#include "
mem/ruby/network/garnet/CommonTypes.hh
"
39
#include "
mem/ruby/network/garnet/flit.hh
"
40
41
class
flitBuffer
42
{
43
public
:
44
flitBuffer
();
45
flitBuffer
(
int
maximum_size);
46
47
bool
isReady
(
Tick
curTime);
48
bool
isEmpty
();
49
void
print
(std::ostream& out)
const
;
50
bool
isFull
();
51
void
setMaxSize
(
int
maximum);
52
int
getSize
()
const
{
return
m_buffer
.size(); }
53
54
flit
*
55
getTopFlit
()
56
{
57
flit
*
f
=
m_buffer
.front();
58
std::pop_heap(
m_buffer
.begin(),
m_buffer
.end(),
flit::greater
);
59
m_buffer
.pop_back();
60
return
f
;
61
}
62
63
flit
*
64
peekTopFlit
()
65
{
66
return
m_buffer
.front();
67
}
68
69
void
70
insert
(
flit
*flt)
71
{
72
m_buffer
.push_back(flt);
73
std::push_heap(
m_buffer
.begin(),
m_buffer
.end(),
flit::greater
);
74
}
75
76
uint32_t
functionalWrite
(
Packet
*pkt);
77
78
private
:
79
std::vector<flit *>
m_buffer
;
80
int
max_size
;
81
};
82
83
inline
std::ostream&
84
operator<<
(std::ostream& out,
const
flitBuffer
& obj)
85
{
86
obj.
print
(out);
87
out << std::flush;
88
return
out;
89
}
90
91
#endif // __MEM_RUBY_NETWORK_GARNET_0_FLITBUFFER_HH__
flitBuffer
Definition:
flitBuffer.hh:41
operator<<
std::ostream & operator<<(std::ostream &out, const flitBuffer &obj)
Definition:
flitBuffer.hh:84
flit
Definition:
flit.hh:41
flitBuffer::flitBuffer
flitBuffer()
Definition:
flitBuffer.cc:34
flit::greater
static bool greater(flit *n1, flit *n2)
Definition:
flit.hh:90
Tick
uint64_t Tick
Tick count type.
Definition:
types.hh:59
std::vector< flit * >
CommonTypes.hh
flitBuffer::getTopFlit
flit * getTopFlit()
Definition:
flitBuffer.hh:55
flitBuffer::functionalWrite
uint32_t functionalWrite(Packet *pkt)
Definition:
flitBuffer.cc:80
flitBuffer::isEmpty
bool isEmpty()
Definition:
flitBuffer.cc:45
flitBuffer::isFull
bool isFull()
Definition:
flitBuffer.cc:68
flitBuffer::getSize
int getSize() const
Definition:
flitBuffer.hh:52
flitBuffer::max_size
int max_size
Definition:
flitBuffer.hh:80
flit.hh
flitBuffer::setMaxSize
void setMaxSize(int maximum)
Definition:
flitBuffer.cc:74
flitBuffer::insert
void insert(flit *flt)
Definition:
flitBuffer.hh:70
flitBuffer::isReady
bool isReady(Tick curTime)
Definition:
flitBuffer.cc:51
Packet
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Definition:
packet.hh:258
flitBuffer::print
void print(std::ostream &out) const
Definition:
flitBuffer.cc:62
flitBuffer::m_buffer
std::vector< flit * > m_buffer
Definition:
flitBuffer.hh:79
flitBuffer::peekTopFlit
flit * peekTopFlit()
Definition:
flitBuffer.hh:64
ArmISA::f
Bitfield< 6 > f
Definition:
miscregs_types.hh:64
Generated on Tue Jun 22 2021 15:28:29 for gem5 by
doxygen
1.8.17