diff options
author | Paul Mackerras <paulus@samba.org> | 2013-09-05 23:17:46 -0400 |
---|---|---|
committer | Alexander Graf <agraf@suse.de> | 2013-10-17 08:44:59 -0400 |
commit | 93b0f4dc29c5f077a1c97bd1d484147230c3779a (patch) | |
tree | 29a0e8bb164c461d26abc4aeaae8504b2ddc296b /arch/powerpc/include/asm/reg.h | |
parent | 14941789f2a13cd89e2dd567c4f708e571ab714e (diff) |
KVM: PPC: Book3S HV: Implement timebase offset for guests
This allows guests to have a different timebase origin from the host.
This is needed for migration, where a guest can migrate from one host
to another and the two hosts might have a different timebase origin.
However, the timebase seen by the guest must not go backwards, and
should go forwards only by a small amount corresponding to the time
taken for the migration.
Therefore this provides a new per-vcpu value accessed via the one_reg
interface using the new KVM_REG_PPC_TB_OFFSET identifier. This value
defaults to 0 and is not modified by KVM. On entering the guest, this
value is added onto the timebase, and on exiting the guest, it is
subtracted from the timebase.
This is only supported for recent POWER hardware which has the TBU40
(timebase upper 40 bits) register. Writing to the TBU40 register only
alters the upper 40 bits of the timebase, leaving the lower 24 bits
unchanged. This provides a way to modify the timebase for guest
migration without disturbing the synchronization of the timebase
registers across CPU cores. The kernel rounds up the value given
to a multiple of 2^24.
Timebase values stored in KVM structures (struct kvm_vcpu, struct
kvmppc_vcore, etc.) are stored as host timebase values. The timebase
values in the dispatch trace log need to be guest timebase values,
however, since that is read directly by the guest. This moves the
setting of vcpu->arch.dec_expires on guest exit to a point after we
have restored the host timebase so that vcpu->arch.dec_expires is a
host timebase value.
Signed-off-by: Paul Mackerras <paulus@samba.org>
Signed-off-by: Alexander Graf <agraf@suse.de>
Diffstat (limited to 'arch/powerpc/include/asm/reg.h')
-rw-r--r-- | arch/powerpc/include/asm/reg.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/arch/powerpc/include/asm/reg.h b/arch/powerpc/include/asm/reg.h index 10d1ef016bf1..fd4db15e6f2a 100644 --- a/arch/powerpc/include/asm/reg.h +++ b/arch/powerpc/include/asm/reg.h | |||
@@ -243,6 +243,7 @@ | |||
243 | #define SPRN_TBRU 0x10D /* Time Base Read Upper Register (user, R/O) */ | 243 | #define SPRN_TBRU 0x10D /* Time Base Read Upper Register (user, R/O) */ |
244 | #define SPRN_TBWL 0x11C /* Time Base Lower Register (super, R/W) */ | 244 | #define SPRN_TBWL 0x11C /* Time Base Lower Register (super, R/W) */ |
245 | #define SPRN_TBWU 0x11D /* Time Base Upper Register (super, R/W) */ | 245 | #define SPRN_TBWU 0x11D /* Time Base Upper Register (super, R/W) */ |
246 | #define SPRN_TBU40 0x11E /* Timebase upper 40 bits (hyper, R/W) */ | ||
246 | #define SPRN_SPURR 0x134 /* Scaled PURR */ | 247 | #define SPRN_SPURR 0x134 /* Scaled PURR */ |
247 | #define SPRN_HSPRG0 0x130 /* Hypervisor Scratch 0 */ | 248 | #define SPRN_HSPRG0 0x130 /* Hypervisor Scratch 0 */ |
248 | #define SPRN_HSPRG1 0x131 /* Hypervisor Scratch 1 */ | 249 | #define SPRN_HSPRG1 0x131 /* Hypervisor Scratch 1 */ |