diff options
| author | Marcelo Tosatti <mtosatti@redhat.com> | 2008-04-30 12:23:54 -0400 |
|---|---|---|
| committer | Avi Kivity <avi@qumranet.com> | 2008-05-04 07:44:46 -0400 |
| commit | ece15babfa514e06118f62f4df2c757d6209f4f0 (patch) | |
| tree | 46eadfa87b6adb88a2252c15f0468e8330968001 | |
| parent | dc7457ea52f88539dc72925360e6068d5c938a0f (diff) | |
KVM: PIT: support mode 4
The in-kernel PIT emulation ignores pending timers if operating under
mode 4, which for example DragonFlyBSD uses (and Plan9 too, apparently).
Mode 4 seems to be similar to one-shot mode, other than the fact that it
starts counting after the next CLK pulse once programmed, while mode 1
starts counting immediately, so add a FIXME to enhance precision.
Fixes sourceforge bug 1952988.
Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
Acked-by: Sheng Yang <sheng.yang@intel.com>
Signed-off-by: Avi Kivity <avi@qumranet.com>
| -rw-r--r-- | arch/x86/kvm/i8254.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/x86/kvm/i8254.c b/arch/x86/kvm/i8254.c index 4c943eabacc3..3324d90038e4 100644 --- a/arch/x86/kvm/i8254.c +++ b/arch/x86/kvm/i8254.c | |||
| @@ -288,6 +288,8 @@ static void pit_load_count(struct kvm *kvm, int channel, u32 val) | |||
| 288 | * mode 1 is one shot, mode 2 is period, otherwise del timer */ | 288 | * mode 1 is one shot, mode 2 is period, otherwise del timer */ |
| 289 | switch (ps->channels[0].mode) { | 289 | switch (ps->channels[0].mode) { |
| 290 | case 1: | 290 | case 1: |
| 291 | /* FIXME: enhance mode 4 precision */ | ||
| 292 | case 4: | ||
| 291 | create_pit_timer(&ps->pit_timer, val, 0); | 293 | create_pit_timer(&ps->pit_timer, val, 0); |
| 292 | break; | 294 | break; |
| 293 | case 2: | 295 | case 2: |
