Go to the documentation of this file.
38 #ifndef __CPU_KVM_TIMER_HH__
39 #define __CPU_KVM_TIMER_HH__
91 virtual void arm(
Tick ticks) = 0;
float hostFactor
Performance scaling factor.
BaseKvmTimer(int signo, float hostFactor, Tick hostFreq)
Setup basic timer functionality shared by all timer implementations.
PerfKvmTimer(PerfKvmCounter &ctr, int signo, float hostFactor, Tick hostFreq)
Create a timer that uses an existing hardware cycle counter.
struct itimerspec prevTimerSpec
void disarm()
Disarm the timer.
Tick ticksFromHostCycles(uint64_t cycles)
Convert cycles executed on the host into Ticks executed in the simulator.
void arm(Tick ticks) override
Arm the timer so that it fires after a certain number of ticks.
An instance of a performance counter.
Tick calcResolution()
Calculate the timer resolution, used by resolution() which caches the result.
void disarm() override
Disarm the timer.
virtual Tick calcResolution()=0
Calculate the timer resolution, used by resolution() which caches the result.
uint64_t Tick
Tick count type.
Tick _resolution
Cached resolution.
Tick hostFreq
Host frequency.
Tick calcResolution() override
Calculate the timer resolution, used by resolution() which caches the result.
virtual void arm(Tick ticks)=0
Arm the timer so that it fires after a certain number of ticks.
virtual void disarm()=0
Disarm the timer.
PerfEvent based timer using the host's CPU cycle counter.
void arm(Tick ticks)
Arm the timer so that it fires after a certain number of ticks.
PosixKvmTimer(int signo, clockid_t clockID, float hostFactor, Tick hostFreq)
uint64_t hostNs(Tick ticks)
Convert a time in simulator ticks to host nanoseconds.
Timer functions to interrupt VM execution after a number of simulation ticks.
Timer based on standard POSIX timers.
int signo
Signal to deliver when the timer times out.
PerfKvmCounter & hwOverflow
Tick ticksFromHostNs(uint64_t ns)
Convert nanoseconds executed on the host into Ticks executed in the simulator.
uint64_t hostCycles(Tick ticks)
Convert a time in simulator ticks to host cycles.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Tick resolution()
Determine the resolution of the timer in ticks.
Generated on Wed Jul 13 2022 10:39:15 for gem5 by doxygen 1.8.17