gem5
v20.1.0.0
|
PerfEvent based timer using the host's CPU cycle counter. More...
#include <timer.hh>
Public Member Functions | |
PerfKvmTimer (PerfKvmCounter &ctr, int signo, float hostFactor, Tick hostFreq) | |
Create a timer that uses an existing hardware cycle counter. More... | |
~PerfKvmTimer () | |
void | arm (Tick ticks) |
Arm the timer so that it fires after a certain number of ticks. More... | |
void | disarm () |
Disarm the timer. More... | |
Public Member Functions inherited from BaseKvmTimer | |
BaseKvmTimer (int signo, float hostFactor, Tick hostFreq) | |
Setup basic timer functionality shared by all timer implementations. More... | |
virtual | ~BaseKvmTimer () |
virtual bool | expired () |
Tick | resolution () |
Determine the resolution of the timer in ticks. More... | |
Tick | ticksFromHostCycles (uint64_t cycles) |
Convert cycles executed on the host into Ticks executed in the simulator. More... | |
Tick | ticksFromHostNs (uint64_t ns) |
Convert nanoseconds executed on the host into Ticks executed in the simulator. More... | |
Protected Member Functions | |
Tick | calcResolution () |
Calculate the timer resolution, used by resolution() which caches the result. More... | |
Protected Member Functions inherited from BaseKvmTimer | |
uint64_t | hostNs (Tick ticks) |
Convert a time in simulator ticks to host nanoseconds. More... | |
uint64_t | hostCycles (Tick ticks) |
Convert a time in simulator ticks to host cycles. More... | |
Private Attributes | |
PerfKvmCounter & | hwOverflow |
Additional Inherited Members | |
Protected Attributes inherited from BaseKvmTimer | |
int | signo |
Signal to deliver when the timer times out. More... | |
PerfEvent based timer using the host's CPU cycle counter.
PerfKvmTimer::PerfKvmTimer | ( | PerfKvmCounter & | ctr, |
int | signo, | ||
float | hostFactor, | ||
Tick | hostFreq | ||
) |
Create a timer that uses an existing hardware cycle counter.
ctr | Attached performance counter configured for overflow reporting. |
signo | Signal to deliver |
hostFactor | Performance scaling factor |
hostFreq | Clock frequency of the host |
Definition at line 168 of file timer.cc.
References PerfKvmCounter::enableSignals(), hwOverflow, and BaseKvmTimer::signo.
|
virtual |
Arm the timer so that it fires after a certain number of ticks.
ticks | Number of ticks until the timer fires |
Implements BaseKvmTimer.
Definition at line 181 of file timer.cc.
References BaseKvmTimer::hostCycles(), hwOverflow, PerfKvmCounter::period(), and PerfKvmCounter::refresh().
|
protectedvirtual |
Calculate the timer resolution, used by resolution() which caches the result.
Implements BaseKvmTimer.
Definition at line 194 of file timer.cc.
References MIN_HOST_CYCLES, and BaseKvmTimer::ticksFromHostCycles().
|
virtual |
Disarm the timer.
When this method has returned, the timer may no longer deliver signals upon timeout.
Implements BaseKvmTimer.
Definition at line 188 of file timer.cc.
References hwOverflow, and PerfKvmCounter::stop().
|
private |
Definition at line 247 of file timer.hh.
Referenced by arm(), disarm(), and PerfKvmTimer().