gem5 [DEVELOP-FOR-25.0]
Loading...
Searching...
No Matches
dep_graph.hh
Go to the documentation of this file.
1/*
2 * Copyright (c) 2012 ARM Limited
3 * All rights reserved
4 *
5 * The license below extends only to copyright in the software and shall
6 * not be construed as granting a license to any other intellectual
7 * property including but not limited to intellectual property relating
8 * to a hardware implementation of the functionality of the software
9 * licensed hereunder. You may use the software subject to the license
10 * terms below provided that you ensure that this notice is replicated
11 * unmodified and in its entirety in all distributions of the software,
12 * modified or unmodified, in source code or in binary form.
13 *
14 * Copyright (c) 2006 The Regents of The University of Michigan
15 * All rights reserved.
16 *
17 * Redistribution and use in source and binary forms, with or without
18 * modification, are permitted provided that the following conditions are
19 * met: redistributions of source code must retain the above copyright
20 * notice, this list of conditions and the following disclaimer;
21 * redistributions in binary form must reproduce the above copyright
22 * notice, this list of conditions and the following disclaimer in the
23 * documentation and/or other materials provided with the distribution;
24 * neither the name of the copyright holders nor the names of its
25 * contributors may be used to endorse or promote products derived from
26 * this software without specific prior written permission.
27 *
28 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
29 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
30 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
31 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
32 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
33 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
34 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
35 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
36 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
38 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39 */
40
41#ifndef __CPU_O3_DEP_GRAPH_HH__
42#define __CPU_O3_DEP_GRAPH_HH__
43
44#include "cpu/o3/comm.hh"
45
46namespace gem5
47{
48
49namespace o3
50{
51
53template <class DynInstPtr>
55{
56 public:
58 : inst(NULL), next(NULL)
59 { }
60
62 //Might want to include data about what arch. register the
63 //dependence is waiting on.
65};
66
76template <class DynInstPtr>
78{
79 public:
81
86
88
90 void resize(int num_entries);
91
93 void reset();
94
96 void insert(RegIndex idx, const DynInstPtr &new_inst);
97
99 void setInst(RegIndex idx, const DynInstPtr &new_inst)
100 { dependGraph[idx].inst = new_inst; }
101
104 { dependGraph[idx].inst = NULL; }
105
107 void remove(RegIndex idx, const DynInstPtr &inst_to_remove);
108
111
113 bool empty() const;
114
116 bool empty(RegIndex idx) const { return !dependGraph[idx].next; }
117
120 void dump();
121
122 private:
130
133
134 // Debug variable, remove when done testing.
136
137 public:
138 // Debug variable, remove when done testing.
140 // Debug variable, remove when done testing.
141 uint64_t nodesRemoved;
142};
143
144template <class DynInstPtr>
148
149template <class DynInstPtr>
150void
152{
153 numEntries = num_entries;
154 dependGraph.resize(numEntries);
155}
156
157template <class DynInstPtr>
158void
160{
161 // Clear the dependency graph
162 DepEntry *curr;
163 DepEntry *prev;
164
165 for (int i = 0; i < numEntries; ++i) {
166 curr = dependGraph[i].next;
167
168 while (curr) {
170
171 prev = curr;
172 curr = prev->next;
173 prev->inst = NULL;
174
175 delete prev;
176 }
177
178 if (dependGraph[i].inst) {
179 dependGraph[i].inst = NULL;
180 }
181
182 dependGraph[i].next = NULL;
183 }
184}
185
186template <class DynInstPtr>
187void
189{
190 //Add this new, dependent instruction at the head of the dependency
191 //chain.
192
193 // First create the entry that will be added to the head of the
194 // dependency chain.
195 DepEntry *new_entry = new DepEntry;
196 new_entry->next = dependGraph[idx].next;
197 new_entry->inst = new_inst;
198
199 // Then actually add it to the chain.
200 dependGraph[idx].next = new_entry;
201
203}
204
205
206template <class DynInstPtr>
207void
209 const DynInstPtr &inst_to_remove)
210{
211 DepEntry *prev = &dependGraph[idx];
212 DepEntry *curr = dependGraph[idx].next;
213
214 // Make sure curr isn't NULL. Because this instruction is being
215 // removed from a dependency list, it must have been placed there at
216 // an earlier time. The dependency chain should not be empty,
217 // unless the instruction dependent upon it is already ready.
218 if (curr == NULL) {
219 return;
220 }
221
222 nodesRemoved++;
223
224 // Find the instruction to remove within the dependency linked list.
225 while (curr->inst != inst_to_remove) {
226 prev = curr;
227 curr = curr->next;
229
230 assert(curr != NULL);
231 }
232
233 // Now remove this instruction from the list.
234 prev->next = curr->next;
235
237
238 // Could push this off to the destructor of DependencyEntry
239 curr->inst = NULL;
240
241 delete curr;
242}
243
244template <class DynInstPtr>
247{
248 DepEntry *node;
249 node = dependGraph[idx].next;
250 DynInstPtr inst = NULL;
251 if (node) {
252 inst = node->inst;
253 dependGraph[idx].next = node->next;
254 node->inst = NULL;
256 delete node;
257 }
258 return inst;
259}
260
261template <class DynInstPtr>
262bool
264{
265 for (int i = 0; i < numEntries; ++i) {
266 if (!empty(i))
267 return false;
268 }
269 return true;
270}
271
272template <class DynInstPtr>
273void
275{
276 DepEntry *curr;
277
278 for (int i = 0; i < numEntries; ++i)
279 {
280 curr = &dependGraph[i];
281
282 if (curr->inst) {
283 cprintf("dependGraph[%i]: producer: %s [sn:%lli] consumer: ",
284 i, curr->inst->pcState(), curr->inst->seqNum);
285 } else {
286 cprintf("dependGraph[%i]: No producer. consumer: ", i);
287 }
288
289 while (curr->next != NULL) {
290 curr = curr->next;
291
292 cprintf("%s [sn:%lli] ",
293 curr->inst->pcState(), curr->inst->seqNum);
294 }
295
296 cprintf("\n");
297 }
298 cprintf("memAllocCounter: %i\n", memAllocCounter);
299}
300
301} // namespace o3
302} // namespace gem5
303
304#endif // __CPU_O3_DEP_GRAPH_HH__
Node in a linked list.
Definition dep_graph.hh:55
DependencyEntry< DynInstPtr > * next
Definition dep_graph.hh:64
void clearInst(RegIndex idx)
Clears the producing instruction.
Definition dep_graph.hh:103
DependencyGraph()
Default construction.
Definition dep_graph.hh:83
void insert(RegIndex idx, const DynInstPtr &new_inst)
Inserts an instruction to be dependent on the given index.
Definition dep_graph.hh:188
bool empty(RegIndex idx) const
Checks if there are any dependents on a specific register.
Definition dep_graph.hh:116
bool empty() const
Checks if the entire dependency graph is empty.
Definition dep_graph.hh:263
void remove(RegIndex idx, const DynInstPtr &inst_to_remove)
Removes an instruction from a single linked list.
Definition dep_graph.hh:208
void reset()
Clears all of the linked lists.
Definition dep_graph.hh:159
int numEntries
Number of linked lists; identical to the number of registers.
Definition dep_graph.hh:132
DynInstPtr pop(RegIndex idx)
Removes and returns the newest dependent of a specific register.
Definition dep_graph.hh:246
void resize(int num_entries)
Resize the dependency graph to have num_entries registers.
Definition dep_graph.hh:151
std::vector< DepEntry > dependGraph
Array of linked lists.
Definition dep_graph.hh:129
void setInst(RegIndex idx, const DynInstPtr &new_inst)
Sets the producing instruction of a given register.
Definition dep_graph.hh:99
void dump()
Debugging function to dump out the dependency graph.
Definition dep_graph.hh:274
DependencyEntry< DynInstPtr > DepEntry
Definition dep_graph.hh:80
const PCStateBase & pcState() const override
Read the PC state of this instruction.
Definition dyn_inst.hh:897
InstSeqNum seqNum
The sequence number of the instruction.
Definition dyn_inst.hh:124
STL vector class.
Definition stl.hh:37
Bitfield< 7 > i
Definition misc_types.hh:67
RefCountingPtr< DynInst > DynInstPtr
Copyright (c) 2024 Arm Limited All rights reserved.
Definition binary32.hh:36
uint16_t RegIndex
Definition types.hh:176
void cprintf(const char *format, const Args &...args)
Definition cprintf.hh:155

Generated on Mon May 26 2025 09:19:08 for gem5 by doxygen 1.13.2