gem5  v22.1.0.0
sched_event.hh
Go to the documentation of this file.
1 /*
2  * Copyright 2018 Google, Inc.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are
6  * met: redistributions of source code must retain the above copyright
7  * notice, this list of conditions and the following disclaimer;
8  * redistributions in binary form must reproduce the above copyright
9  * notice, this list of conditions and the following disclaimer in the
10  * documentation and/or other materials provided with the distribution;
11  * neither the name of the copyright holders nor the names of its
12  * contributors may be used to endorse or promote products derived from
13  * this software without specific prior written permission.
14  *
15  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
18  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
21  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26  */
27 
28 #ifndef __SYSTEMC_CORE_SCHED_EVENT_HH__
29 #define __SYSTEMC_CORE_SCHED_EVENT_HH__
30 
31 #include <functional>
32 #include <list>
33 
34 #include "base/types.hh"
35 
36 namespace sc_gem5
37 {
38 
39 class ScEvent;
40 
42 
43 class ScEvent
44 {
45  private:
46  std::function<void()> work;
49  ScEvents::iterator _it;
50 
51  friend class Scheduler;
52 
53  void
55  {
56  when(w);
57  assert(!scheduled());
58  _events = &events;
59  _events->push_back(this);
60  _it = _events->end();
61  _it--;
62  }
63 
64  void
66  {
67  assert(scheduled());
68  _events->erase(_it);
69  _events = nullptr;
70  }
71  public:
72  ScEvent(std::function<void()> work) :
73  work(work), _when(gem5::MaxTick), _events(nullptr)
74  {}
75 
76  ~ScEvent();
77 
78  bool scheduled() { return _events != nullptr; }
79  ScEvents *scheduledOn() { return _events; }
80 
81  void when(gem5::Tick w) { _when = w; }
82  gem5::Tick when() { return _when; }
83 
84  void run() { deschedule(); work(); }
85 };
86 
87 } // namespace sc_gem5
88 
89 #endif // __SYSTEMC_CORE_SCHED_EVENT_HH__
Defines global host-dependent types: Counter, Tick, and (indirectly) {int,uint}{8,...
gem5::Tick _when
Definition: sched_event.hh:47
ScEvents * _events
Definition: sched_event.hh:48
gem5::Tick when()
Definition: sched_event.hh:82
ScEvents::iterator _it
Definition: sched_event.hh:49
void schedule(ScEvents &events, gem5::Tick w)
Definition: sched_event.hh:54
std::function< void()> work
Definition: sched_event.hh:46
ScEvents * scheduledOn()
Definition: sched_event.hh:79
void when(gem5::Tick w)
Definition: sched_event.hh:81
ScEvent(std::function< void()> work)
Definition: sched_event.hh:72
Bitfield< 6 > w
Definition: pagetable.hh:59
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
uint64_t Tick
Tick count type.
Definition: types.hh:58
const Tick MaxTick
Definition: types.hh:60
std::list< ScEvent * > ScEvents
Definition: sched_event.hh:39

Generated on Wed Dec 21 2022 10:22:40 for gem5 by doxygen 1.9.1