gem5
v20.1.0.0
mem
ruby
network
garnet
Credit.cc
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
#include "
mem/ruby/network/garnet/Credit.hh
"
31
32
#include "
base/trace.hh
"
33
#include "debug/RubyNetwork.hh"
34
35
// Credit Signal for buffers inside VC
36
// Carries m_vc (inherits from flit.hh)
37
// and m_is_free_signal (whether VC is free or not)
38
39
Credit::Credit
(
int
vc,
bool
is_free_signal,
Tick
curTime)
40
:
flit
(0, vc, 0,
RouteInfo
(), 0, nullptr, 0, 0, curTime)
41
{
42
m_is_free_signal
=
is_free_signal
;
43
m_type
=
CREDIT_
;
44
}
45
46
flit
*
47
Credit::serialize
(
int
ser_id,
int
parts, uint32_t bWidth)
48
{
49
DPRINTF
(RubyNetwork,
"Serializing a credit\n"
);
50
bool
new_free =
false
;
51
if
((ser_id+1 == parts) &&
m_is_free_signal
) {
52
new_free =
true
;
53
}
54
Credit
*new_credit_flit =
new
Credit
(
m_vc
, new_free,
m_time
);
55
return
new_credit_flit;
56
}
57
58
flit
*
59
Credit::deserialize
(
int
des_id,
int
num_flits, uint32_t bWidth)
60
{
61
DPRINTF
(RubyNetwork,
"DeSerializing a credit vc:%d free:%d\n"
,
62
m_vc
,
m_is_free_signal
);
63
if
(
m_is_free_signal
) {
64
// We are not going to get anymore credits for this vc
65
// So send a credit in any case
66
return
new
Credit
(
m_vc
,
true
,
m_time
);
67
}
68
69
return
new
Credit
(
m_vc
,
false
,
m_time
);
70
}
71
72
void
73
Credit::print
(std::ostream& out)
const
74
{
75
out <<
"[Credit:: "
;
76
out <<
"Type="
<<
m_type
<<
" "
;
77
out <<
"VC="
<<
m_vc
<<
" "
;
78
out <<
"FreeVC="
<<
m_is_free_signal
<<
" "
;
79
out <<
"Set Time="
<<
m_time
<<
" "
;
80
out <<
"]"
;
81
}
82
83
84
Credit::m_is_free_signal
bool m_is_free_signal
Definition:
Credit.hh:61
flit
Definition:
flit.hh:41
RouteInfo
Definition:
CommonTypes.hh:47
Tick
uint64_t Tick
Tick count type.
Definition:
types.hh:63
Credit::is_free_signal
bool is_free_signal()
Definition:
Credit.hh:58
Credit::Credit
Credit()
Definition:
Credit.hh:48
Credit
Definition:
Credit.hh:45
flit::m_time
Tick m_time
Definition:
flit.hh:114
CREDIT_
@ CREDIT_
Definition:
CommonTypes.hh:39
DPRINTF
#define DPRINTF(x,...)
Definition:
trace.hh:234
flit::m_vc
int m_vc
Definition:
flit.hh:110
Credit::deserialize
flit * deserialize(int des_id, int num_flits, uint32_t bWidth)
Definition:
Credit.cc:59
flit::m_type
flit_type m_type
Definition:
flit.hh:115
Credit::serialize
flit * serialize(int ser_id, int parts, uint32_t bWidth)
Definition:
Credit.cc:47
Credit.hh
Credit::print
void print(std::ostream &out) const
Definition:
Credit.cc:73
trace.hh
Generated on Wed Sep 30 2020 14:02:13 for gem5 by
doxygen
1.8.17