gem5
v21.2.1.1
mem
ruby
structures
BankedArray.hh
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2012 Advanced Micro Devices, Inc.
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: redistributions of source code must retain the above copyright
8
* notice, this list of conditions and the following disclaimer;
9
* redistributions in binary form must reproduce the above copyright
10
* notice, this list of conditions and the following disclaimer in the
11
* documentation and/or other materials provided with the distribution;
12
* neither the name of the copyright holders nor the names of its
13
* contributors may be used to endorse or promote products derived from
14
* this software without specific prior written permission.
15
*
16
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
*
28
* Author: Brad Beckmann
29
*
30
*/
31
32
#ifndef __MEM_RUBY_STRUCTURES_BANKEDARRAY_HH__
33
#define __MEM_RUBY_STRUCTURES_BANKEDARRAY_HH__
34
35
#include <vector>
36
37
#include "
mem/ruby/common/TypeDefines.hh
"
38
#include "
mem/ruby/system/RubySystem.hh
"
39
40
namespace
gem5
41
{
42
43
namespace
ruby
44
{
45
46
class
BankedArray
47
{
48
private
:
49
unsigned
int
banks
;
50
Cycles
accessLatency
;
51
unsigned
int
bankBits
;
52
unsigned
int
startIndexBit
;
53
RubySystem
*
m_ruby_system
;
54
55
class
AccessRecord
56
{
57
public
:
58
AccessRecord
() :
idx
(0),
startAccess
(0),
endAccess
(0) {}
59
int64_t
idx
;
60
Tick
startAccess
;
61
Tick
endAccess
;
62
};
63
64
// If the tick event is scheduled then the bank is busy
65
// otherwise, schedule the event and wait for it to complete
66
std::vector<AccessRecord>
busyBanks
;
67
68
unsigned
int
mapIndexToBank
(int64_t idx);
69
70
public
:
71
BankedArray
(
unsigned
int
banks
,
Cycles
accessLatency
,
72
unsigned
int
startIndexBit
,
RubySystem
*
rs
);
73
74
// Note: We try the access based on the cache index, not the address
75
// This is so we don't get aliasing on blocks being replaced
76
bool
tryAccess
(int64_t idx);
77
78
void
reserve
(int64_t idx);
79
80
Cycles
getLatency
()
const
{
return
accessLatency
; }
81
};
82
83
}
// namespace ruby
84
}
// namespace gem5
85
86
#endif
gem5::ruby::BankedArray::startIndexBit
unsigned int startIndexBit
Definition:
BankedArray.hh:52
gem5::ruby::BankedArray
Definition:
BankedArray.hh:46
gem5::ruby::BankedArray::bankBits
unsigned int bankBits
Definition:
BankedArray.hh:51
gem5::ruby::BankedArray::accessLatency
Cycles accessLatency
Definition:
BankedArray.hh:50
gem5::ruby::BankedArray::getLatency
Cycles getLatency() const
Definition:
BankedArray.hh:80
std::vector
STL vector class.
Definition:
stl.hh:37
gem5::ruby::BankedArray::mapIndexToBank
unsigned int mapIndexToBank(int64_t idx)
Definition:
BankedArray.cc:102
gem5::ruby::BankedArray::m_ruby_system
RubySystem * m_ruby_system
Definition:
BankedArray.hh:53
gem5::Cycles
Cycles is a wrapper class for representing cycle counts, i.e.
Definition:
types.hh:78
gem5::ruby::BankedArray::AccessRecord
Definition:
BankedArray.hh:55
gem5::ruby::BankedArray::AccessRecord::endAccess
Tick endAccess
Definition:
BankedArray.hh:61
gem5::ruby::BankedArray::AccessRecord::idx
int64_t idx
Definition:
BankedArray.hh:59
TypeDefines.hh
gem5::Tick
uint64_t Tick
Tick count type.
Definition:
types.hh:58
gem5::ruby::BankedArray::BankedArray
BankedArray(unsigned int banks, Cycles accessLatency, unsigned int startIndexBit, RubySystem *rs)
Definition:
BankedArray.cc:44
RubySystem.hh
gem5::ruby::BankedArray::AccessRecord::AccessRecord
AccessRecord()
Definition:
BankedArray.hh:58
gem5::ruby::BankedArray::banks
unsigned int banks
Definition:
BankedArray.hh:49
gem5::ruby::BankedArray::tryAccess
bool tryAccess(int64_t idx)
Definition:
BankedArray.cc:60
gem5::ruby::RubySystem
Definition:
RubySystem.hh:63
gem5::ruby::BankedArray::AccessRecord::startAccess
Tick startAccess
Definition:
BankedArray.hh:60
gem5::ruby::BankedArray::reserve
void reserve(int64_t idx)
Definition:
BankedArray.cc:76
gem5::ruby::BankedArray::busyBanks
std::vector< AccessRecord > busyBanks
Definition:
BankedArray.hh:66
gem5
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Definition:
tlb.cc:60
gem5::ArmISA::rs
Bitfield< 9, 8 > rs
Definition:
misc_types.hh:377
Generated on Wed May 4 2022 12:14:01 for gem5 by
doxygen
1.8.17