gem5
[DEVELOP-FOR-25.0]
Loading...
Searching...
No Matches
gpu-compute
scheduling_policy.hh
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2014-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 __GPU_COMPUTE_SCHEDULING_POLICY_HH__
33
#define __GPU_COMPUTE_SCHEDULING_POLICY_HH__
34
35
#include <vector>
36
37
namespace
gem5
38
{
39
40
class
Wavefront
;
41
45
class
SchedulingPolicy
46
{
47
public
:
48
SchedulingPolicy
() { }
49
virtual
Wavefront
*
chooseWave
(
std::vector<Wavefront*>
*sched_list) = 0;
50
};
51
60
template
<
typename
Policy>
61
class
__SchedulingPolicy
:
public
SchedulingPolicy
62
{
63
public
:
64
__SchedulingPolicy
() { }
65
66
Wavefront
*
67
chooseWave
(
std::vector<Wavefront*>
*sched_list)
override
68
{
69
return
Policy::__chooseWave(sched_list);
70
}
71
};
72
73
}
// namespace gem5
74
75
#endif
// __GPU_COMPUTE_SCHEDULING_POLICY_HH__
gem5::SchedulingPolicy::chooseWave
virtual Wavefront * chooseWave(std::vector< Wavefront * > *sched_list)=0
gem5::SchedulingPolicy::SchedulingPolicy
SchedulingPolicy()
Definition
scheduling_policy.hh:48
gem5::Wavefront
Definition
wavefront.hh:62
gem5::__SchedulingPolicy::chooseWave
Wavefront * chooseWave(std::vector< Wavefront * > *sched_list) override
Definition
scheduling_policy.hh:67
gem5::__SchedulingPolicy::__SchedulingPolicy
__SchedulingPolicy()
Definition
scheduling_policy.hh:64
std::vector
STL vector class.
Definition
stl.hh:37
gem5
Copyright (c) 2024 Arm Limited All rights reserved.
Definition
binary32.hh:36
Generated on Mon May 26 2025 09:19:11 for gem5 by
doxygen
1.13.2