[RFC PATCH] KVM: arm/arm64: Don't let userspace update CNTVOFF once guest is running

Marc Zyngier marc.zyngier at arm.com
Thu Jun 25 01:48:43 PDT 2015


Hi Christoffer,

On 25/06/15 09:04, Christoffer Dall wrote:
> On Wed, Jun 24, 2015 at 03:54:57PM +0100, Marc Zyngier wrote:
>> Userspace is allowed to set the guest's view of CNTVCT, which turns
>> into setting CNTVOFF for the whole VM. One thing userspace is not supposed
>> to do is to update that register while the guest is running. Time will
>> either move forward (best case) or backward (really bad idea). Either way,
>> this shouldn't happen.
>>
>> This patch prevents userspace from touching CNTVOFF as soon as a vcpu
>> has been started. This ensures that time will keep monotonically increase.
>>
>> Signed-off-by: Marc Zyngier <marc.zyngier at arm.com>
>> ---
>>
>> QEMU seems to trigger this at boot time, and I have no idea why it does so.
>> It would be good to find out, hence the RFC tag.
> 
> Is this at kernel boot time you see this, or at system startup time?

When the kernel boots. The OSV guys also have seen this (time going
backward), and this patch seems to have solved their problem.

> IIRC, QEMU creates a throw-away VM with the default CPU target time,
> reads out all the system registers to get the KVM reset values of those,
> then creates the real VM, and feeds back in all the system register
> reset values, as a method for QEMU and KVM to be in sync about the reset
> state of the machine.  If we do this, and include CNTVCT, then that
> would probably trigger this, but the VCPU really shouldn't have been run
> at that time...

I definitely see this process happening, but that doesn't seem to be the
problem.

> We should prevent userspace from fiddling with this register post VCPU
> start regardless, but yes, it would be good to find out why this is
> happening in the first place.

My main problem is that I cannot easily correlate what is happening in
the guest at that time with something touching CNTVCT. That's just odd.

> How did you notice this and does it manifest itself in some user-visible
> ugliness?

It was first reported by the OSV guys, and I then spotted some
interesting hrtimers taking too long at guest boot time. Putting some
traces quickly identified the issue.

Thanks,

	M.
-- 
Jazz is not dead. It just smells funny...



More information about the linux-arm-kernel mailing list