gem5
v24.0.0.0
Loading...
Searching...
No Matches
mem
ruby
network
garnet
Credit.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_CREDIT_HH__
32
#define __MEM_RUBY_NETWORK_GARNET_0_CREDIT_HH__
33
34
#include <cassert>
35
#include <iostream>
36
37
#include "
base/types.hh
"
38
#include "
mem/ruby/network/garnet/CommonTypes.hh
"
39
#include "
mem/ruby/network/garnet/flit.hh
"
40
41
namespace
gem5
42
{
43
44
namespace
ruby
45
{
46
47
namespace
garnet
48
{
49
50
// Credit Signal for buffers inside VC
51
// Carries m_vc (inherits from flit.hh)
52
// and m_is_free_signal (whether VC is free or not)
53
54
class
Credit
:
public
flit
55
{
56
public
:
57
Credit
() {};
58
Credit
(
int
vc,
bool
is_free_signal
,
Tick
curTime);
59
60
// Functions used by SerDes
61
flit
*
serialize
(
int
ser_id,
int
parts, uint32_t bWidth);
62
flit
*
deserialize
(
int
des_id,
int
num_flits, uint32_t bWidth);
63
void
print
(std::ostream& out)
const
;
64
65
~Credit
() {};
66
67
bool
is_free_signal
() {
return
m_is_free_signal
; }
68
69
private
:
70
bool
m_is_free_signal
;
71
};
72
73
}
// namespace garnet
74
}
// namespace ruby
75
}
// namespace gem5
76
77
#endif
// __MEM_RUBY_NETWORK_GARNET_0_CREDIT_HH__
CommonTypes.hh
types.hh
Defines global host-dependent types: Counter, Tick, and (indirectly) {int,uint}{8,...
gem5::ruby::garnet::Credit
Definition
Credit.hh:55
gem5::ruby::garnet::Credit::is_free_signal
bool is_free_signal()
Definition
Credit.hh:67
gem5::ruby::garnet::Credit::Credit
Credit()
Definition
Credit.hh:57
gem5::ruby::garnet::Credit::~Credit
~Credit()
Definition
Credit.hh:65
gem5::ruby::garnet::Credit::print
void print(std::ostream &out) const
Definition
Credit.cc:82
gem5::ruby::garnet::Credit::m_is_free_signal
bool m_is_free_signal
Definition
Credit.hh:70
gem5::ruby::garnet::Credit::serialize
flit * serialize(int ser_id, int parts, uint32_t bWidth)
Definition
Credit.cc:56
gem5::ruby::garnet::Credit::deserialize
flit * deserialize(int des_id, int num_flits, uint32_t bWidth)
Definition
Credit.cc:68
gem5::ruby::garnet::flit
Definition
flit.hh:51
flit.hh
gem5
Copyright (c) 2024 - Pranith Kumar Copyright (c) 2020 Inria All rights reserved.
Definition
binary32.hh:36
gem5::Tick
uint64_t Tick
Tick count type.
Definition
types.hh:58
Generated on Tue Jun 18 2024 16:24:05 for gem5 by
doxygen
1.11.0