gem5
v22.0.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
q
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
l
m
n
o
p
r
s
t
u
v
w
Typedefs
a
b
c
d
g
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
gpu-compute
pool_manager.hh
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2015-2017 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 met:
7
*
8
* 1. Redistributions of source code must retain the above copyright notice,
9
* this list of conditions and the following disclaimer.
10
*
11
* 2. Redistributions in binary form must reproduce the above copyright notice,
12
* this list of conditions and the following disclaimer in the documentation
13
* and/or other materials provided with the distribution.
14
*
15
* 3. Neither the name of the copyright holder nor the names of its
16
* contributors may be used to endorse or promote products derived from this
17
* software without specific prior written permission.
18
*
19
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29
* POSSIBILITY OF SUCH DAMAGE.
30
*/
31
32
#ifndef __POOL_MANAGER_HH__
33
#define __POOL_MANAGER_HH__
34
35
#include <cassert>
36
#include <cstdint>
37
#include <string>
38
39
#include "params/PoolManager.hh"
40
#include "
sim/sim_object.hh
"
41
42
namespace
gem5
43
{
44
45
// Pool Manager Logic
46
class
PoolManager
:
public
SimObject
47
{
48
public
:
49
PoolManager
(
const
PoolManagerParams &
p
);
50
virtual
~PoolManager
() {
_poolSize
= 0; }
51
uint32_t
minAllocation
() {
return
_minAllocation
; }
52
virtual
std::string
printRegion
() = 0;
53
virtual
uint32_t
regionSize
(
std::pair<uint32_t,uint32_t>
®ion) = 0;
54
virtual
bool
canAllocate
(uint32_t numRegions, uint32_t size) = 0;
55
56
virtual
uint32_t
allocateRegion
(
const
uint32_t size,
57
uint32_t *
reserved
) = 0;
58
59
virtual
void
freeRegion
(uint32_t firstIdx, uint32_t lastIdx) = 0;
60
uint32_t
poolSize
() {
return
_poolSize
; }
61
// I don't think with the current API it is possible to do what
62
// we intend to - reset the entire register pool.
63
// Because we need to reset the register pool when all WGs on
64
// the Compute Unit are finished - before launching WGs from
65
// another kernel.
66
// TsungTai Yeh added a virtual method do the very same - at a diff
67
// place though.
68
virtual
void
resetRegion
(
const
int
& regsPerSimd) {};
// do nothing
69
70
private
:
71
// minimum size that can be reserved per allocation
72
uint32_t
_minAllocation
;
73
// pool size in number of elements
74
uint32_t
_poolSize
;
75
};
76
77
}
// namespace gem5
78
79
#endif // __POOL_MANAGER_HH__
gem5::PoolManager::_poolSize
uint32_t _poolSize
Definition:
pool_manager.hh:74
gem5::PoolManager::allocateRegion
virtual uint32_t allocateRegion(const uint32_t size, uint32_t *reserved)=0
gem5::PoolManager::resetRegion
virtual void resetRegion(const int ®sPerSimd)
Definition:
pool_manager.hh:68
reserved
reserved
Definition:
pcireg.h:54
gem5::PoolManager::canAllocate
virtual bool canAllocate(uint32_t numRegions, uint32_t size)=0
gem5::VegaISA::p
Bitfield< 54 > p
Definition:
pagetable.hh:70
sim_object.hh
gem5::PoolManager::minAllocation
uint32_t minAllocation()
Definition:
pool_manager.hh:51
gem5::PoolManager::freeRegion
virtual void freeRegion(uint32_t firstIdx, uint32_t lastIdx)=0
gem5::PoolManager::regionSize
virtual uint32_t regionSize(std::pair< uint32_t, uint32_t > ®ion)=0
gem5::SimObject
Abstract superclass for simulation objects.
Definition:
sim_object.hh:146
gem5::PoolManager::_minAllocation
uint32_t _minAllocation
Definition:
pool_manager.hh:68
gem5::PoolManager
Definition:
pool_manager.hh:46
std::pair
STL pair class.
Definition:
stl.hh:58
gem5::PoolManager::printRegion
virtual std::string printRegion()=0
gem5::PoolManager::PoolManager
PoolManager(const PoolManagerParams &p)
Definition:
pool_manager.cc:37
gem5::PoolManager::~PoolManager
virtual ~PoolManager()
Definition:
pool_manager.hh:50
gem5::PoolManager::poolSize
uint32_t poolSize()
Definition:
pool_manager.hh:60
gem5
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Definition:
gpu_translation_state.hh:37
Generated on Thu Jun 16 2022 10:41:54 for gem5 by
doxygen
1.8.17