Arm架构包含通用定时器(Generic Timer),这是每个处理器中都有的一组标准化定时器。通用定时器包括一组比较器,这些比较器与一个共同的系统计数进行比较。当比较器的值等于或小于系统计数时,该比较器会生成中断。在下图中,我们可以看到系统中的通用定时器(橙色)以及其比较器和计数器模块的组件。
下图显示了一个具有托管两个虚拟CPU(vCPU)的超级管理程序的示例系统:
【注意】:在这个例子中,我们忽略了运行超级管理程序以在vCPU之间进行上下文切换的开销。
经过4毫秒的物理时间或wall-clock时间后,每个vCPU都运行了2毫秒。如果vCPU0在T=0时设置了其比较器,以在3毫秒后生成中断,你是否期望中断已触发?
或者,你是想要在虚拟时间(由vCPU体验的时间)经过2毫秒后,还是在挂钟时间经过2毫秒后产生中断?
Arm架构提供了执行这两种操作的能力,具体取决于虚拟化的用途。让我们看看它是如何实现的。
在运行在vCPU上的软件可以访问两个计时器:
- EL1物理计时器
- EL1虚拟计时器
EL1物理计时器与由系统计数(system counter)模块生成的计数进行比较。使用该计时器可以获得wall-clock时间。
EL